

## Computer Program Execution

---

### A. Introduction

#### Objectives

At the end of this lab you should be able to:

- ◆ Use the CPU simulator to create basic CPU instructions
  - ◆ Use the simulator to execute basic CPU instructions
  - ◆ Use CPU instructions to move data to registers, compare values in registers, push data to the stack, pop data from the stack, jump to address locations and add values held in registers.
  - ◆ Explain the function of the special CPU registers PC (Program Counter) and SR (Status Register) and status flags OV, N and Z.
  - ◆ Produce code for simple conditional statements and loops.
  - ◆ Use direct addressing mode of accessing data in memory
  - ◆ Use indirect addressing mode of accessing data in memory
  - ◆ Write a subroutine and call it
  - ◆ Pass parameters to a subroutine
- 

### B. Processor (CPU) Simulators

The computer architecture tutorials are supported by simulators, which are created to help underpin theoretical concepts normally covered during the lectures. The simulators provide visual and animated representation of mechanisms involved and enable the students to observe the hidden inner workings of systems, which would be difficult or impossible to do otherwise. The added advantage of using simulators is that they allow the students to experiment and explore different technological aspects of systems without having to install and configure the real systems.

---

### C. Basic Theory

The programming model of computer architecture defines those low-level architectural components, which include the following

- ◆ CPU instruction set
- ◆ CPU registers
- ◆ Different ways of addressing instructions and data in instructions, i.e. addressing modes such as direct and indirect addressing.

It also defines interactions between the above components. It is this low-level programming model which makes programmed computations possible.

---

## D. Simulator Details

This section includes basic information on the simulator enabling the students to use the simulator. The tutor(s) will be available to help in case of difficulty in using the simulator. The main window is composed of several views that represent different functional parts of the simulated Central Processing Unit. These are shown in Figure 1 below and are composed of

- ◆ CPU Instructions memory
- ◆ Special CPU registers
- ◆ CPU (general purpose) registers
- ◆ Program stack
- ◆ Program creation and program running features



**Image 1 – CPU Simulator window**

**Figure 1. CPU-OS Simulator Window**

The parts of the simulator relevant to this lab are described below. Please read this information carefully and try to identify the different parts on the real CPU Simulator window BEFORE attempting the following exercises. Use this information in conjunction with the exercises that follow.

## 1. CPU instruction memory view

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |             |      |
|----------------------------------|------|-------------|------|
| PAdd                             | LAdd | Instruction | Base |
|                                  |      |             |      |

**Figure 2. Instruction memory view**

This view contains the program instructions. The instructions are displayed as sequences of low-level instruction mnemonics (in assembler-level format) and not as binary code. This is done for clarity and makes code more readable by humans.

Each instruction is associated with two addresses: the physical address (**PAdd**) and the logical address (**LAdd**). This view also displays the base address (**Base**) against each instruction. The sequence of instructions belonging to the same program will have the same base address.

## 2. Special CPU registers view



**Figure 3. Special CPU**

**registers view**

the memory address  
currently being  
accessed.

This view shows the set of CPU registers, which have pre-defined specialist functions:

**PC: Program Counter** contains the address of the next instruction to be executed.

**IR: Instruction Register** contains the instruction currently being executed.

**SR: Status Register** contains information pertaining to the result of the last executed instruction.

**SP: Stack Pointer** register points to the value maintained at the top of the program stack (see below).

**BR: Base Register** contains current base address.

**MAR : Memory Address Register** contains

**Status bits: OV: Overflow; Z: Zero; N: Negative**

### 3. CPU registers view

| GENERAL PURPOSE CPU REGISTERS |         |   |         |
|-------------------------------|---------|---|---------|
| Reg                           | Val (D) | C | Val (D) |
| R00                           | 0       |   |         |
| R01                           | 0       |   |         |
| R02                           | 0       |   |         |
| R03                           | 0       |   |         |
| R04                           | 0       |   |         |
| R05                           | 0       |   |         |
| R06                           | 0       |   |         |
| R07                           | 0       |   |         |
| R08                           | 0       |   |         |
| R09                           | 0       |   |         |
| R10                           | 0       |   |         |
| R11                           | 0       |   |         |
| R12                           | 0       |   |         |
| R13                           | 0       |   |         |
| R14                           | 0       |   |         |
| R15                           | 0       |   |         |
| R16                           | 0       |   |         |
| R17                           | 0       |   |         |
| R18                           | 0       |   |         |
| R19                           | 0       |   |         |
| R20                           | 0       |   |         |
| R21                           | 0       |   |         |
| R22                           | 0       |   |         |
| R23                           | 0       |   |         |
| R24                           | 0       |   |         |
| R25                           | 0       |   |         |

Registers | Program Stack | Watch |

Reg Value  CHANGE RESET ALL

Figure 4. CPU Registers view

The register set view shows the contents of all the general-purpose registers, which are used to maintain temporary values as the program's instructions are executed. **Registers are very fast memories that hold temporary values while the CPU executes instructions.**

