# **PSM Syntax**

Each line of your PSM file should adhere to the following basic syntax. Don't worry too much about getting everything perfect or tidy because the assembler will look after things like additional spaces and is very tolerant of upper or lower case characters except where it really matters. If you get something wrong the assembler will show you what it doesn't like and provide advice to help you correct it.



PLEASE SEE – 'all\_kcpsm6\_syntax.psm' which provides a PSM file (albeit not a real program) that further describes all directives and has examples of all the supported syntax. Since it is a valid PSM file you can assemble it to see the FMT and LOG files as well.



## **Registers and the NAMEREG Directive**

KCPSM6 can generally access 16 general purpose registers assigned the default names 's0' through to 'sF'. There are absolutely no restrictions on which register or combination of registers can be specified as 'sX' or 'sY' operands in any of the instructions that work with registers. This provides you with complete freedom to allocate registers as you wish. If you are careful with your allocation of registers to different tasks it will often avoid the requirement to 'shuffle' data around too much which is often the case when a processor has an accumulator based processor architecture.

The KCPSM6 assembler is able to identify the default name of a resister regardless of the mixture of upper and lower case characters that you use to describe it but it will always convert it to the lower case 's' followed by an upper case hexadecimal digit when writing the FMT and LOG files. For example 'S4' will be interpreted as the default register name 's4'. Likewise, 'sd', 'Sd' and 'SD' will all be interpreted as default register name 'sD'. In other words, the assembler allows you to concentrate on writing your code without having to be so precise about syntax and format.

#### **NAMEREG** Directive

The NAMEREG directive is an *optional* facility that can help you keep track of what data you expect a particular register to contain. Prior to the NAMEREG directive the resister will have the default name such as 'sB'. Once renamed only the new name will identify the register and that name is case sensitive exactly as you defined it. Changing the name has no effect on the contents of the register or how it can be used.

| ADD sB, 42               | } | Default register name applies before the NAMEREG directive.                 | S |
|--------------------------|---|-----------------------------------------------------------------------------|---|
| ;<br>NAMEREG sB, Status  | 7 | The new name can only contain 'a' to 'z', 'A' to 'Z' and '_' underscore (no | S |
| ;<br>;                   | _ | for anything else like a line label of a hexadecimal value.                 | S |
| INPUT Status, flags_port | 7 | Following the NAMEREG directive only the new is valid and this name is      | S |
| ;                        | _ | case sensitive. In this case 'sB' will no longer be recognised.             | S |
| NAMEREG Status, speed    |   | The NAMEREG directive can be used to change the name again and then         | S |
| SUB speed, 01            |   | thinking this is either useful or something to be avoided! ©                | s |
| ;<br>NAMEREG speed, sB   | ٦ | The encouriests default register nerve can be restand and                   | s |
| ;<br>LOAD sB, 19         | } | following this all the normal case insensitivity rules also apply.          |   |

### 16 Registers All general purpose All 8-bits

