## Registers

| Register               | Description                                                                                                                                                                  |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RØ                     | 16 bit, General Purpose                                                                                                                                                      |
| R1                     | 16 bit, General Purpose                                                                                                                                                      |
| R2                     | 16 bit, General Purpose                                                                                                                                                      |
| R3                     | 16 bit, General Purpose                                                                                                                                                      |
| R4                     | 16 bit, General Purpose                                                                                                                                                      |
| R5                     | 16 bit, General Purpose                                                                                                                                                      |
| R6                     | 16 bit, General Purpose                                                                                                                                                      |
| R7                     | 16 bit, General Purpose                                                                                                                                                      |
| SP                     | 16 bit, Stack Pointer                                                                                                                                                        |
| PC                     | 16 bit, Program Pointer                                                                                                                                                      |
| SAR<br>I V S C Z AC AZ | Status Register  I: Interrupt flag  V, S, C, Z: Compare flags  AC, AZ: Arithmetic flags  (SR refers to the compare flags subset)  (AR refers to the arithmetic flags subset) |

All general purpose registers are 16 bit long. ALU operations are 16 bit. 8 bit operations are not natively supported except for extended loads and truncated stores. The Status Register flags are split into two sets, the SR set and the AR set. Instructions may update SR only or both SR and AR.

## **Condition Codes Summary**

| Encoding | Machine<br>Name | Alt<br>Names | SR Flags       | Description                                                       |
|----------|-----------------|--------------|----------------|-------------------------------------------------------------------|
| 000      | eq              | z            | Z              | Equal than. Zero                                                  |
| 001      | ne              | nz           | !Z             | Not equal. Not zero                                               |
| 010      | uge             | hs, c        | С              | Unsigned greater than or equal. Carry                             |
| 011      | ult             | lo, nc       | !C             | Unsigned less than. Not carry                                     |
| 100      | lt              | -            | S != V         | Signed less than                                                  |
| 101      | ge              | -            | S == V         | Signed greater than or equal                                      |
| 110      | ugt             | hi           | C && !Z        | Unsigned greater than                                             |
| 111      | gt              | -            | (S == V) && !Z | Signed greater than                                               |
| -        | ule             | ls           | !C II Z        | Unsigned less than or equal<br>Implemented as the opposite of ugt |
| -        | le              | -            | (S != V)    Z  | Signed less than or equal<br>Implemented as the opposite of gt    |

# Opcode Summary, by opcode number