This architecture supports from 8 to 64 registers. These registers are often used to hold values of a program's variables as defined in high-level languages.

Not all architectures have this many registers. Some have more (e.g. 128 register) and some others have less (e.g. 8 registers). In all cases, these registers serve similar purposes.

This view displays each register's name (**Reg**), its current value (**Val**) and some additional values, which are reserved for program debugging. It can also be used to reset the individual register values manually which is often useful for advanced debugging. To

manually change a register's content, first select the register then enter the new value in the text box, **Reg Value**, and click on the **CHANGE** button in the **Registers** tab.

## 4. Program stack view

**Figure 5. Program stack view**

The program stack is another area which maintains temporary values as the instructions are executed. The stack is a LIFO (last-in-first-out) data structure. It is also used for efficient interrupt handling and sub-routine calls. **Each program has its own individual stack.**

The CPU instructions PSH (push) and POP are used to store values on top of stack and pop values from top of stack respectively.

## 5. Program list view

| PROGRAM LIST |      |       |      |
|--------------|------|-------|------|
| Name         | Base | Start | Type |
|              |      |       |      |

## Figure 6. Program List View

Use the **REMOVE PROGRAM** button to remove the selected program from the list; use the **REMOVE ALL PROGRAMS** button to remove all the programs from the list. Note that when a program is removed, its instructions are also removed from the **Instruction Memory View**.

## 6. Program creation



**Figure 7. Create program tab**

To create a new program enter its name in the **Program Name** box and its base address in the **Base Address** box then click on the **ADD** button. The new program's name will appear in the Program List view

(see Figure 6).



**Figure 8. Add program instructions tab**

Use **ADD NEW...** button to add a new instruction; use **EDIT...** button to edit the selected instruction; use **MOVE DOWN/ MOVE UP** buttons to move the selected instruction down or up; use **INSERT ABOVE.../INSERT BELOW...** buttons to insert a new

instruction above or below the selected instruction respectively.

## 7. Program data memory view



**Figure 9. Program data memory view**

The CPU instructions that access that part of the memory containing data can write or read the data in addressed locations. This data can be seen in the memory pages window shown in Figure 9 above.

You can display this window by clicking the **SHOW PROGRAM DATA MEMORY...** button in the main CPU window. The **Ladd** (logical address) column shows the starting address of each line in the display. Each line of the display represents 8 bytes of data. Columns **B0** through to **B7** represent bytes 0 to 7 on each line. The **Data** column shows the displayable characters corresponding to the 8 bytes. Those bytes that correspond to non-displayable characters are shown as dots. The data bytes are displayed in hex format only. For example, in Figure 9, there are non-zero data bytes in address locations 19 and 37. These data bytes correspond to displayable characters capital A and B.

To manually change the values of any bytes, first select the line(s) containing the bytes. Then use the information in the **Initialize Data** frame to modify the values of the bytes in the selected line(s) as **Integer**, **Boolean** or **String** formats. You need to click the **UPDATE** button to make the change.

---

## E. Lab Exercises - Investigate and Explore

The lab exercises are a series of activities, which are carried out by the students under basic guidelines. **So, how is this tutorial conducted?** The students are expected to follow the instructions given in order to identify and locate the required information, to act upon it and make notes of their observations. In order to be able to do these activities you should consult the information in **Section D** above and also frequently refer to the **Appendix** for information on various CPU instructions you will be asked to create and use.

Remember, you need to carefully read and understand the instructions before you attempt each activity.

**Enter the instructions you create in order to answer the questions in the blank boxes. Refer to Appendix at the end of this document to find the details on the desired instructions. You are expected to execute the instructions you created on the simulator in order to verify your answers.**

### **START HERE: Creating a program and adding instructions to it**

Now, let us start. First you need to place some instructions in the **Instruction Memory View** (see Figure 2), representing the RAM in the real machine, before executing any instructions. To do this, follow the steps below:

In the **Program** tab (see Figure 7), first enter a **Program Name**, and then enter a **Base Address** (this can be any number, but for this exercise use 100). Click on the **ADD** button. A new program name will be entered in the **Program List** view (see Figure 6). By the way, you can use the **SAVE...** button to save instructions in a file. You can also use the **LOAD...** button to load instructions from a file.

You are now ready to enter instructions into the CPU Simulator. You do this by clicking on the **ADD NEW...** button in the **Instructions** tab (see Figure 8). This will display the **Instructions: CPU0** window. You use this window to select and enter the CPU instructions. Further information on this can be found on this module's site. **Appendix** lists the instructions you will need in this exercise.

Now, have a go at the following activities (enter your answers in the text boxes provided).

**A word of caution:** Regularly save your code in a file in case the simulator crashes in which case you can restart the simulator and re-load your file.

## Part A: (Refer to the appendix for help with CPU instructions)

- Create an instruction, which moves number 5 to register R00.

