Shop OBEX P1 Docs P2 Docs Learn Events
New Spin - Page 13 — Parallax Forums

New Spin

1101113151636

Comments

  • cgraceycgracey Posts: 14,133
    edited 2017-02-24 03:55
    The ideas to simplify spontaneous string declarations are good.

    Here is the v16 instruction list. I already changed the bit operations to BITxx:

    https://docs.google.com/spreadsheets/d/1J-CyOON6QUvB8lMIlAMlrru7dpWtL8XInvHiAxBwStI/edit?usp=sharing
  • jmgjmg Posts: 15,145
    cgracey wrote: »
    I already changed the bit operations to BITxx:

    Shouldn't TESTB have been included in the migration to BITxx , as (eg) BITRD, since it is the means to read BIT into CY/Z ?


  • cgraceycgracey Posts: 14,133
    edited 2017-02-24 04:33
    jmg wrote: »
    cgracey wrote: »
    I already changed the bit operations to BITxx:

    Shouldn't TESTB have been included in the migration to BITxx , as (eg) BITRD, since it is the means to read BIT into CY/Z ?


    It's not too late. Those BITxx instructions don't really pop like I wish they would. Maybe a '_' chr after BIT:
    BIT_L
    BIT_H
    OUT_C
    DIR_NZ
    DRV_H
    

    I don't know. Naming is one of the biggest difficulties in programming.
  • jmgjmg Posts: 15,145
    cgracey wrote: »
    It's not too late. Those BITxx instructions don't really pop like I wish they would. Maybe a '_' chr after BIT:
    BIT_L
    BIT_H
    OUT_C
    DIR_NZ
    DRV_H
    

    I don't know. Naming is one of the biggest difficulties in programming.
    Looks fine to me, but then I'm used to using '_'. Others may not like mnemonics with "_".
    - also possible to improve 'pop' of that important suffix is
    BitL
    BitH
    OutC
    DirNZ
    DrvH
    

  • cgracey wrote:
    Those BITxx instructions don't really pop like I wish they would. Maybe a '_' chr after BIT
    jmg wrote:
    Looks fine to me, but then I'm used to using '_'. Others may not like mnemonics with "_".
    Typing efficiency is also important. The underscore requires holding down the shift key.

    Besides, after Microchip's native PIC mnemonics, anything else looks good! :)

    -Phil
  • Cluso99Cluso99 Posts: 18,069
    What is the purpose of DRVRND & FLTRND ?

    i.e. why would you want to output a random bit?
  • Cluso99Cluso99 Posts: 18,069
    cgracey wrote: »
    jmg wrote: »
    cgracey wrote: »
    I already changed the bit operations to BITxx:

    Shouldn't TESTB have been included in the migration to BITxx , as (eg) BITRD, since it is the means to read BIT into CY/Z ?


    It's not too late. Those BITxx instructions don't really pop like I wish they would. Maybe a '_' chr after BIT:
    BIT_L
    BIT_H
    OUT_C
    DIR_NZ
    DRV_H
    

    I don't know. Naming is one of the biggest difficulties in programming.
    Please no "_".

  • cgraceycgracey Posts: 14,133
    edited 2017-02-24 06:34
    Cluso99 wrote: »
    What is the purpose of DRVRND & FLTRND ?

    i.e. why would you want to output a random bit?

    Because Putin.

    Let's see if the moderators notice that.
  • cgraceycgracey Posts: 14,133
    Cluso99 wrote: »
    cgracey wrote: »
    jmg wrote: »
    cgracey wrote: »
    I already changed the bit operations to BITxx:

    Shouldn't TESTB have been included in the migration to BITxx , as (eg) BITRD, since it is the means to read BIT into CY/Z ?


    It's not too late. Those BITxx instructions don't really pop like I wish they would. Maybe a '_' chr after BIT:
    BIT_L
    BIT_H
    OUT_C
    DIR_NZ
    DRV_H
    

    I don't know. Naming is one of the biggest difficulties in programming.
    Please no "_".

    I agree.
  • cgraceycgracey Posts: 14,133
    edited 2017-02-24 06:33
    ...Besides, after Microchip's native PIC mnemonics, anything else looks good! :)

    -Phil

    My favorite was "BTFSC", which meant "bit test file register and skip if clear". In our assembly language, we renamed that to "SB". For OR, I think they had "IORWF" which meant "inclusive-OR W with file register".
  • BML
    BMH
    COUT

  • cgracey wrote: »
    Cluso99 wrote: »
    What is the purpose of DRVRND & FLTRND ?

    i.e. why would you want to output a random bit?

    Because Putin.

    Let's see if the moderators notice that.

    We're not watching :-)
  • jmgjmg Posts: 15,145
    cgracey wrote: »
    Cluso99 wrote: »
    What is the purpose of DRVRND & FLTRND ?

    i.e. why would you want to output a random bit?
    I can see uses for testing perhaps, but I think I'd rather have better open drain support, and use an extra line of code for the random pin case, than vice versa.
    There also has to be a finite silicon cost to DRVRND & FLTRND ?


  • cgraceycgracey Posts: 14,133
    jmg wrote: »
    cgracey wrote: »
    Cluso99 wrote: »
    What is the purpose of DRVRND & FLTRND ?

    i.e. why would you want to output a random bit?
    I can see uses for testing perhaps, but I think I'd rather have better open drain support, and use an extra line of code for the random pin case, than vice versa.
    There also has to be a finite silicon cost to DRVRND & FLTRND ?


    What would be needed for better open-drain support? You can always copy C or !C to a DIR bit via DIRC or DIRNC. Is there more needed?
  • jmgjmg Posts: 15,145
    cgracey wrote: »
    What would be needed for better open-drain support? You can always copy C or !C to a DIR bit via DIRC or DIRNC. Is there more needed?
    Perhaps that DIRC, DIRNC needs an alias into the BITxx group, to make it clearer you can float via CY ?

    Would that be BITFC, BITFNC or BITCF, BITNCF ?

    I can see a use where the streamer is opendrain, which I think would need a pin-config for open drain (as many MCUs have now)
    Maybe that is already there ?

  • cgraceycgracey Posts: 14,133
    jmg wrote: »
    cgracey wrote: »
    What would be needed for better open-drain support? You can always copy C or !C to a DIR bit via DIRC or DIRNC. Is there more needed?
    Perhaps that DIRC, DIRNC needs an alias into the BITxx group, to make it clearer you can float via CY ?

    Would that be BITFC, BITFNC or BITCF, BITNCF ?

    I can see a use where the streamer is opendrain, which I think would need a pin-config for open drain (as many MCUs have now)
    Maybe that is already there ?

    BITxx are general register bit operations, while DIRxx/OUTxx/FLTxx/DRVxx are DIR and OUT bit operations whose index spans 64 bits (DIRA/DIRB and OUTA/OUTB). Just use those instructions, I think.
  • jmgjmg Posts: 15,145
    cgracey wrote: »
    BITxx are general register bit operations, while DIRxx/OUTxx/FLTxx/DRVxx are DIR and OUT bit operations whose index spans 64 bits (DIRA/DIRB and OUTA/OUTB). Just use those instructions, I think.

    Oops yes, slight brain fade here, only paying half attention, and getting confused with 8051 opcodes, where the same BIT opcodes apply across all of Pin IO space and Flags and user RAM Boolean scratch bits.

  • Heater.Heater. Posts: 21,230
    Yes please. If the @, @@, @@@ chaos can be fixed that would be great.

    No to ternary operators. That is just unnecessary source code obfuscation.

    That an interesting point about variable length arguments lists using "args[]". We can add lots of Javascript features as well as C++ ones :)

    Just say no to "_".
  • cgracey wrote: »
    Cluso99 wrote: »
    What is the purpose of DRVRND & FLTRND ?

    i.e. why would you want to output a random bit?

    Because Putin.

    Let's see if the moderators notice that.

    Didn't see a thing.

  • cgracey wrote: »
    The ideas to simplify spontaneous string declarations are good.

    Here is the v16 instruction list. I already changed the bit operations to BITxx:

    https://docs.google.com/spreadsheets/d/1J-CyOON6QUvB8lMIlAMlrru7dpWtL8XInvHiAxBwStI/edit?usp=sharing
    I assume that the "EEEE" field is what used to be called the "CCCC" field? In other words, the conditional?
  • cgracey wrote: »
    One thing I'd like to do before getting this out is maybe clear up some name-space conflicts.

    NOT, AND, and OR are both PASM instructions and boolean operators. This is going to cause headaches.

    How about if, for PASM, we renamed these instructions to NOTF, ANDF, ORF and XORF (F for 'function', let's say)? XORF is just there for consistency.

    Any better idea?

    If you have inline assembly, there's no need for builtin Spin functions for PASM; instead you could create an object that has them all, and the function names would then be in the object namespace. E.g.:
    PUB notf(Dv, S) : r
      ASM
        NOT Dv, S
      ENDASM
      r := Dv
    
    and then to use it do:
      OBJ i : "instructions"
      ...
      x := i.notf(x, y)
    
    You could even have the "instructions" object built in to the interpreter and/or always loaded with a predefined name like "instr".

    This is exactly what fastspin does for most of the Spin builtins corresponding to instructions, except that it puts the function definitions into global namespace for compatibility with Spin.

    Eric
  • It seems like there is a lot of discussion on the new Spin syntax, operator names and other things that have no impact on the silicon. I thought the sudden urgency of getting Spin working on the P2 was to uncover potential issues with the hardware design before it goes out to synthesis. Changing Spin syntax and operator names doesn't do a thing toward that goal, and in fact only delays the silicon even more. I was hoping for a merry Chipmas this year, but it seems more and more doubtful when I see all the random tweaks that are suggested for New Spin.
  • TorTor Posts: 2,010
    To me ternary makes for clearer code. Not obfuscation.

    Oneliners are good. In Perl we have, for example
     something(1,2,3) if $a < 4;
     $a++ unless $a  > 10;
    
  • Some items on my Spin2 wish list:

    1. Eliminate @@ -- not to mention the hideous @@@. Make @ mean "the address of", period, regardless of context. IOW, figure out the actual address at compile time, even if it means an extra compile pass or two, or maybe even a linking phase. In Spin, @ vs. @@ causes a lot of confusion, and neither is entirely adequate for the simple job they're supposed to perform.
    Good idea, this is one place where breaking backwards compatibility with Spin would probably be worth it.
    2. Add the ternary operator: condition ? eval_if_true : eval_if_false. Probably have to use ?? and :: to avoid ambiguity with the random operator.
    fastspin has x := if condition then eval_if_true else eval_if_false. This means adding one keyword, "then", but I think it's easier to read than C's version.
    3. Something better has to be done with strings. Although the utility of string(...) for comma-separated lists is indisputable, it is pretty wordy, especially for simple strings like "abcdef". It would be nice to come up with some sort of shorthand notation. Maybe let a simple "abc" return a pointer the way string does. But what to do about "a", which returns $61 now. Require a pseudo-function, like ord? Actually, ord would be handy for strings up to 4 bytes in length, since they can be packed into a long.
    I agree, this is another place where Spin could be improved on. Many languages have different syntax for single characters than strings. SIngle quotes are taken, unfortunately, but maybe &x could mean "character x"? Or we could just require people to subscript, like "a"[0], but that's a bit of a pain.
    4. "Lazy" Booleans (e.g. && ||). If the outcome of a Boolean expression is known before completion, quit evaluating the rest of it.
    Oops, looks like I got this wrong -- I thought Spin AND and OR already worked this way! I think personally there's no harm in changing AND and OR to short-circuit evaluation for Spin2 -- the results are already the same except for side effects.
    5. Variable-length argument lists. Allow stuff like
    my_sum := sum(12, a, $56, x)
    
    PUB sum(count, args[]) | i
      repeat i from 0 to count - 1
        result += args[i]
    
    where count is implicitly assigned the value 4 in the above method call. This would come especially handy in formatting routines, where you have a format string à la printf, followed by a list of values to print.

    This seems like a nice idea, although I'd probably swap the order of the count and array (that way there's no ambiguity about whether count is a user parameter or not -- anything after an array parameter is something inserted by the compiler.

    Eric
  • Cluso99Cluso99 Posts: 18,069
    edited 2017-02-24 14:28
    Propeller P16X64A Instruction Summary v16.0 24Feb2017
    *=postedit
    Cond Opcode  CZ I Dest      Source    Instr00 01      10      11      Operand(s)                                             Flags
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 00000ff CZ I DDDDDDDDD SSSSSSSSS ROR     ROL     SHR     SHL     D,{#}S                                                 CZ CZ CZ CZ
    EEEE 00001ff CZ I DDDDDDDDD SSSSSSSSS RCR     RCL     SAR     SAL     D,{#}S                                                 CZ CZ CZ CZ
    EEEE 00010ff CZ I DDDDDDDDD SSSSSSSSS ADD     ADDX    ADDS    ADDSX   D,{#}S                                                 CZ CZ CZ CZ
    EEEE 00011ff CZ I DDDDDDDDD SSSSSSSSS SUB     SUBX    SUBS    SUBSX   D,{#}S                                                 CZ CZ CZ CZ
    EEEE 00100ff CZ I DDDDDDDDD SSSSSSSSS CMP     CMPX    CMPS    CMPSX   D,{#}S                                                 CZ CZ CZ CZ
    EEEE 00101ff CZ I DDDDDDDDD SSSSSSSSS CMPR    CMPM    SUBR    CMPSUB  D,{#}S                                                 CZ CZ CZ CZ
    EEEE 00110ff CZ I DDDDDDDDD SSSSSSSSS MIN     MAX     MINS    MAXS    D,{#}S                                                 CZ CZ CZ CZ
    EEEE 00111ff CZ I DDDDDDDDD SSSSSSSSS SUMC    SUMNC   SUMZ    SUMNZ   D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01000ff CZ I DDDDDDDDD SSSSSSSSS BITL    BITH    BITC    BITNC   D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01001ff CZ I DDDDDDDDD SSSSSSSSS BITZ    BITNZ   BITN    BITX    D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01010ff CZ I DDDDDDDDD SSSSSSSSS ANDN    AND     OR      XOR     D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01011ff CZ I DDDDDDDDD SSSSSSSSS MUXC    MUXNC   MUXZ    MUXNZ   D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01100ff CZ I DDDDDDDDD SSSSSSSSS MOV     NOT     ABS     NEG     D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01101ff CZ I DDDDDDDDD SSSSSSSSS NEGC    NEGNC   NEGZ    NEGNZ   D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01110ff CZ I DDDDDDDDD SSSSSSSSS INCMOD  DECMOD  TOPONE  BOTONE  D,{#}S                                                 CZ CZ CZ CZ
    EEEE 01111ff CZ I DDDDDDDDD SSSSSSSSS TESTN   TEST    ANYB    TESTB   D,{#}S                                                 CZ CZ CZ CZ
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 1000ffN NN I DDDDDDDDD SSSSSSSSS SETNIB  GETNIB  ROLNIB  xxx     D,{#}S,#N                                              -- -- --    *
    EEEE 100011f NN I DDDDDDDDD SSSSSSSSS SETBYTE GETBYTE                 D,{#}S,#N                                              -- --      
    EEEE 1001000 NN I DDDDDDDDD SSSSSSSSS ROLBYTE                         D,{#}S,#N                                              --         
    EEEE 1001001 fn I DDDDDDDDD SSSSSSSSS SETWORD GETWORD                 D,{#}S,#N                                              -- --      
    EEEE 1001010 0N I DDDDDDDDD SSSSSSSSS ROLWORD                         D,{#}S,#N                                              --         
    EEEE 1001010 1f I DDDDDDDDD SSSSSSSSS ALTSN   ALTGN                   D,{#}S                                                 -- --      
    EEEE 1001011 ff I DDDDDDDDD SSSSSSSSS ALTSB   ALTGB   ALTSW   ALTGW   D,{#}S                                                 -- -- -- --
    EEEE 1001100 ff I DDDDDDDDD SSSSSSSSS ALTR    ALTD    ALTS    ALTB    D,{#}S                                                 -- -- -- --
    EEEE 1001101 ff I DDDDDDDDD SSSSSSSSS ALTI    SETR    SETD    SETS    D,{#}S                                                 -- -- -- --
    EEEE 1001110 ff I DDDDDDDDD SSSSSSSSS BMASK   BMASKN  TRIML   TRIMR   D,{#}S                                                 -- -- -- --
    EEEE 1001111 ff I DDDDDDDDD SSSSSSSSS DECOD   REV     MOVBYTS SFUNC   D,{#}S                                                 -- -- -- --
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 1001111 11 1 DDDDDDDDD 0000000ff SPLITB  MERGEB  SPLITW  MERGEW  D            \ SFUNC                                   -- -- -- -- *
    EEEE 1001111 11 1 DDDDDDDDD 0000001ff SEUSSF  SEUSSR  RGBSQZ  RGBEXP  D            /                                         -- -- -- -- *
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 101000f fZ I DDDDDDDDD SSSSSSSSS MUL     MULS    SCLU    SCL     D,{#}S                                                 -Z -Z -Z -Z
    EEEE 1010010 ff I DDDDDDDDD SSSSSSSSS ADDPIX  MULPIX  BLNPIX  MIXPIX  D,{#}S                                                 -- -- -- --
    EEEE 1010011 ff I DDDDDDDDD SSSSSSSSS ADDCT1  ADDCT2  ADDCT3  WMLONG  D,{#}S;D,{#}S;D,{#}S;D,{#}S/PTRx                       -- -- -- --
    EEEE 1010100 Cf I DDDDDDDDD SSSSSSSSS RQPIN   RDPIN                   D,{#}S                                                 C- C-      
    EEEE 1010101 CZ I DDDDDDDDD SSSSSSSSS RDLUT                           D,{#}S                                                 CZ         
    EEEE 101011f CZ I DDDDDDDDD SSSSSSSSS RDBYTE  RDWORD                  D,{#}S/PTRx                                            CZ CZ      
    EEEE 101100f CZ I DDDDDDDDD SSSSSSSSS RDLONG  CALLD                   D,{#}S/PTRx;D,{#}S                                     CZ CZ      
    EEEE 1011010 ff I DDDDDDDDD SSSSSSSSS IJZ     IJNZ    IJS     IJNS    D,{#}S                                                 -- -- -- --
    EEEE 1011011 ff I DDDDDDDDD SSSSSSSSS DJZ     DJNZ    DJS     DJNS    D,{#}S                                                 -- -- -- --
    EEEE 1011100 ff I DDDDDDDDD SSSSSSSSS TJZ     TJNZ    TJS     TJNS    D,{#}S                                                 -- -- -- --
    EEEE 1011101 fL I DDDDDDDDD SSSSSSSSS JP      JNP                     {#}D,{#}S                                              -- --      
    EEEE 1011110 fL I DDDDDDDDD SSSSSSSSS CALLPA  CALLPB                  {#}D,{#}S                                              -- --      
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 1011111 01 I 0000000ff SSSSSSSSS JINT    JCT1    JCT2    JCT3    {#}S                                                   -- -- -- --
    EEEE 1011111 01 I 0000001ff SSSSSSSSS JSE1    JSE2    JSE3    JSE4    {#}S                                                   -- -- -- --
    EEEE 1011111 01 I 0000010ff SSSSSSSSS JPAT    JFBW    JXMT    JXFI    {#}S                                                   -- -- -- --
    EEEE 1011111 01 I 0000011ff SSSSSSSSS JXRO    JXRL    JATN    JQMT    {#}S                                                   -- -- -- --
    EEEE 1011111 01 I 0000100ff SSSSSSSSS JNINT   JNCT1   JNCT2   JNCT3   {#}S                                                   -- -- -- --
    EEEE 1011111 01 I 0000101ff SSSSSSSSS JNSE1   JNSE2   JNSE3   JNSE4   {#}S                                                   -- -- -- --
    EEEE 1011111 01 I 0000110ff SSSSSSSSS JNPAT   JNFBW   JNXMT   JNXFI   {#}S                                                   -- -- -- --
    EEEE 1011111 01 I 0000111ff SSSSSSSSS JNXRO   JNXRL   JNATN   JNQMT   {#}S                                                   -- -- -- --
    EEEE 1011111 1L I DDDDDDDDD SSSSSSSSS SETPAT                          {#}D,{#}S                                              --         
    ---------------------------------------------------------------------------------------------------------------------------------------- *
    EEEE 110000f fL I DDDDDDDDD SSSSSSSSS WRPIN   WXPIN   WYPIN   WRLUT   {#}D,{#}S                                              -- -- -- --
    EEEE 110001f fL I DDDDDDDDD SSSSSSSSS WRBYTE  WRWORD  WRLONG  RDFAST  {#}D,{#}S/PTRx;{#}D,{#}S/PTRx;{#}D,{#}S/PTRx;{#}D,{#}S -- -- -- --
    EEEE 110010f fL I DDDDDDDDD SSSSSSSSS WRFAST  FBLOCK  XINIT   XZERO   {#}D,{#}S                                              -- -- -- --
    EEEE 1100110 fL I DDDDDDDDD SSSSSSSSS XCONT   REP                     {#}D,{#}S                                              -- --      
    EEEE 1100111 CL I DDDDDDDDD SSSSSSSSS COGINIT                         {#}D,{#}S                                              C-         
    EEEE 110100f fL I DDDDDDDDD SSSSSSSSS QMUL    QDIV    QFRAC   QSQRT   {#}D,{#}S                                              -- -- -- --
    EEEE 1101010 fL I DDDDDDDDD SSSSSSSSS QROTATE QVECTOR                 {#}D,{#}S                                              -- --      
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 1101011 C0 L DDDDDDDDD 0000000ff CLKSET  COGID   COGSTOP LOCKNEW {#}D;{#}D;{#}D;D                                       C- C- -- C-
    EEEE 1101011 C0 0 DDDDDDDDD 0000001ff LOCKNEW LOCKRET LOCKCLR LOCKSET D;{#}D;{#}D;{#}D                                       C- -- C- C-
    EEEE 1101011 CZ L DDDDDDDDD 0000010ff <spare> <spare> <spare> <spare> {#}D                                                   CZ CZ CZ CZ *
    EEEE 1101011 CZ L DDDDDDDDD 0000011ff <spare> <spare> <spare> <spare> {#}D                                                   CZ CZ CZ CZ *
    EEEE 1101011 CZ 0 DDDDDDDDD 0000100ff RFBYTE  RFWORD  RFLONG  WFBYTE  D;D;D;{#}D                                             CZ CZ CZ --
    EEEE 1101011 00 L DDDDDDDDD 0000101ff WFWORD  WFLONG  SETQ    SETQ2   {#}D                                                   -- -- -- --
    EEEE 1101011 CZ 0 DDDDDDDDD 0000110ff GETQX   GETQY   GETCT   GETRND  D;D;D;{D}                                              CZ CZ -- CZ
    EEEE 1101011 00 L DDDDDDDDD 0000111ff SETDACS SETXFRQ GETXCOS GETXSIN {#}D;{#}D;D;D                                          -- -- -- --
    EEEE 1101011 00 L DDDDDDDDD 0001000ff SETSE1  SETSE2  SETSE3  SETSE4  {#}D                                                   -- -- -- --
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 1101011 C0 0 0000000ff 000100100 POLLINT POLLCT1 POLLCT2 POLLCT3                                                        C- C- C- C-
    EEEE 1101011 C0 0 0000001ff 000100100 POLLSE1 POLLSE2 POLLSE3 POLLSE4                                                        C- C- C- C-
    EEEE 1101011 C0 0 0000010ff 000100100 POLLPAT POLLFBW POLLXMT POLLXFI                                                        C- C- C- C-
    EEEE 1101011 C0 0 0000011ff 000100100 POLLXRO POLLXRL POLLATN POLLQMT                                                        C- C- C- C-
    EEEE 1101011 C0 0 0000100ff 000100100 WAITINT WAITCT1 WAITCT2 WAITCT3                                                        C- C- C- C-
    EEEE 1101011 C0 0 0000101ff 000100100 WAITSE1 WAITSE2 WAITSE3 WAITSE4                                                        C- C- C- C-
    EEEE 1101011 C0 0 0000110ff 000100100 WAITPAT WAITFBW WAITXMT WAITXFI                                                        C- C- C- C-
    EEEE 1101011 C0 0 0000111ff 000100100 WAITXRO WAITXRL WAITATN ALLOWI                                                         C- C- C- --
    EEEE 1101011 00 0 0001000ff 000100100 ALLOWI  STALLI  TRGINT1 TRGINT2                                                        -- -- -- --
    EEEE 1101011 00 0 0001001ff 000100100 TRGINT3 NIXINT1 NIXINT2 NIXINT3                                                        -- -- -- --
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 1101011 00 0 DDDDDDDDD 0001001ff xxx     SETINT1 SETINT2 SETINT3 {#}D                                                   -- -- -- -- *
    EEEE 1101011 00 L DDDDDDDDD 0001010ff WAITX   SETCZ   PUSH    POP     {#}D;{#}D;{#}D;D                                       -- CZ -- CZ
    EEEE 1101011 CZ 0 DDDDDDDDD 0001011ff JMP     CALL    CALLA   CALLB   D                                                      CZ CZ CZ CZ
    EEEE 1101011 00 L DDDDDDDDD 0001100ff JMPREL  RET     RETA    RETB    {#}D;;;                                                -- CZ CZ CZ
    EEEE 1101011 00 0 DDDDDDDDD 0001101ff GETPTR  GETINT  SETBRK  SETLUT  D;D;{#}D;{#}D                                          -- -- -- --
    EEEE 1101011 00 L DDDDDDDDD 0001110ff SETCY   SETCI   SETCQ   SETCFRQ {#}D                                                   -- -- -- --
    EEEE 1101011 00 L DDDDDDDDD 0001111ff SETCMOD SETPIX  SETPIV  COGATN  {#}D                                                   -- -- -- --
    EEEE 1101011 CZ L DDDDDDDDD 0010000ff DIRL    DIRH    DIRC    DIRNC   {#}D                                                   CZ CZ CZ CZ
    EEEE 1101011 CZ L DDDDDDDDD 0010001ff DIRZ    DIRNZ   DIRN    TESTNIN {#}D                                                   CZ CZ CZ CZ
    EEEE 1101011 CZ L DDDDDDDDD 0010010ff OUTL    OUTH    OUTC    OUTNC   {#}D                                                   CZ CZ CZ CZ
    EEEE 1101011 CZ L DDDDDDDDD 0010011ff OUTZ    OUTNZ   OUTN    TESTIN  {#}D                                                   CZ CZ CZ CZ
    EEEE 1101011 CZ L DDDDDDDDD 0010100ff FLTL    FLTH    FLTC    FLTNC   {#}D                                                   CZ CZ CZ CZ
    EEEE 1101011 CZ L DDDDDDDDD 0010101ff FLTZ    FLTNZ   FLTN    FLTRND  {#}D                                                   CZ CZ CZ CZ
    EEEE 1101011 CZ L DDDDDDDDD 0010110ff DRVL    DRVH    DRVC    DRVNC   {#}D                                                   CZ CZ CZ CZ
    EEEE 1101011 CZ L DDDDDDDDD 0010111ff DRVZ    DRVNZ   DRVN    DRVRND  {#}D                                                   CZ CZ CZ CZ
    ----------------------------------------------------------------------------------------------------------------------------------------
    EEEE 11011ff RA A AAAAAAAAA AAAAAAAAA JMP     CALL    CALLA   CALLB   #A                                                     -- -- -- --
    EEEE 1110fWW RA A AAAAAAAAA AAAAAAAAA CALLD   LOC                     PA/PB/PTRA/PTRB,#A                                     -- --      
    EEEE 1111fNN NN N NNNNNNNNN NNNNNNNNN AUGS    AUGD                    #N                                                     -- --      
    
  • Cluso99Cluso99 Posts: 18,069
    cgracey wrote: »
    ...Besides, after Microchip's native PIC mnemonics, anything else looks good! :)

    -Phil

    My favorite was "BTFSC", which meant "bit test file register and skip if clear". In our assembly language, we renamed that to "SB". For OR, I think they had "IORWF" which meant "inclusive-OR W with file register".

    My favourite was BANDCF = Branch and catch fire !
  • cgracey wrote: »
    THE VERILOG IS FINISHED.

    ALELUYA !

  • cgracey wrote: »
    Cluso99 wrote: »
    What is the purpose of DRVRND & FLTRND ?

    i.e. why would you want to output a random bit?

    Because Putin.

    Let's see if the moderators notice that.

    Remember, the is no Moderation in P2 forums. :)

  • Publison wrote: »
    Remember, the is no Moderation in P2 forums. :)

    Is it no moderation forever or only until P2 goes on sale.
  • Publison wrote: »
    Remember, the is no Moderation in P2 forums. :)

    Is it no moderation forever or only until P2 goes on sale.

    That's up to Ken and Chip.

Sign In or Register to comment.