| Pattern |   | Encoding |   |   |   |     |   |     |    |             |    |        |     |       |                                                                                                                                    |   | Description                                    |
|---------|---|----------|---|---|---|-----|---|-----|----|-------------|----|--------|-----|-------|------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------|
| T1      | 1 | 1        | 1 | o |   |     | C | ıac | aa | a aaaa aaaa |    |        |     |       |                                                                                                                                    |   | Relative Call/Jump                             |
| T2      | 1 | 1        | 0 | 1 |   | СС  |   |     |    | а           | aa | aa     | aa  | aa    |                                                                                                                                    |   | Conditional branch                             |
| Т6      | 1 | 1        | 0 | 0 |   | Rd  |   | 1   | 0  | р           |    | k      | k l | kk    | k                                                                                                                                  |   | And, Or immediate                              |
| Т9      | 1 | 1        | 0 | 0 | o | xx  |   | 0   |    |             | kk | kk     | kk  | kk    |                                                                                                                                    |   | Add/Subtract offset to SP                      |
| Т7      | 1 | 0        | 0 | р |   | Rd  |   |     | Rn |             |    | k      | k l | κk    | k                                                                                                                                  |   | Load/store with immediate offset               |
| Т8      | 0 | 1        | 0 | р |   | Rd  |   | 1   |    | kkkk kkkk   |    |        |     |       | Move, Compare, Add, Subtract immediate                                                                                             |   |                                                |
| Т9      | 0 | 1        | 0 | р |   | Rd  |   | 0   |    | kkkk kkkk   |    |        |     |       | SP relative load/store                                                                                                             |   |                                                |
| T5      | 0 | 0        | 1 |   | 0 | р   |   |     | Rn | n Rs Rd     |    |        | Rd  |       | Three register ALU operation,<br>Load/store with register offset                                                                   |   |                                                |
| T4      | 0 | 0        | 0 | 1 |   | сс  |   |     | Rn |             |    | Rs     |     |       | Rd                                                                                                                                 |   | Conditional select                             |
| Т3      | 0 | 0        | 0 | 0 |   | СС  |   | 1   | 1  | х           | х  | х      | х   |       | Rd                                                                                                                                 |   | Conditional set                                |
| T11     | 0 | 0        | 0 | 0 |   | ор  |   | 1   | 0  | 0           | р  | x x Rd |     |       | Push/Pop, Move SP Register, Add SP Register, Branch/Call Indirect, Move immediate, Load/store with absolute address, ALU operation |   |                                                |
| T12     | 0 | 0        | 0 | 0 |   | ор  |   | 0   | 1  | х           | х  | х      | х   | x x x |                                                                                                                                    | х | Zero Operand Instructions                      |
| T13     | 0 | 0        | 0 | 0 |   | ор  |   | 0   | 0  | x           |    | Rs Rd  |     |       | Two register ALU operation Two register Move, Compare, ALU operation                                                               |   |                                                |
| -       | 0 | 0        | 0 | 0 | 0 | 0 0 | ) | 0   | 0  | 0           | 0  | 0      | 0   | 0     | 0                                                                                                                                  | 0 | NOP instruction, emulated through 'mov r0, r0' |

# Opcode Summary, by instruction pattern