| GENERAL PURPOSE CPU REGISTERS |         |   |         |
|-------------------------------|---------|---|---------|
| Reg                           | Val (D) | C | Val (D) |
| R00                           | 5       |   |         |
| R01                           | 0       |   |         |
| R02                           | 0       |   |         |
| R03                           | 0       |   |         |
| R04                           | 0       |   |         |

- Execute the above instruction (**You do this by double-clicking on the instruction**). Observe the result in the **CPU Registers** view (Figure 4).

- Create an instruction, which moves number 7 to register R01.

| GENERAL PURPOSE CPU REGISTERS |         |   |         |
|-------------------------------|---------|---|---------|
| Reg                           | Val (D) | C | Val (D) |
| R00                           | 5       |   |         |
| R01                           | 7       |   |         |
| R02                           | 0       |   |         |
| R03                           | 0       |   |         |

- Execute it (**You do this by double-clicking on the instruction**)
- Observe the contents of R00 and R01 in the **CPU Registers** view (Figure 4).
- Create an instruction, which adds the contents of R00 and R01.

| GENERAL PURPOSE CPU REGISTERS |         |   |         |
|-------------------------------|---------|---|---------|
| Reg                           | Val (D) | C | Val (D) |
| R00                           | 5       |   |         |
| R01                           | 12      |   |         |
| R02                           | 0       |   |         |
| R03                           | 0       |   |         |

- Execute it.
- Note down which register the result is put in.

|     |
|-----|
| R01 |
|-----|

- Create an instruction, which pushes the value in the above register to the top of the program stack, and then execute it. Observe the value in **Program Stack** (Figure 5).

| PROGRAM STACK (RAM) |     |         |      |  |
|---------------------|-----|---------|------|--|
|                     | Pos | Val (D) | Addr |  |
| TOS->               | 1   | 12      | 0011 |  |

- Create an instruction to push number 2 on top of the program stack and execute it. Observe the value in **Program Stack** (Figure 5).

| PROGRAM STACK (RAM) |     |         |      |  |
|---------------------|-----|---------|------|--|
|                     | Pos | Val (D) | Addr |  |
| TOS->               | 2   | 2       | 0014 |  |
|                     | 1   | 12      | 0011 |  |

11. Create an instruction to unconditionally jump to the first instruction.

|  |
|--|
|  |
|--|

12. Execute it.

13. Observe the value in the **PC** register. This is the address of the next instruction to be executed. Make a note of the instruction it is pointing to?

|  |
|--|
|  |
|--|

14. Create an instruction to pop the value on top of the **Program Stack** into register R02.



15. Execute it.

16. Create an instruction to pop the value on top of the **Program Stack** into register R03.



17. Execute it.

18. Execute the last instruction once again. What happened? Explain.

|                                        |
|----------------------------------------|
| stack underflow because stack is empty |
|----------------------------------------|

19. Create a compare instruction, which compares values in registers R04 and R05.



20. Manually insert two equal values in registers R04 and R05 (Figure 4).

21. Execute the above compare instruction.

22. Which of the status flags **OV/Z/N** is set (i.e. box is checked)?

| SPECIAL CPU REGISTERS        |                                       | GENERAL PURPOSE CPU REGISTERS |                            |     |         |
|------------------------------|---------------------------------------|-------------------------------|----------------------------|-----|---------|
| Reg                          | Val (D)                               | C                             | Va                         | Reg | Val (D) |
| PC                           | 33                                    | SR                            | 1                          | R00 | 5       |
| SP                           | 8102                                  | BR                            | 0                          | R01 | 12      |
| SR Status Fl                 |                                       | CPU Mod                       |                            | R02 | 0       |
| OV <input type="checkbox"/>  | Z <input checked="" type="checkbox"/> | N <input type="checkbox"/>    | User <input type="radio"/> | R03 | 0       |
| Kernel <input type="radio"/> |                                       |                               |                            | R04 | 1       |
|                              |                                       |                               |                            | R05 | 1       |

23. Manually insert a value in first register greater than that in second register.

24. Execute the compare instruction again.

25. Which of the status flags **OV/Z/N** is set?

| SPECIAL CPU REGISTERS        |                            | GENERAL PURPOSE CPU REGISTERS         |                            |     |         |
|------------------------------|----------------------------|---------------------------------------|----------------------------|-----|---------|
| Reg                          | Val (D)                    | C                                     | Va                         | Reg | Val (D) |
| PC                           | 33                         | SR                                    | 2                          | R00 | 5       |
| SP                           | 8102                       | BR                                    | 0                          | R01 | 12      |
| SR Status Fl                 |                            | CPU Mod                               |                            | R02 | 0       |
| OV <input type="checkbox"/>  | Z <input type="checkbox"/> | N <input checked="" type="checkbox"/> | User <input type="radio"/> | R03 | 0       |
| Kernel <input type="radio"/> |                            |                                       |                            | R04 | 1       |
|                              |                            |                                       |                            | R05 | 0       |

26. Manually insert a value in first register smaller than that in second register.

27. Execute the compare instruction once again.

28. Which of the status flags **OV/Z/N** is set?

