## YASAC Cheat Sheet, March 2023

## YASAC System on Chip



#### YASAC Data Unit



## YASAC Instructions

| Op. code | Instruction | RTL                                                                    | SVNZC |  |
|----------|-------------|------------------------------------------------------------------------|-------|--|
| 00001    | LDI Ra,k    | Ra ← k                                                                 |       |  |
| 00010    | MOV Ra,Rb   | Ra ← Rb                                                                |       |  |
| 00011    | ADD Ra,Rb   | Ra ← Ra+Rb                                                             | ****  |  |
| 00100    | SUB Ra,Rb   | Ra ← Ra-Rb                                                             | ****  |  |
| 00101    | STOP        | -                                                                      |       |  |
| 00110    | LD Ra,Rb    | Ra ← datamem(Rb)                                                       |       |  |
| 00111    | ST Rb,Ra    | datamem(Rb) ← Ra                                                       |       |  |
| 01000    | LDS Ra,k    | Ra ← datamem(k)                                                        |       |  |
| 01001    | STS k,Ra    | datamem(k) ← Ra                                                        |       |  |
| 01010    | JMP k       | PC ← k                                                                 |       |  |
| 01011    | BRBS s,k    | status[s]: PC ← k                                                      |       |  |
| 01100    | BRBC s,k    | ~status[s]: PC ← k                                                     |       |  |
| 01101    | AND Ra,Rb   | Ra ← Ra & Rb                                                           | ****  |  |
| 01110    | OR Ra,Rb    | Ra ← Ra   Rb                                                           | ****  |  |
| 01111    | EOR Ra,Rb   | Ra ← Ra ^ Rb                                                           | ****  |  |
| 10000    | ROR Ra      | Ra ← SHR(Ra,C)                                                         | ****  |  |
| 10001    | ROL Ra      | Ra ← SHL(Ra,C)                                                         | ****  |  |
| 10010    | BCLR s      | sreg[s] ← 0                                                            | ****  |  |
| 10011    | BSET s      | sreg[s] ← 1                                                            | ****  |  |
| 10100    | PUSH Ra     | datamem[sp] ← Ra; sp ← sp - 1                                          |       |  |
| 10101    | POP Ra      | Ra ← datamem[sp+1]; sp ← sp + 1                                        |       |  |
| 10110    | CALL k      | datamem[sp] $\leftarrow$ pc; pc $\leftarrow$ k; sp $\leftarrow$ sp - 1 |       |  |
| 10111    | RET         | $pc \leftarrow datamem[sp+1]; sp \leftarrow sp + 1$                    |       |  |

#### Instruction formats

|   | \$     | 3  |   | 3  |
|---|--------|----|---|----|
| A | opcode | Ra |   | Rb |
| B | opcode | Ra | k |    |
| C | opcode | S  | k |    |

# **ALU** operations



|                                 |      |                      | sreg     |
|---------------------------------|------|----------------------|----------|
| m/2 90                          | 90   | ~                    | ZNNFC    |
| ALU_AND ALU_TRA ALU_SUB ALU_TRB | 0000 | a+b<br>a<br>a-b<br>b | ******   |
| ALU_NEG                         | 0100 | -a                   | ** * *   |
| ALU- AND                        | 0101 | AND(a,b)             | ** ** -  |
| ALU-OR                          | 0110 | 0R(a,b)              | ****     |
| ALU- EOR                        | 0111 | EOR(a,b)             | ****-    |
| 4LU_ROR                         | 1000 | SHR (a,cin)          | ** * * * |
| ALU_ ROL                        | 1061 | 2HL (a, %)           | ** ***   |

## Branch pseudo-instructions

| Instruction | Pseudo-instructions | Description                                                                                   |
|-------------|---------------------|-----------------------------------------------------------------------------------------------|
| BRBS 0,k    | BRCS k<br>BRLO k    | Branch if carry (Carry Set) Branch if A <b (lower)<="" a-b="" after="" td="" unsigned=""></b> |
| BRBS 1,k    | BRZS k<br>BREQ k    | Branch if the result is zero (Zero Set)<br>Branch if A=B after A-B (EQual)                    |
| BRBS 2,k    | BRMI k              | Branch if the sign is Minus                                                                   |
| BRBS 3,k    | BRVS k              | Branch if overflow (oVerflow Set)                                                             |
| BRBS 4,k    | BRLT k              | Branch A <b (less="" a-b="" after="" signed="" td="" than)<=""></b>                           |
| BRBC 0,k    | BRCC k<br>BRSH k    | Branch if no carry (Carry Cleared)<br>Branch if A≥B after uns. A-B (Same or Higher)           |
| BRBC 1,k    | BRZC k<br>BRNE k    | Branch if the result is not zero (Zero Cleared)<br>Branch if A≠B after A-B (Not Equal)        |
| BRBC 2,k    | BRPL k              | Branch if the sign is PLus                                                                    |
| BRBC 3,k    | BRVC k              | Branch if not overflow (oVerflow Cleared)                                                     |
| BRBC 4,k    | BRGE k              | Branch A≥B after signed A-B (Greater or Equal)                                                |

## Status pseudo-instructions

| Instruction | Pseudo-<br>instructions | Description        |
|-------------|-------------------------|--------------------|
| BCLR 0      | CLC                     | CLear Carry bit    |
| BCLR 1      | CLZ                     | CLear Zero bit     |
| BCLR 2      | CLN                     | CLear Negative bit |
| BCLR 3      | CLV                     | CLear oVerflow bit |
| BCLR 4      | CLS                     | CLear Sign bit     |
| BSET 0      | SEC                     | SEt Carry bit      |
| BSET 1      | SEZ                     | SEt Zero bit       |
| BSET 2      | SEN                     | SEt Negative bit   |
| BSET 3      | SEV                     | SEt oVerflow bit   |
| BSET 4      | SES                     | SEt Sign bit       |