| Pattern |   | Encoding [ |   |   |      |    |            |      |         |    |      |     |   | Description                                                                                                                        |
|---------|---|------------|---|---|------|----|------------|------|---------|----|------|-----|---|------------------------------------------------------------------------------------------------------------------------------------|
| T1      | 1 | 1          | 1 | 0 |      | aa | aaa aaaa   |      |         |    |      |     |   | Relative Call/Jump                                                                                                                 |
| T2      | 1 | 1          | 0 | 1 | сс   |    |            | а    | aac     | a  | aa   | aa  |   | Conditional branch                                                                                                                 |
| Т3      | 0 | 0          | 0 | 0 | сс   | 1  | 1          | х    | х       | х  | х    | Ro  | d | Conditional set                                                                                                                    |
| T4      | 0 | 0          | 0 | 1 | сс   |    | Rn         |      | ı       | ₹s |      | Ro  | d | Conditional select                                                                                                                 |
| T5      | 0 | 0          | 1 |   | ор   |    | Rn         | n Rs |         |    |      | Ro  | d | Three register ALU operation,<br>Load/store with register offset                                                                   |
| T6      | 1 | 1          | 0 | 0 | Rd   | 1  | 0          | р    | kk kkkk |    |      |     |   | And, Or immediate                                                                                                                  |
| Т7      | 1 | 0          | 0 | р | Rd   |    | Rn kk kkkk |      |         |    |      | kkk |   | Load/store with immediate offset                                                                                                   |
| Т8      | 0 | 1          | 0 | р | Rd   | 1  |            |      | kkŀ     | κk | kk   | kk  |   | Move, Compare, Add, Subtract immediate                                                                                             |
| Т9      | 0 | 1          | 0 | р | Rd   | 0  |            |      | kkŀ     | κk | kk   | kk  |   | SP relative load/store                                                                                                             |
| T10     | 1 | 1          | 0 | 0 | o xx | 0  |            |      | kkŀ     | ĸk | kk   | kk  |   | Add/Subtract offset to SP                                                                                                          |
| T11     | 0 | 0          | 0 | 0 | ор   | 1  | 0          | o    | р       | x  | x Rd |     | d | Push/Pop, Move SP Register, Add SP Register, Branch/Call Indirect, Move immediate, Load/store with absolute address, ALU operation |
| T12     | 0 | 0          | 0 | 0 | ор   | 0  | 1          | х    | x       | х  | х    | x x | x | Zero Operand Instructions                                                                                                          |
| T13     | 0 | 0          | 0 | 0 | ор   | 0  | 0          | x    | ı       | Rs |      | Rd  |   | Two register ALU operation<br>Two register Move, Compare, ALU operation                                                            |

# **Instructions Summary**

|            | Encoding    | Machine<br>Name | Assembly Instruction | Description                                                                                      |
|------------|-------------|-----------------|----------------------|--------------------------------------------------------------------------------------------------|
| Relativ    | e Call/Jun  | пр              |                      |                                                                                                  |
| T1         | 0           | jmprel          | jmp Label            | PC relative unconditional branch to Label                                                        |
| T1         | 1           | callrel         | call Label           | PC relative subroutine call to Label                                                             |
| Conditi    | onal branc  | ch              |                      |                                                                                                  |
| T2         | %cc         | b%cc            | b%cc Label           | Branch PC relative to Label if %cc matches SR flags, otherwise proceed with the next instruction |
| Conditi    | onal set    |                 |                      |                                                                                                  |
| ТЗ         | %сс         | set%cc          | set%cc Rd            | Conditional set. Move 1 to Rd if %cc matches SR flags, otherwise move 0 to Rd                    |
| Conditi    | onal selec  | :t              |                      |                                                                                                  |
| T4         | %cc         | sel%cc          | sel%cc Rn, Rs, Rd    | Conditional select. Copy Rn to Rd if %cc matches SR flags, otherwise copy Rs to Rd               |
| Three r    | egister AL  | .U operation    |                      |                                                                                                  |
|            | 0000        | addrrr          | add Rn, Rs, Rd       | Rd = Rn+Rs, update SR, AR                                                                        |
|            | 0001        | adcrrr          | addc Rn, Rs, Rd      | Rd = Rn+(Rs+AC), update $SR$ , $AR$                                                              |
|            | 0010        | subrrr          | sub Rn, Rs, Rd       | Rd = Rn-Rs, update SR, AR                                                                        |
| <b>T</b> E | 0011        | subcrrr         | subc Rn, Rs, Rd      | Rd = Rn-(Rs+!AC), update SR, AR                                                                  |
| T5         | 0100        | orrrr           | or Rn, Rs, Rd        | Rd = Rn   Rs, update SR                                                                          |
|            | 0101        | andrrr          | and Rn, Rs, Rd       | Rd = Rn & Rs, update SR                                                                          |
|            | 0110        | xorrrr          | xor Rn, Rs, Rd       | Rd = Rn ^ Rs, update SR                                                                          |
|            | 0111        | -               | -                    | Reserved                                                                                         |
| Load/st    | ore with r  | egister offs    | set                  |                                                                                                  |
|            | 100x        | mov16nr         | ld.w [Rn, Rs], Rd    | Load contents of word aligned memory address Rn+Rs into Rd                                       |
|            | 1010        | mov8znr         | ld.zb [Rn, Rs], Rd   | Load zero-extended contents of byte memory address Rn+Rs into Rd                                 |
| T5         | 1011        | mov8snr         | ld.sb [Rn, Rs], Rd   | Load sign-extended contents of byte memory address Rn+Rs into Rd                                 |
|            | 110x        | mov16rn         | st.w Rd, [Rn, Rs]    | Store Rd in word aligned memory address Rn+Rs                                                    |
|            | 111x        | mov8rn          | st.b Rd, [Rn, Rs]    | Store byte truncated Rd in byte memory address Rn+Rs                                             |
| And, Or    | · Immediate | 2               |                      |                                                                                                  |
|            | 00          | andkr           | and Rd, K, Rd        | Logical AND zero-extended K with Rd and store result in Rd, update SR                            |
| Т6         | 01          | orkr            | or Rd, K, Rd         | Logical OR zero-extended K with Rd and store result in Rd, update SR                             |
|            | -           | -               | -                    | Reserved                                                                                         |
|            | -           | -               | -                    | Reserved                                                                                         |
| Load/st    | ore with i  | mmediate off    | set                  |                                                                                                  |
|            | 00          | mov16mr         | ld.w [Rn, K], Rd     | Load contents of word aligned memory address Rn+zext(K) into Rd.                                 |
| T7         | 01          | movs8mr         | ld.sb [Rn, K], Rd    | Load sign-extended contents of byte memory address Rn+zext(K) into Rd                            |
|            | 10          | mov16rm         | st.w Rd, [Rn, K]     | Store Rd in word aligned memory address Rn+zext(K)                                               |
|            | 11          | mov8rm          | st.b Rd, [Rn, K]     | Store byte truncated Rd in byte memory address Rn+zext(K)                                        |

|         | Encoding    | Machine<br>Name | Assembly Instruction    | Description                                                     |
|---------|-------------|-----------------|-------------------------|-----------------------------------------------------------------|
| Move, C | Compare, Ad | ld, Subtract    | immediate               |                                                                 |
|         | 00          | movkr           | mov K, Rd               | Copy sign-extended K into Rd                                    |
|         | 01          | cmpkr           | cmp Rd, K               | Compare Rd with sign-extended K and update SR flags             |
| Т8      | 10          | addkr           | add Rd, K, Rd           | Add zero-extended K to Rd and store result in Rd, update SR, AR |
|         | 11          | subkr           | sub Rd, K, Rd           | Subtract zero-extended K from Rd and store in Rd, update SR, AR |
| SP rela | tive load/  | 'store          |                         |                                                                 |
|         | 00          | mov16qr         | ld.w [SP, K], Rd        | Load the contents of stack memory address SP+zext(K) into Rd    |
| Т9      | 01          | movs8qr         | ld.sb [SP, K], Rd       | Load the contents of byte memory address SP+zext(K) into Rd     |
|         | 10          | mov16rq         | st.w Rd, [SP, K]        | Store Rd in stack memory address SP+zext(K)                     |
|         | 11          | mov8rq          | st.b Rd, [SP, K]        | Store the lower byte of Rd in byte memory address SP+zext(K)    |
| Add/Sub | tract offs  | set to SP       |                         |                                                                 |
| T10     | 0           | addks           | add SP, K, SP           | Add zero-extended K to SP, update SR, AR                        |
|         | 1           | subks           | sub SP, K, SP           | Subtract zero-extended K from SP, update SR, AR                 |
| Push/Po | p, move SP  | Register, a     | ıdd SP Register, Branch | n/Call indirect                                                 |
|         | 000 00      | push            | push Rd                 | Decrement SP and store Rd onto the stack                        |
|         | 001 00      | рор             | pop Rd                  | Load Rd from the stack and increment SP                         |
|         | 010 00      | movsr           | mov SP, Rd              | Copy SP into Rd                                                 |
| T11     | 011 00      | movrs           | mov Rd, SP              | Copy Rd into SP                                                 |
|         | 100 00      | addrs           | add SP, Rd, SP          | SP = SP+Rd, update SR, AR                                       |
|         | 101 00      | subrs           | sub SP, Rd, SP          | SP = SP-Rd, update SR, AR                                       |
|         | 110 00      | addsr           | add SP, Rd, Rd          | Rd = SP+Rd, update SR, AR                                       |
|         | 111 00      | subsr           | sub SP, Rd, Rd          | Rd = SP-Rd, update SR, AR                                       |
| Branch/ | 'Call indir | ect             |                         |                                                                 |
|         | 000 01      | jmpreg          | jmp Rd                  | Jump to Rd                                                      |
|         | 001 01      | callreg         | call Rd                 | Subroutine call to Rd                                           |
|         | 010 01      | -               | -                       |                                                                 |
| T11     | 011 01      | -               | -                       |                                                                 |
|         | 100 01      | -               | -                       |                                                                 |
|         | 101 01      | -               | -                       |                                                                 |
|         | 110 01      | -               | -                       |                                                                 |
|         | 111 01      | movSr           | mov SR, Rd              | Copy SAR to Rd                                                  |
| One Reg | jister ALU  | -               |                         |                                                                 |
|         | 000 10      | lsr             | lsr Rd                  | 1 bit shift right of Rd                                         |
|         | 001 10      | lsl             | lsl Rd                  | 1 bit shift left of Rd                                          |
|         | 010 10      | asr             | asr Rd                  | 1 bit signed shift right of Rd                                  |
| T11     | 011 10      | -               | -                       | -                                                               |
|         | 100 10      | -               | -                       | -                                                               |
|         | 101 10      | neg             | neg Rd                  | Negate Rd, update SR                                            |
|         | 110 10      | not             | not Rd                  | Complement Rd, update SR                                        |
|         | 111 10      | -               | -                       | -                                                               |

|         | Encoding   | Machine<br>Name | Assembly Instruction | Description                                              |
|---------|------------|-----------------|----------------------|----------------------------------------------------------|
| Move Im | mediate, L | .oad/store wi   | th absolute address  |                                                          |
|         | 000 11     | movKr           | mo∨.w K, Rd          | Copy K into Rd (K is in the next instruction word)       |
|         | -          | K               | mov.w k, ka          | copy is the ora (it is the next instruction nora)        |
|         | 001 11     | mov16ar         | ld.w [A], Rd         | Load contents of word aligned memory address A into      |
|         | -          | Α               | 24.11 [7.5], 114     | Rd (A is in the next instruction word)                   |
|         | 010 11     | mov8zar         | ld.zb [A], Rd        | Load zero-extended contents of byte memory address A     |
|         | -          | Α               | LU.ZD [A], Nu        | into Rd (A is in the next instruction word)              |
| T11     | 011 11     | mov8sar         | ld.sb [A], Rd        | Load sign-extended contents of byte memory address A     |
| 111     | -          | Α               | LU.SD [A], NU        | into Rd (A is in the next instruction word)              |
|         | 100 11     | mov16ra         | st.w Rd, [A]         | Store Rd in word aligned memory address A (A is in       |
|         | _          | Α               | St.W Nu, [A]         | the next instruction word)                               |
|         | 101 11     | mov8ra          | st.b Rd, [A]         | Store lower byte of Rd in byte memory address A (A is    |
|         | -          | Α               | SC.D Ku, [A]         | in the next instruction word)                            |
|         | 110 11     | -               | -                    | -                                                        |
|         | 111 11     | -               | -                    | -                                                        |
| Zero Op | erand Inst | ructions        |                      |                                                          |
|         | 000        | ret             | ret                  | Return from subroutine                                   |
|         | 001        | reti            | reti                 | Return from interrupt                                    |
|         | 010        | dint            | dint                 | Disable interrups                                        |
| T12     | 011        | eint            | eint                 | Enable interrupts                                        |
| 112     | 100        |                 |                      |                                                          |
|         | 101        |                 |                      |                                                          |
|         | 110        |                 |                      |                                                          |
|         | 111        |                 |                      |                                                          |
| Two reg | ister Move | e, Compare, A   | LU operation         |                                                          |
|         | 000        | movrr           | mov Rs, Rd           | Copy Rs to Rd                                            |
|         | 001        | cmprr           | cmp Rs, Rd           | Compare Rd with Rs and update SR flags                   |
|         | 010        | zext            | zext Rs, Rd          | Move zero-extended Rs low byte to Rd                     |
|         | 011        | sext            | sext Rs, Rd          | Move sign-extended Rs low byte to Rd                     |
| T13     | 100        | swapb           | swapb Rs, Rd         | Move the swapped bytes of Rs to Rd                       |
|         | 101        | sextw           | sextw Rs, Rd         | Sets Rd to all ones if Rs is negative, or zero otherwise |
|         | 110        | -               | -                    | -                                                        |
|         | 111        | mov16pr         | ld {Rs}, Rd          | Load Program Memory                                      |