| SPECIAL CPU REGISTERS        |                            | GENERAL PURPOSE CPU REGISTERS |                            |     |          |
|------------------------------|----------------------------|-------------------------------|----------------------------|-----|----------|
| Reg                          | Val (D)                    | B                             | Val1 (D)                   | C   | Val2 (D) |
| PC                           | 33                         | SR                            | 0                          | R00 | 0        |
| SP                           | 8096                       | BR                            | 0                          | R01 | 0        |
| SR Status Fl                 |                            | CPU Mod                       |                            | R02 | 0        |
| OV <input type="checkbox"/>  | Z <input type="checkbox"/> | N <input type="checkbox"/>    | User <input type="radio"/> | R03 | 0        |
| Kernel <input type="radio"/> |                            |                               |                            | R04 | 0        |
|                              |                            |                               |                            | R05 | 1        |
| IR                           | CMP R04, R05               |                               | R06                        | 0   |          |
| MAR                          | 28                         |                               | R07                        | 0   |          |
| MDR                          | CMR05                      |                               | R08                        | 0   |          |
|                              |                            |                               | R09                        | 0   |          |
|                              |                            |                               | R10                        | 0   |          |

29. Create an instruction, which will jump to the first instruction if the values in registers R04 and R05 are equal.



30. Test the above instruction by manually putting equal values in registers R04 and R05, then first executing the compare instruction followed by executing the jump instruction (**Remember:** You execute an instruction by double-clicking on it). If it worked the first instruction should be highlighted.

31. Now that you have some understanding of basic CPU instructions and are able to program the simulator here is a bit of challenge for you: preparing a little program loop. Program loops are extremely useful and are very frequently used by computer programs. Here's what you have to do:

1. Create an instruction that moves number 0 into register R01
2. Create an instruction that adds number 1 to register R01
3. Create an instruction that compares number 10 and register R01
4. Create an instruction that jumps back to instruction 2 above if R01 is not equal to number 10.
5. Create a HLT instruction.

Make a note of the instructions 1 to 5 you created above in the box below:

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |              |      |   |  |
|----------------------------------|------|--------------|------|---|--|
| PAdd                             | LAdd | Instruction  | Base | T |  |
| □ 1000                           | 0000 | MOV #0, R00  | 1000 | 0 |  |
| □ 1006                           | 0006 | ADD #1, R01  | 1000 | 1 |  |
| □ 1012                           | 0012 | CMP #10, R01 | 1000 | 3 |  |
| □ 1018                           | 0018 | JNE 0006     | 1000 | 2 |  |
| □ → 1022                         | 0022 | HLT          | 1000 | 2 |  |

6. Starting from instruction 1 manually execute instructions 1 to 4 one after the other. What happened when you executed instruction 4?

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |              |      |   |  |
|----------------------------------|------|--------------|------|---|--|
| PAdd                             | LAdd | Instruction  | Base | T |  |
| □ 1000                           | 0000 | MOV #0, R00  | 1000 | 0 |  |
| □ → 1006                         | 0006 | ADD #1, R01  | 1000 | 1 |  |
| □ 1012                           | 0012 | CMP #10, R01 | 1000 | 3 |  |
| □ 1018                           | 0018 | JNE 0006     | 1000 | 2 |  |
| □ 1022                           | 0022 | HLT          | 1000 | 2 |  |

go back to instruction 2

7. Now first click on the **RESET PROGRAM** button (see **Program Control** tab in Figure 1) and then highlight instruction 1 above. Next click on the **RUN** button. Now observe the loop in action.



## Part B: (Refer to the appendix for help with CPU instructions)

- Produce the code for a conditional statement such that if the value in register R02 is **greater than** (**>**) the value in register R01 then register R03 is set to 8. Test it on the simulator.

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |              |      |
|----------------------------------|------|--------------|------|
| PAdd                             | LAdd | Instruction  | Base |
| □ 0000                           | 0000 | CMP R02, R01 | 0000 |
| □ <b>0005</b>                    | 0005 | JGT 5        | 0000 |
| □ 0009                           | 0009 | MOV #8, R03  | 0000 |

- Produce the code for a loop that repeats **5 times** where the value of register R02 is incremented by 2 every time the loop repeats. Test it on the simulator.

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |             |      |
|----------------------------------|------|-------------|------|
| PAdd                             | LAdd | Instruction | Base |
| □ 3000                           | 0000 | MOV #5, R00 | 3000 |
| □ 3006                           | 0006 | ADD #2, R02 | 3000 |
| □ 3012                           | 0012 | SUB #1, R00 | 3000 |
| □ 3018                           | 0018 | CMP #0, R00 | 3000 |
| □ 3024                           | 0024 | JGT 6       | 3000 |
| □ <b>3028</b>                    | 0028 | HLT         | 3000 |