| sE   |  |  |  |  |
|------|--|--|--|--|
| sD [ |  |  |  |  |
| sC   |  |  |  |  |
| sB [ |  |  |  |  |
| sA [ |  |  |  |  |
| s9 [ |  |  |  |  |
| s8 [ |  |  |  |  |
| s7 [ |  |  |  |  |
| s6 [ |  |  |  |  |
| s5 [ |  |  |  |  |
| s4 [ |  |  |  |  |
| s3 [ |  |  |  |  |
| s2 [ |  |  |  |  |
| s1 [ |  |  |  |  |
| s0 [ |  |  |  |  |



## **KCPSM6** Instruction Set

| Page | e Opcode   | Instruction      |
|------|------------|------------------|
| R    | egister lo | ading            |
| 55   | 00xy0      | LOAD sX, sY      |
| 55   | 01xkk      | LOAD sX, kk      |
| 71   | 16xy0      | STAR sX, sY      |
| L    | ogical     |                  |
| 56   | 02xy0      | AND sX, sY       |
| 56   | 03xkk      | AND sX, kk       |
| 57   | 04xy0      | OR sX, sY        |
| 57   | 05xkk      | OR sX, kk        |
| 58   | 06xy0      | XOR sX, sY       |
| 58   | 07xkk      | XOR sX, kk       |
| A    | rithmetic  |                  |
| 59   | 10xy0      | ADD sX, sY       |
| 59   | 11xkk      | ADD sX, kk       |
| 60   | 12xy0      | ADDCY sX, sY     |
| 60   | 13xkk      | ADDCY sX, kk     |
| 61   | 18xy0      | SUB sX, sY       |
| 61   | 19xkk      | SUB sX, kk       |
| 62   | 1Axy0      | SUBCY sX, sY     |
| 62   | 1Bxkk      | SUBCY sX, kk     |
| Т    | est and C  | ompare           |
| 63   | 0Cxy0      | TEST sX, sY      |
| 63   | 0Dxkk      | TEST sX, kk      |
| 64   | 0Exy0      | TESTCY sX, sY    |
| 64   | 0Fxkk      | TESTCY sX, kk    |
| 65   | 1Cxy0      | COMPARE sX, sY   |
| 65   | 1Dxkk      | COMPARE sX, kk   |
| 66   | 1Exy0      | COMPARECY sX, sY |
| 66   | 1Fxkk      | COMPARECY sX, kk |

| Page                    | Opcode           | Instruction |  |  |  |  |
|-------------------------|------------------|-------------|--|--|--|--|
| Sł                      | Shift and Rotate |             |  |  |  |  |
| 67                      | 14x06            | SLO sX      |  |  |  |  |
| 67                      | 14x07            | SL1 sX      |  |  |  |  |
| 67                      | 14x04            | SLX sX      |  |  |  |  |
| 67                      | 14x00            | SLA sX      |  |  |  |  |
| 67                      | 14x02            | RL sX       |  |  |  |  |
| 68                      | 14x0E            | SR0 sX      |  |  |  |  |
| 68                      | $14 \times 0F$   | SR1 sX      |  |  |  |  |
| 68                      | 14x0A            | SRX sX      |  |  |  |  |
| 68                      | 14x08            | SRA sX      |  |  |  |  |
| 68                      | 14x0C            | RR sX       |  |  |  |  |
| Register Bank Selection |                  |             |  |  |  |  |
| 70                      | 37000            | REGBANK A   |  |  |  |  |
| 70                      | 37001            | REGBANK B   |  |  |  |  |
| Input and Output        |                  |             |  |  |  |  |

| 73 | 08xy0 | INPUT sX, (sY) |
|----|-------|----------------|
| 73 | 09xpp | INPUT sX, pp   |
| 74 | 2Cxy0 | OUTPUT sX,(sY) |
| 74 | 2Dxpp | OUTPUT sX, pp  |
| 78 | 2Bkkp | OUTPUTK kk, p  |
|    |       |                |

## **Scratch Pad Memory**

### (64, 128 or 256 bytes)

| 81 | 2Exy0 | STORE | sX, | (sY) |
|----|-------|-------|-----|------|
| 81 | 2Fxss | STORE | sX, | SS   |
| 82 | 0Axy0 | FETCH | sX, | (sY) |
| 82 | 0Bxss | FETCH | sX, | SS   |
| 82 | 0Bxss | FETCH | sX, | SS   |

aaa : 12-bit address 000 to FFF kk : 8-bit constant 00 to FF pp : 8-bit port ID 00 to FF p: 4-bit port ID 0 to F ss : 8-bit scratch pad location 00 to FF x : Register within bank s0 to sF y : Register within bank s0 to sF

Page Opcode Instruction

## Interrupt Handling

| 83 | 28000 | DISABLE INTERRUPT |
|----|-------|-------------------|
| 83 | 28001 | ENABLE INTERRUPT  |
| 84 | 29000 | RETURNI DISABLE   |
| 84 | 29001 | RETURNI ENABLE    |

#### Jump

| 37 | 22aaa | JUMP aaa       |
|----|-------|----------------|
| 88 | 32aaa | JUMP Z, aaa    |
| 88 | 36aaa | JUMP NZ, aaa   |
| 88 | 3Aaaa | JUMP C, aaa    |
| 88 | 3Eaaa | JUMP NC, aaa   |
| 39 | 26xy0 | JUMP@ (sX, sY) |

#### **Subroutines**

| 92 | 20aaa | CALL aaa           |
|----|-------|--------------------|
| 93 | 30aaa | CALL Z, aaa        |
| 93 | 34aaa | CALL NZ, aaa       |
| 93 | 38aaa | CALL C, aaa        |
| 93 | 3Caaa | CALL NC, aaa       |
| 94 | 24xy0 | CALL@ (sX, sY)     |
| 96 | 25000 | RETURN             |
| 97 | 31000 | RETURN Z           |
| 97 | 35000 | RETURN NZ          |
| 97 | 39000 | RETURN C           |
| 97 | 3D000 | RETURN NC          |
| 98 | 21xkk | LOAD&RETURN sX, kk |

#### **Version Control**

100 14x80 HWBUILD sX

