Shop OBEX P1 Docs P2 Docs Learn Events
The unofficial P2 documentation project - Page 6 — Parallax Forums

The unofficial P2 documentation project

13468913

Comments

  • Bill HenningBill Henning Posts: 6,445
    edited 2012-12-14 05:23
    Thanks Chip!
  • BeanBean Posts: 8,129
    edited 2012-12-14 07:14
    I was reading the Prop2_docs.txt file that Chip posted today.

    When describing the REPS instruction it says it can repeat 1..16,384 times. But then in the example code it is set to repeat 20,000 times ???

    Bean
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2012-12-14 07:34
    Bean wrote: »
    I was reading the Prop2_docs.txt file that Chip posted today.

    When describing the REPS instruction it says it can repeat 1..16,384 times. But then in the example code it is set to repeat 20,000 times ???

    Bean
    Well it looks like you only have 13 bits for the count but there's another bit tucked away in bit 25!
    000011 n11 1 nnnn nnnnnnnnn 001iiiiii

    Scrub that, 14 bits are only 16,384 anyway....I'll have to have a closer look but it's getting a bit late.
  • BEEPBEEP Posts: 58
    edited 2012-12-14 08:44
    cgracey wrote: »
    I updated the doc's to include the instruction-block repeaters:

    Prop2_Docs.txt

    Here's the new part:

    txt to pdf
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-14 10:47
    Chip: Thanks for the new instruction formats.
    I have updated my summary and posted below.

    I note that the following instructions are no longer valid.
    [TABLE="width: 498"]
    [TR]
    [TD="width: 10%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]SETSQRT
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [TD="width: 12%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]D/#n
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Start      SQRT[31..0] = D/#n (for square root calc)  (r=1 for #n)
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [/TR]
    [TR]
    [TD="width: 10%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]SETQM
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [TD="width: 12%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]D/#n
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]QSINCOS/QARCTAN/QROTATE 0=Circular, 1=Hyperbolic mode (r=1 for #n)
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [/TR]
    [TR]
    [TD="width: 22%, bgcolor: #FF6600, colspan: 2"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]CHKSPD
    [/SIZE][/FONT][/SIZE][/FONT] 
    [/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Compare SPA=<SPB                          (CLUT/FIFO stack pointers)
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [/TR]
    [TR]
    [TD="width: 22%, bgcolor: #FF6600, colspan: 2"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]CHKSPA
    [/SIZE][/FONT][/SIZE][/FONT] 
    [/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Compare SPA==0                            (CLUT/FIFO stack pointers)
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [/TR]
    [TR]
    [TD="width: 22%, bgcolor: #FF6600, colspan: 2"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]CHKSPB
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Compare SPB==0                            (CLUT/FIFO stack pointers)
    [/SIZE][/FONT][/SIZE][/FONT]
    [/TD]
    [/TR]
    [/TABLE]
    
    

    P2_Instructions(9).zip
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2012-12-14 15:42
    Cluso99 wrote: »
    Chip: Thanks for the new instruction formats.
    I have updated my summary and posted below.

    I note that the following instructions are no longer valid.
    [TABLE="width: 498"]
    [TR]
    [TD="width: 10%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]SETSQRT
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [TD="width: 12%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]D/#n
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Start      SQRT[31..0] = D/#n (for square root calc)  (r=1 for #n)
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [/TR]
    [TR]
    [TD="width: 10%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]SETQM
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [TD="width: 12%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]D/#n
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]QSINCOS/QARCTAN/QROTATE 0=Circular, 1=Hyperbolic mode (r=1 for #n)
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [/TR]
    [TR]
    [TD="width: 22%, bgcolor: #FF6600, colspan: 2"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]CHKSPD
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Compare SPA=<SPB                          (CLUT/FIFO stack pointers)
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [/TR]
    [TR]
    [TD="width: 22%, bgcolor: #FF6600, colspan: 2"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]CHKSPA
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Compare SPA==0                            (CLUT/FIFO stack pointers)
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [/TR]
    [TR]
    [TD="width: 22%, bgcolor: #FF6600, colspan: 2"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]CHKSPB
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [TD="width: 78%, bgcolor: #FF6600"][FONT=Courier][SIZE=1][FONT=Courier][SIZE=1]Compare SPB==0                            (CLUT/FIFO stack pointers)
    [/SIZE][/FONT][/SIZE][/FONT][/TD]
    [/TR]
    [/TABLE]
    
    
    
    

    P2_Instructions(9).zip
    I just checked Chip's list in post #151 and GETSQRT is there but only in the D form, seems the immediate mode is dropped.

    Scrub that, I didn't read the attachement properly, it's SETSQRT
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-14 19:19
    Chip:
    I see that in the latest instruction list
    SUBR
    INCMOD
    DECMOD
    I presume these insructions require that the R (WR) bit =1 to distinguish them from their other opcodes with R=0.
  • SapiehaSapieha Posts: 2,964
    edited 2012-12-15 07:31
    Hi Chip.

    None of documents still describe that ones.
    Machine Code                            |    Mnemonic    |    Operand    |    Operation
    ----------------------------------------------------------------------------------------------
    ????                                        NOP
    ????                                        RET
    ????                                        CALL
    ????                                        JMP
    
    
  • David BetzDavid Betz Posts: 14,516
    edited 2012-12-15 08:04
    Sapieha wrote: »
    Hi Chip.

    None of documents still describe that ones.
    Machine Code                            |    Mnemonic    |    Operand    |    Operation
    ----------------------------------------------------------------------------------------------
    ????                                        NOP
    ????                                        RET
    ????                                        CALL
    ????                                        JMP
    
    
    RET, CALL, and JMP are just JMPRET instructions.
  • SapiehaSapieha Posts: 2,964
    edited 2012-12-15 08:12
    David.

    You write to me obvious things.

    If You look correctly -- You will find what I ask Chip!
  • David BetzDavid Betz Posts: 14,516
    edited 2012-12-15 09:02
    Sapieha wrote: »
    David.

    You write to me obvious things.

    If You look correctly -- You will find what I ask Chip!
    Sorry. I guess you're looking for documentation to show that these are really the same opcode? I guess I should have known that since you obviously would know that those are all the same instruction. :-)
  • SapiehaSapieha Posts: 2,964
    edited 2012-12-15 09:04
    Hi David.

    Still for be correct in my version of Instructions manual --- I need that info from Chip.

    Not assumptions from You!
    David Betz wrote: »
    Sorry. I guess you're looking for documentation to show that these are really the same opcode? I guess I should have known that since you obviously would know that those are all the same instruction. :-)
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-15 10:28
    Sapieha: There is no reason to have a separate NOP instruction (as in fact we didn't in P1). I presume the compiler (you can see what pnut.exe outputs) will continue to output 32x 0's, but NOPX #1 (or NOPX #0 ??? see below) would be equally correct, along with any opcode other than REPS together with cccc=0000. REPS is opcode 3 with some other bits set to distinguish it from others.

    This brings up the question (because of REPD/REPS), does NOPX #1 repeat NOP 1 or 2 executions???

    Did anyone see an explanation of JP & JNP & SUBR anywhere. I seem to have missed if/where I saw it.

    BTW Here is my latest P2 Instruction Summary using Chips latest opcode list. IT is an Excel Spreadsheet zipped.
    P2_Instructions(10).zip
  • SapiehaSapieha Posts: 2,964
    edited 2012-12-15 15:27
    Hi Peter.

    COG picture need addition of.

    4 x Regs.CFGPINS
    Machine Code                            |    Mnemonic    |    Operand    |    Operation
    ----------------------------------------------------------------------------------------------
    000011 ZCN 1 CCCC DDnnDDDDD 011100011    |    SETPORT        |    D/#n    | Assign which port the CFGPINS instruction will configure
                                                                              | given register “D (0-511)” or number “n (0-3)”.
    111010 000 I CCCC DDDDDDDDD SSSSSSSSS    |    CFGPINS        |    D/#n    | Setup pins masked by register “D (0-511)” to register
                                                                              | “S (0-511)”. The pin configuration modes are below.
                                                                              | (waits for alt)
    
    
  • Bob Lawrence (VE1RLL)Bob Lawrence (VE1RLL) Posts: 1,720
    edited 2012-12-15 16:11
    @Cluso99

    re:
    BTW Here is my latest P2 Instruction Summary using Chips latest opcode list. IT is an Excel Spreadsheet zipped.
    P2_Instructions(10).zip

    T
    hat's looking real good and very helpful. Thanks!

    Bob
  • AribaAriba Posts: 2,690
    edited 2012-12-15 18:20
    Cluso99 wrote: »
    Did anyone see an explanation of JP & JNP & SUBR anywhere. I seem to have missed if/where I saw it.

    P2_Instructions(10).zip

    SUBR is subtract reverse: D = S - D, while normal SUB is D = D - S
    JP and JNP I guess they work like that:
    JP D,S : if Pin D <> 0 jump to S / #S
    JNP D,S : if Pin D == 0 jump to S / #S

    Andy
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-15 22:02
    @Cluso99

    re:
    BTW Here is my latest P2 Instruction Summary using Chips latest opcode list. IT is an Excel Spreadsheet zipped.
    P2_Instructions(10).zip

    T
    hat's looking real good and very helpful. Thanks!

    Bob
    Thanks Bob. My earlier posts were a zipped Excel spreadsheet but I just came to realise probably most did not know that.

    When Chip posted the later opcodes a few posts back, I just imported them into the spreadsheed, sorted them to align with my prior instruction set, and used formulae to copy them into my part of the spreadsheet, then deleted the imported data. Most of the hard written docs I had done earlier. Then a re-sort.

    Andy: Thanks for the SUBR instruction. Yes, I have guessed the JP/JPD/HNP/JNPD are something like that although probably the D is a mask where bits=1 are the bits to be tested. The jump has to be to the [#]S location to be consistent with other jumps.

    There are only a few instruction details I am not happy with atm.
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-16 01:17
    Chip: You previously asked if anyone had a specific shift style instruction. I see you have a spare slot opcode 000011 S 01000 marked <empty>.

    I am unsure of how difficult this is, whether you have time, if there is any risk, and if you consider this useful to others besides me. So I will just put it out there for you.

    In my faster interpreter, and in ZiCog, for each base 8 bit instruction I used this value as an offset into a table of 256 longs (I refer to them as a vector table). Each long had 3 9 bit cog addresses (vectors) for jump/call tables. This allowed me to divide the ops into up to 3 sets of routines. Of course, some of these routines were common to many ops. So each time I grabbed a new vector, I either jumped or called the address sitting in the lowest 9 bits of the long vector I had fetched. If the op needed a 2nd routine then I would shift the vector 9 bits right and again perform a jump/call. Likewise, if a 3rd routine was required, I would again shift right 9 bits and jump/call. I also used the top 5 bits as flags to do certain things within my routines. Now as these vectors shifted right, so would these 5 bits of flags.

    What would be nice, would be an instruction that shifted only the right 27 bits (3x9) right 9 places leaving the top 5 bits in place. It would also be nice to clear the 9 bits 26..18 after the shift although this is not absolutely necessary.

    As a bonus, it could be nice to shift left the top 5 bits a number of places left, inserting 0's in their place.
    Here is what the P1/P2 equivalent instructions would be like to achieve this...
    DAT
    ' Simplest basic instruction...
    '   Shift bits 26..0 (or 26..9) >> 9 leaving bits 31..27 untouched...
    ' 000011_ZCN_1_CCCC_DDDDDDDDD_01000xxxx   S27R9 D  'xxxx=0000 (leaves another 15 possible instructions)
    ' Shifts D[26..0] >> 9 then clears D[28..18]=0 leaving D[31..27] untouched
    '             S27R9     vector                  ' new instruction simulated by P1/P2
    S27R9         mov       t1,vector               ' take a copy
                  and       t1,top5                 ' extract top 5 bits for later
                  shr       vector,#9               ' shift all bits right 9, bringing in 9x 0's at the top
                  and       vector,bottom18         ' extract lower 18 bits (2x 9) <This could be optional>
                  or        vector,t1               ' put back the top 5 bits
    
    vector        long      (%10101 << 27) | (101101101 << 18) | (010010010 << 9) | (111000111)   ' 5 bits plus 3x 9bit cog addresses
    'the following are just to be able to show the instructions but would not be required with the new instruction
    t1            long      0                       ' temporary register
    top5          long      %11111_000000000_000000000_000000000    ' mask to extract top     5 bits[31..27]
    bottom18      long      %00000_000000000_111111111_111111111    ' mask to extract bottom 18 bits[17..0]
    
    '   Perhaps a second instruction or variant using S[0]=1 
    ' 000011_ZCN_1_CCCC_DDDDDDDDD_01000xxx1   S27R9L2 D 'xxx-=000x (leaves another 14 possible instructions)
    ' Shifts D[26..0] >> 9 plus shifts D[31..27] << 2 then clears D[28..18]=0
    
  • Roy ElthamRoy Eltham Posts: 3,000
    edited 2012-12-16 02:47
    Cluso99,
    Perhaps a more general set of instructions that could still work for you are this: SWAPDS & SWAPIS (maybe more variants would be needed). It would require your data to be in 9 5 9 9 format instead of 5 9 9 9 format. So instead of shifting, you just swap things into S and then jmp/call to S.

    I'm just offering this up as an alternative solution. If Chip does end up doing another change in the Verilog he might slip something like this in. I'm not suggesting he do one just for this, since it costs them a decent chunk of change each time.

    Roy
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-16 13:06
    Roy: My alternative is to just copy the vector twice, or keep track of where the upper 5 bits are. But with the instruction I described, provided it replaces the 9 bits shifted with 0's, what I end up with is a set of vectors that will store "0" once all the vectors have been executed. So I can just place an instruction at cog $0 and can continue to do my jump/call. So if the instruction only has 2 vectors used, the third will be previously set to $0. So it saves me checking the number of routines executed. I couldn't do this before.

    I am sure there are additional ways I can do this with a special instruction. I did not want to try and make this special instruction too complicated, although I can think of a few ways to increase its possible use by utilising those 4 unused S bits.

    I will continue to think about it, and to check my faster spin interpreter, to see if there is a better way with a special instruction. Meanwhile, I will await Chips reply to see if this is worthwhile pursuing some more over the next couple of days.
  • Roy ElthamRoy Eltham Posts: 3,000
    edited 2012-12-16 15:50
    Cluso99,
    Ok, yeah, I see the need for the clearing now. The most general case instructions I could think of require 15 bits of input data (which I don't think is available anymore). It would be a SHFR, SHFL, & SAFR. Same as SHR, SHL, and SAR except you speficy the upper and lower bounds of the field (5 bits each) along the shift amount (5 bits). Normal shifting clears the bits that are left behind, SAR clears or sets based on the upper bit, so it would work for you I think.
  • SapiehaSapieha Posts: 2,964
    edited 2012-12-16 19:21
    Hi Chip.

    If You have still some instructions space why instead of adding extra shift --- Don't add one more SPx ---- SPC so it can be possible use CLUT at both Stack and Ring-buffer
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-18 01:03
    Chip:

    I have been looking at the instruction summary (I have attached my latest spreadsheet here in zipped format)...

    Since the work has begun on combining the P2 logic with the frame, I expect there will be no further changes to the P2 unless further bug(s) are found.

    For the documents, here are a few questions, and also suggestions for possible future use by imposing some restrictions (aided by compiler restrictions):
    1. SUBR, CMPSUB, INCMOD, DECMOD require WR (R=1) for correct decoding of their respective related instructions with NR (R=0). (see above posts)
    2. Isn't CMPS a SUBS with NR ? and Isn't CMPSX a SUBSX with NR ? If so, this would save 2 opcodes for later. Make the compiler utilise SUBS/SUBSX NR coding for CMPS and CMPSX.
    3. ROR, ROL, SHR, SHL, RCR, RCL, SAR, REV require that S[8..5] be set to 0000. This would permit possible future enhancements to these instructions by utilising these additional 4 bits. (my request above for a new shift instruction could fit in here at some later time)
    4. ENC could have WR (R=1) permanently, so providing another instruction(s) with NR (R=0) later.
    5. IJZ, IJZD, IJNZ, IJNZD and DJZ, DJZD, DJNZ, DJNZD and TJZ, TJZD, TJNZ, TJNZD and JP, JPD, JNP, JNPD use 3 opcodes. Unless I missed a use for IJxx and DJxx having the NR (R=0) option, then if you need another code change to the P2, these instructions could share 2 opcodes where the TJxx and JPxx have NR (R=0) and IJxx and DJxx have the WR (R=1). This would leave another opcode free. WAITVID (and DECMOD) could then move to opcode 111110 (puts it next to the other WAITCNT, WAITPEQ, WAITPNE opcode) - more logical in the summary???
    6. I note many of the opcode 000011 instructions with a D operand have the option for #n. Is this the case for all these opcodes where there is a D operand?
    P2_Instructions(11).zip
  • cgraceycgracey Posts: 14,206
    edited 2012-12-18 17:29
    I just finished documenting the hub counter instructions (at the end):

    Prop2_Docs.txt
  • jmgjmg Posts: 15,175
    edited 2012-12-18 17:48
    cgracey wrote: »
    I just finished documenting the hub counter instructions (at the end):
    000011 000 1 CCCC DDDDDDDDD 000001101        PASSCNT D       'loops until CNTL passes D            1*
    111111 0CR I CCCC DDDDDDDDD SSSSSSSSS        WAITCNT D,S     'wait for CNTL or CNT (WC), D += S    ?
    111111 110 I CCCC DDDDDDDDD SSSSSSSSS        WAITPEQ D,S  WC 'wait for (pins & S) = D with timeout ?
    111111 111 I CCCC DDDDDDDDD SSSSSSSSS        WAITPNE D,S  WC 'wait for (pins & S) = D with timeout ?
    ----------------------------------------------------------------------------------------------------
    * 1 clock if task uses no more than every 4th time slot (4 clocks in single-task)
    

    can these have a granularity formula ? - and mins and inc sizes for ?
    Are all multi-task compatible ?
    I see this caveat
    PASSCNT This is intended as a non-pipeline-stalling alternative to WAITCNT, for use in multi-task programs.


    I do not quite follow the * 1 clock if task uses no more than every 4th time slot (4 clocks in single-task)

    something like : This takes X cycles + V*S*Tcy more, where Tcy is the sysClk period, S is the Slice multiplier and V is the variable time
    0..RealTime. ?
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2012-12-18 18:12
    cgracey wrote: »
    I just finished documenting the hub counter instructions (at the end):

    Prop2_Docs.txt
    I've just added these to the main document but it looks like nothing much has been done with the assembler reference section in another document. Maybe Seairth has run out of steam, any volunteers?

    I find it too time consuming to update the document from the other contributions as I would have to find all the bits that have been changed. Is there any possiblity guys that you can update the live document? I know sometimes it's easier just to work offline with your favorite tools but it's even easier not to bother in the first place. Since we are putting the effort in how about that little extra needed to wrangle with Google docs, it gets easier, really, and everyone gets to benefit by having it all up-to-date in one place. Otherwise we just end up with fragmented bits and pieces.

    The instruction summary spreadsheet is here and edit permissions are open to anyone.
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-18 18:48
    Sorry Peter. THe spreadsheet is just too complicated to edit in google docs. There are too many changes and they are still coming. I don't mind if errors are posted on this thread and I will fix them. Once they settle down they can be posted that way, but atm it is way way easier to keep them in the excel and post here as a zip file. The last major change I had to import all the opcodes from Chip's later list because so many had changed. I will be posting an update shortly as soo as I resolve a few questions with Chip.
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-18 18:54
    Chip:

    How can you decode the COGINIT instruction? Am I missing something?
    000011 ZCR 0 CCCC DDDDDDDDD SSSSSSSSS     COGINIT D,S     'launch cog at D, cog PTRA = S     1..9
    
    000011 000 0 CCCC DDDDDDDDD 010110000     WRQUAD  D         'write QUADs at D                        1..8
    000011 000 0 CCCC DDDDDDDDD 010110001     RDQUAD  D         'read quad at D into QUADs               1..8
    000011 010 0 CCCC DDDDDDDDD 010110001     RDQUADC D         'read cached quad at D into QUADs     1, 1..8
    
  • Cluso99Cluso99 Posts: 18,069
    edited 2012-12-18 19:04
    Chip:
    And these... Should SUBR, CMPSUB, INCMOD and DECMOD have R=1 ?
    [TABLE="width: 1059"]
    [TR]
    [TD]111000[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]1111[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]SETINDS[/TD]
    [TD]D,S[/TD]
    [TD]Inc/Dec INDA by S and INDB by D (-256..+255) lower/higher=$000/$1FF[/TD]
    [/TR]
    [TR]
    [TD]111000[/TD]
    [TD]Z[/TD]
    [TD]C[/TD]
    [TD]R[/TD]
    [TD]I[/TD]
    [TD]CCCC[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]SUBR[/TD]
    [TD]D,[#]S[/TD]
    [TD]Subtract (reverse) D=S-D[/TD]
    [/TR]
    [/TABLE]
    
    [TABLE="width: 1059"]
    [TR]
    [TD]111001[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]I[/TD]
    [TD]0B0A[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]FIXINDx[/TD]
    [TD]D,S[/TD]
    [TD](FIXINDA D,S / FIXINDB D,S / FIXINDS D,S)[/TD]
    [/TR]
    [TR]
    [TD]111001[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0001[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]FIXINDA[/TD]
    [TD]#D,#S[/TD]
    [TD]Set INDA to #S,    set Lower/Upper limits to lower/higher of #D/#S[/TD]
    [/TR]
    [TR]
    [TD]111001[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0100[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]FIXINDB[/TD]
    [TD]#D,#S[/TD]
    [TD]Set INDB to #S,    set Lower/Upper limits to lower/higher of #D/#S[/TD]
    [/TR]
    [TR]
    [TD]111001[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0101[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]FIXINDS[/TD]
    [TD]#D,#S[/TD]
    [TD]Set INDA & INDB to #S, Lower/Upper limits to lower/higher of #D/#S[/TD]
    [/TR]
    [TR]
    [TD]111001[/TD]
    [TD]Z[/TD]
    [TD]C[/TD]
    [TD]R[/TD]
    [TD]I[/TD]
    [TD]CCCC[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]CMPSUB[/TD]
    [TD]D,[#]S[/TD]
    [TD]Subtract S from D if D=>S: If D=>S, D -= S[/TD]
    [/TR]
    [/TABLE]
    
    [TABLE="width: 1059"]
    [TR]
    [TD]111010[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]I[/TD]
    [TD]CCCC[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]CFGPINS[/TD]
    [TD]D,[#]S[/TD]
    [TD]Config Pins on "SETPORT" masked by D to S/#n (logic/pullup/etc)[/TD]
    [/TR]
    [TR]
    [TD]111010[/TD]
    [TD]Z[/TD]
    [TD]C[/TD]
    [TD]R[/TD]
    [TD]I[/TD]
    [TD]CCCC[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]INCMOD[/TD]
    [TD]D,[#]S[/TD]
    [TD]Inc D modulo [#]S:       D++; If D>S, D=0[/TD]
    [/TR]
    [/TABLE]
    
    [TABLE="width: 1059"]
    [TR]
    [TD]111011[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]0[/TD]
    [TD]I[/TD]
    [TD]CCCC[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]WAITVID[/TD]
    [TD]D,[#]S[/TD]
    [TD]Wait for video generator to take D & S pixels[/TD]
    [/TR]
    [TR]
    [TD]111011[/TD]
    [TD]Z[/TD]
    [TD]C[/TD]
    [TD]R[/TD]
    [TD]I[/TD]
    [TD]CCCC[/TD]
    [TD]DDDDDDDDD[/TD]
    [TD]SSSSSSSSS[/TD]
    [TD]DECMOD[/TD]
    [TD]D,[#]S[/TD]
    [TD]Dec D modulo [#]S:       D--; If D<0, D=S[/TD]
    [/TR]
    [/TABLE]
    
  • cgraceycgracey Posts: 14,206
    edited 2012-12-18 19:14
    Cluso99 wrote: »
    Chip:

    How can you decode the COGINIT instruction? Am I missing something?
    000011 ZCR 0 CCCC DDDDDDDDD SSSSSSSSS     COGINIT D,S     'launch cog at D, cog PTRA = S     1..9
    
    000011 000 0 CCCC DDDDDDDDD 010110000     WRQUAD  D         'write QUADs at D                        1..8
    000011 000 0 CCCC DDDDDDDDD 010110001     RDQUAD  D         'read quad at D into QUADs               1..8
    000011 010 0 CCCC DDDDDDDDD 010110001     RDQUADC D         'read cached quad at D into QUADs     1, 1..8
    

    Sorry, Cluso!

    The "I" bit should set to 1 in WRQUAD..RDQUADC.

    Here is an updated file:

    Prop2_Docs.txt
Sign In or Register to comment.