- The numbers 4, -3, 5 and -6 are manually pushed on top of stack in that order. Produce the code for a routine that **pops** two numbers from top of stack **multiplies** them and **pushes** the result back to top of stack. The routine repeats this until there is only one number left on top of stack. Test the code on the simulator.

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |              |      | Cache - Pipeline | Execution Unit | SPECIAL CPU REGISTERS | GENERAL PURPOSE CPU REGISTERS |         |   |         |
|----------------------------------|------|--------------|------|------------------|----------------|-----------------------|-------------------------------|---------|---|---------|
| PAdd                             | LAdd | Instruction  | Base | PC               | SR             | BR                    | Reg                           | Val (D) | C | Val (D) |
| □ 2000                           | 0000 | MOV #3, R02  | 2000 | 36               | 1              | 2000                  | R00                           | 90      |   |         |
| □ 2006                           | 0006 | POP R00      | 2000 | 8098             |                |                       | R01                           | 360     |   |         |
| □ 2009                           | 0009 | POP R01      | 2000 |                  |                |                       | R02                           | 0       |   |         |
| □ 2012                           | 0012 | MUL R00, R01 | 2000 |                  |                |                       | R03                           | 0       |   |         |
| □ 2017                           | 0017 | PSH R01      | 2000 |                  |                |                       | R04                           | 0       |   |         |
| □ 2020                           | 0020 | SUB #1, R02  | 2000 |                  |                |                       | R05                           | 0       |   |         |
| □ 2026                           | 0026 | CMP #0, R02  | 2000 |                  |                |                       | R06                           | 0       |   |         |
| □ 2032                           | 0032 | JGT 6        | 2000 |                  |                |                       | R07                           | 0       |   |         |
| □ <b>2036</b>                    | 0036 | HLT          | 2000 |                  |                |                       | R08                           | 0       |   |         |
|                                  |      |              |      |                  |                |                       | R09                           | 0       |   |         |
|                                  |      |              |      |                  |                |                       | R10                           | 0       |   |         |

## Part C: Instructions for writing to and reading from memory (RAM):

- Locate the instruction that **stores** a byte in program data memory and use it to store number 65 in memory address location 20 (this uses **memory direct** addressing method).

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |             |      |
|----------------------------------|------|-------------|------|
| PAdd                             | LAdd | Instruction | Base |
| 0000                             | 0000 | STB #65, 20 | 0000 |

- Move number 51 into register R04. Use the store instruction to **store** the contents of R04 in program data memory location 21 (this uses **register direct** addressing method).

|      |      |              |      |
|------|------|--------------|------|
| 0007 | 0007 | MOV #51, R04 | 0000 |
| 0013 | 0013 | STB R04, 21  | 0000 |

- Move number 22 into register R04. Use this information to indirectly **store** number 59 in program data memory (hint: you will need to use the '@' prefix for this – see the list of instructions in appendix) - (this uses **register indirect** addressing method).

|      |      |              |      |
|------|------|--------------|------|
| 0019 | 0019 | MOV #22, R04 | 0000 |
| 0025 | 0025 | MOV #59, R00 | 0000 |
| 0031 | 0031 | STB R00, 0   | 0000 |

- Locate the instruction that **loads** a byte from program data memory into a register. Use this to load the number in memory address 22 into register R10.

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |                 |                 | CACHE - PIPELINE | Execution Unit    | SPECIAL CPU REGISTERS | GENERAL PURPOSE CPU REGISTERS |
|----------------------------------|------|-----------------|-----------------|------------------|-------------------|-----------------------|-------------------------------|
| 1000 0000 MOV #9, R06            | 1000 | PC 18 SR 0      | SP 8096 BR 1000 | Single pipeline  | Dual pipeline     | SR Status FI          | Reg Val(D) C Val(D)           |
| 1006 0006 MOV #59, R00           | 1000 | SP 8096         | BR 1000         | Select pipeline  | Show Pipeline...  | OV Z N                | R00 59                        |
| 1012 0012 STB R00, 0             | 1000 | IR LDB @22, R10 | MAR 1018        | Cache            | Select cache type | CPU Mod User Kernel   | R01 0                         |
| 1018 0018 LDB @22, R10           | 1000 | MDR LDB @2:     |                 | Data             | Show Cache...     |                       | R02 0                         |
|                                  |      |                 |                 |                  |                   |                       | R03 0                         |
|                                  |      |                 |                 |                  |                   |                       | R04 22                        |
|                                  |      |                 |                 |                  |                   |                       | R05 0                         |
|                                  |      |                 |                 |                  |                   |                       | R06 0                         |
|                                  |      |                 |                 |                  |                   |                       | R07 0                         |
|                                  |      |                 |                 |                  |                   |                       | R08 0                         |
|                                  |      |                 |                 |                  |                   |                       | R09 0                         |
|                                  |      |                 |                 |                  |                   |                       | R10 59                        |

- Write a loop in which 10 numbers from 41 to 50 are written in program data memory starting from memory address 24 (hint: use **register indirect** addressing where register R04 indirectly represents memory address to write to and increment it to address increasing memory locations).

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |             |      | DATA MEMORY |                                             |    |    |    |    |    |    |
|----------------------------------|------|-------------|------|-------------|---------------------------------------------|----|----|----|----|----|----|
| PAdd                             | LAdd | Instruction | Base | FAdd        | B0                                          | B1 | B2 | B3 | B4 | B5 | B6 |
| 1000 0000 MOV #9, R06            | 1000 |             |      | -----       | 0000 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1006 0006 MOV #41, R07           | 1000 |             |      | -----       | 0008 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1012 0012 MOV #24, R05           | 1000 |             |      | -----       | 0016 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1018 0018 STB R07, @R08          | 1000 |             |      | -----       | 0024 29 2A 2B 2C 2D 2E 2F 30 )+,-/0         |    |    |    |    |    |    |
| 1023 0023 ADD #1, R08            | 1000 |             |      | -----       | 0032 31 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1029 0029 ADD #1, R07            | 1000 |             |      | -----       | 0040 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1035 0035 SUB #1, R06            | 1000 |             |      | -----       | 0048 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1041 0041 CMP #0, R06            | 1000 |             |      | -----       | 0056 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1047 0047 JGT 18                 | 1000 |             |      | -----       | 0064 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
| 1051 0051 HLT                    | 1000 |             |      | -----       | 0072 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
|                                  |      |             |      | -----       | 0080 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
|                                  |      |             |      | -----       | 0088 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
|                                  |      |             |      | -----       | 0096 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
|                                  |      |             |      | -----       | 0104 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |
|                                  |      |             |      | -----       | 0112 00 00 00 00 00 00 00 00 00 00 00 ..... |    |    |    |    |    |    |

6. Manually initialise part of program data memory starting from address 40 with string “CPU INSTRUCTIONS RULE” (see section D above on how to do this). Write a loop in which this string is copied to another part of the program data memory starting from address 64.

The screenshot shows two windows from a CPU Simulator:

- CPU INSTRUCTIONS IN MEMORY (RAM)**: A table showing memory locations from 0100 to 0150. The last row, address 0150, contains the instruction HLT.
- DATA MEMORY**: A table showing memory starting at address 0000. The row at address 0080 is highlighted in blue, indicating it is the target for the string copy operation.

| PAdd | LAdd | Instruction    | Base |
|------|------|----------------|------|
| 0100 | 0000 | MOV #22, R00   | 0100 |
| 0106 | 0006 | MOV #40, R01   | 0100 |
| 0112 | 0012 | MOV #64, R02   | 0100 |
| 0118 | 0018 | LDBI @R01, R05 | 0100 |
| 0123 | 0023 | STB R05, @R02  | 0100 |
| 0128 | 0028 | ADD #1, R02    | 0100 |
| 0134 | 0034 | SUB #1, R00    | 0100 |
| 0140 | 0040 | CMP #0, R00    | 0100 |
| 0146 | 0046 | JGT 18         | 0100 |
| 0150 | 0050 | HLT            | 0100 |

  

| PAdd | LAdd | B0 | B1 | B2 | B3 | B4 | B5 | B6 | B7 | Data  |
|------|------|----|----|----|----|----|----|----|----|-------|
| 0000 | 0000 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0008 | 0008 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0016 | 0016 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0024 | 0024 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0032 | 0032 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0040 | 0040 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0048 | 0048 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0056 | 0056 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0064 | 0064 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0072 | 0072 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0080 | 0080 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0088 | 0088 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0096 | 0096 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0104 | 0104 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |
| 0112 | 0112 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ..... |

#### **Part D: Instructions for calling subroutines and passing parameters to subroutines:**

1. Add the following code and run it starting from the first MOV instruction (to do this you need to first select this instruction and then click on the RUN button).

**NOTE:**

Ask your tutor how to add labels to your code. A Label represents the address of the instruction immediately following it. For example, 'Label2' below represents the address of the MOV instruction following it. Labels are used by the jump instructions by putting a '\$' in front of the label name, e.g. the 'JMP \$Label2' instruction will jump to the instruction at address represented by the label 'Label2'.

```
Label2
MOV #16, R03
MOV #h41, R04
Label3
STB R04, @R03
ADD #1, R03
ADD #1, R04
CMP #h4F, R04
JNE $Label3
HLT
```

## **NOTE:**

This code stores numbers hex 41 to hex 4F starting from program memory address 16. These numbers are ASCII codes for displayable characters of the alphabet. You need to understand how this is done by this code in order to benefit from these exercises.

- a. Make a note of what you see in the program's data area after the program stops running:

|       |      |    |    |    |    |    |    |    |    |            |
|-------|------|----|----|----|----|----|----|----|----|------------|
| ----- | 0000 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | .....      |
| ----- | 0016 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | ABCDEFGH   |
| ----- | 0024 | 49 | 4A | 4B | 4C | 4D | 4E | 00 | 00 | IJKLMNOP.. |

- b. Suggest what the significance of @ in @R03 might be:

Indicate address value in R03

2. Add the following subroutine calling code but do **NOT** run it yet:

**MSF**  
**CAL \$Label2**  
**HLT**

Now convert the code in (1) above into a subroutine by simply replacing the **HLT** instruction with the **RET** instruction.

- a. Make a note of the contents of the **PROGRAM STACK** after the instruction **MSF** is executed (you can execute this instruction by simply double-clicking on it):

|       | Pos | Val (D) | Addr |
|-------|-----|---------|------|
| TOS-> | 1   | 0       | 0040 |
| BOS-> | 0   | 0       | 0040 |

- b. Make a note of the contents of the **PROGRAM STACK** after the instruction **CAL** is executed (you can execute this instruction by simply double-clicking on it):

|       | Pos | Val (D) | Addr |
|-------|-----|---------|------|
| TOS-> | 1   | 45      | 0040 |
| BOS-> | 0   | 0       | 0040 |

- c. What is the significance of the additional information on the stack after executing the **CAL** instruction?

used to call the specified subroutine

3. Let's make the above subroutine a little more flexible. Suppose we wish to change the number of characters stored when calling the subroutine. Modify the calling code in (2) as below:

```

MSF
PSH #h60      ← puts the number hex 60 on top of the stack
CAL $Label2
HLT

```

- a. Now modify the subroutine code in (1) as below and run the above calling code (starting from the **MSF** instruction). Pay particular attention to the behaviour of the stack:

```

Label2
MOV #16, R03
MOV #h41, R04
POP R05      ← puts the number on top of the stack in R05

Label3
STB R04, @R03
ADD #1, R03
ADD #1, R04
CMP R05, R04 ← compares R05 with R04

JNE $Label3
RET

```

b. Add a second parameter to the above code that can provide different starting addresses for the data transfer to memory and test it on the simulator. Write the modified code below:

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |                  |     |
|----------------------------------|------|------------------|-----|
| PAdd                             | LAdd | Instruction      | Bas |
| 0100                             | 0000 | Label2.1::       | 010 |
| 0100                             | 0000 | POP R06          | 010 |
| 0103                             | 0003 | MOV R06, R03     | 010 |
| 0108                             | 0008 | MOV #h41, R04    | 010 |
| 0114                             | 0014 | POP R05          | 010 |
| 0117                             | 0017 | Label3::         | 010 |
| 0117                             | 0017 | STB R04, @R03    | 010 |
| 0122                             | 0022 | ADD #1, R03      | 010 |
| 0128                             | 0028 | ADD #1, R04      | 010 |
| 0134                             | 0034 | CMP R05, R04     | 010 |
| 0139                             | 0039 | JNE \$Label3     | 010 |
| 0143                             | 0043 | RET              | 010 |
| 0144                             | 0044 | MSF              | 010 |
| 0145                             | 0045 | PSH #h60         | 010 |
| 0149                             | 0049 | PSH #16          | 010 |
| 0153                             | 0053 | CAL \$Label2.1:: | 010 |
| 0157                             | 0057 | HLT              | 010 |

4. Write a subroutine that takes two numbers as parameters, adds them and returns the result in register R00, i.e. when the subroutine is exited the result is available in R00 to the rest of the program. Test it on the simulator by writing the calling instructions that include passing two numbers on the stack. Copy the code below (including the calling instructions):

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |              |     |
|----------------------------------|------|--------------|-----|
| PAdd                             | LAdd | Instruction  | Bas |
| 0100                             | 0000 | l::          | 010 |
| 0100                             | 0000 | POP R00      | 010 |
| 0103                             | 0003 | POP R01      | 010 |
| 0106                             | 0006 | ADD R00, R01 | 010 |
| 0111                             | 0011 | RET          | 010 |
| 0112                             | 0012 | MSF          | 010 |
| 0113                             | 0013 | PSH #15      | 010 |
| 0117                             | 0017 | PSH #10      | 010 |
| 0121                             | 0021 | CAL \$1      | 010 |
| 0125                             | 0025 | HLT          | 010 |

5. Write a subroutine that takes two numbers as parameters, compares them and returns the higher of the two as the result in register R00 (consider what should happen if the two numbers are the same). Test it on the simulator by writing the calling instructions that include passing two numbers on the stack. Copy the subroutine code alone below:

| CPU INSTRUCTIONS IN MEMORY (RAM) |      |              |
|----------------------------------|------|--------------|
| PAdd                             | LAdd | Instruction  |
| □ 0100                           | 0000 | label::      |
| □ 0100                           | 0000 | POP R01      |
| □ 0103                           | 0003 | POP R02      |
| □ 0106                           | 0006 | CMP R01, R02 |
| □ 0111                           | 0011 | JGT 25       |
| □ 0115                           | 0015 | JLT 19       |
| □ 0119                           | 0019 | MOV R01, R00 |
| □ 0124                           | 0024 | RET          |
| □ 0125                           | 0025 | MOV R02, R00 |
| □ 0130                           | 0030 | RET          |
| □ 0131                           | 0031 | MSF          |
| □ 0132                           | 0032 | PSH #40      |
| □ 0136                           | 0036 | PSH #40      |
| □ 0140                           | 0040 | CAL Slabel:  |
| □ → 0144                         | 0044 | HLT          |

\*\*\* End of Exercises \*\*\*

## Appendix – CPU Simulator Instruction Sub-set

| Inst.                             | Description                                                                                                                                                                                                                                                                          |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Data transfer instructions</b> |                                                                                                                                                                                                                                                                                      |
| MOV                               | Move data to register; move register to register e.g.<br><b>MOV #2, R01</b> moves number 2 into register R01<br><b>MOV R01, R03</b> moves contents of register R01 into register R03                                                                                                 |
| LDB                               | Load a byte from memory to register e.g.<br><b>LDB 1022, R03</b> loads a byte from memory address 1022 into R03<br><b>LDB @R02, R05</b> loads a byte from memory the address of which is in R02                                                                                      |
| LDW                               | Load a word (2 bytes) from memory to register<br>Same as in LDB but a word (i.e. 2 bytes) is loaded into a register                                                                                                                                                                  |
| STB                               | Store a byte from register to memory<br><b>STB R07, 2146</b> stores a byte from R07 into memory address 2146<br><b>STB R04, @R08</b> stores a byte from R04 into memory address of which is in R08                                                                                   |
| STW                               | Store a word (2 bytes) from register to memory<br>Same as in STB but a word (i.e. 2 bytes) is loaded stored in memory                                                                                                                                                                |
| PSH                               | Push data to top of hardware stack (TOS); push register to TOS e.g.<br><b>PSH #6</b> pushes number 6 on top of the stack<br><b>PSH R03</b> pushes the contents of register R03 on top of the stack                                                                                   |
| POP                               | Pop data from top of hardware stack to register e.g.<br><b>POP R05</b> pops contents of top of stack into register R05<br><b>Note:</b> If you try to POP from an empty stack you will get the error message "Stack underflow".                                                       |
| <b>Arithmetic instructions</b>    |                                                                                                                                                                                                                                                                                      |
| ADD                               | Add number to register; add register to register e.g.<br><b>ADD #3, R02</b> adds number 3 to contents of register R02 and stores the result in register R02.<br><b>ADD R00, R01</b> adds contents of register R00 to contents of register R01 and stores the result in register R01. |
| SUB                               | Subtract number from register; subtract register from register                                                                                                                                                                                                                       |
| MUL                               | Multiply number with register; multiply register with register                                                                                                                                                                                                                       |
| DIV                               | Divide number with register; divide register with register                                                                                                                                                                                                                           |

| Control transfer instructions |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| JMP                           | Jump to instruction address <u>unconditionally</u> e.g.<br><b>JMP 100</b> unconditionally jumps to address location 100 where there is another instruction                                                                                                                                                                                                                                                                                                                                                                     |
| JLT                           | Jump to instruction address if less than (after last comparison)                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| JGT                           | Jump to instruction address if greater than (after last comparison)                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| JEQ                           | Jump to instruction address if equal (after last comparison instruction) e.g.<br><b>JEQ 200</b> jumps to address location 200 if the previous comparison instruction result indicates that the two numbers are equal, i.e. the <b>Z</b> status flag is set (the <b>Z</b> box will be checked in this case).                                                                                                                                                                                                                    |
| JNE                           | Jump to instruction address if not equal (after last comparison)                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| MSF                           | Mark Stack Frame instruction is used in conjunction with the CAL instruction. e.g.<br><b>MSF</b> reserve a space for the return address on program stack <b>CAL 1456</b> save the return address in the reserved space and jump to subroutine in address location 1456                                                                                                                                                                                                                                                         |
| CAL                           | Jump to subroutine address (saves the return address on program stack)<br>This instruction is used in conjunction with the <b>MSF</b> instruction. You'll need an MSF instruction before the CAL instruction. See the example above                                                                                                                                                                                                                                                                                            |
| RET                           | Return from subroutine (uses the return address on stack)                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| SWI                           | Software interrupt (used to request OS help)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| HLT                           | Halt simulation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Comparison instruction        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CMP                           | Compare number with register; compare register with register e.g.<br><b>CMP #5, R02</b> compare number 5 with the contents of register R02<br><b>CMP R01, R03</b> compare the contents of registers R01 and R03 Note:<br>If R01 = R03 then the status flag <b>Z</b> will be set, i.e. the <b>Z</b> box is checked. If R01 < R03 then none of the status flags will be set, i.e. none of the status flag boxes are checked.<br>If R01 > R03 then the status flag <b>N</b> will be set, i.e. the <b>N</b> status box is checked. |

| Input, output instructions |                                                                                                                                                                |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IN                         | Get input data (if available) from an external IO device                                                                                                       |
| OUT                        | Output data to an external IO device e.g.<br><b>OUT 16, 0</b> outputs contents of data in location 16 to the console (the second parameter must always be a 0) |

\*\*\*\*\*