









### **How It All Works**

- Basic operation of the M68000 involves performing one or more of the following functions:
  - 1. Fetching contents of a memory location and storing these contents in a CPU register.
  - 2. Storing the contents of a CPU register into a location in memory.
  - 3. Transferring the contents of one CPU register to another.
  - 4. Performing an arithmetic or logical operation and storing the result in a CPU register.
- · Let's look at how to do some of these things...

CSC258 Lecture Slides © Steve Engels, 2006

Slide 6 of 38



























| <b>Control Flow</b>                               | / Instructions                                          |  |
|---------------------------------------------------|---------------------------------------------------------|--|
| 3 main types of control f                         | low instructions.                                       |  |
| <ul> <li>Branching:</li> </ul>                    |                                                         |  |
| BRA (branch always)<br>BSR (branch to subroutine) | Bcc (branch conditionally)<br>DBcc (decrement, and Bcc) |  |
| – Jumping:                                        |                                                         |  |
| JMP (jump to address)                             | JSR (jump to subroutine)                                |  |
| - Subroutines:                                    |                                                         |  |
| RTS (return from subroutine)                      | RTE (return from exception)                             |  |
| CSC258 Lecture Slides © Steve Engels, 2006        | Slide 23 of 38                                          |  |

## **Control Flow Instructions**

• Branch condition codes

| Machine Code                | Condition Suffix (cc)  | Name             | Test Condition                    |
|-----------------------------|------------------------|------------------|-----------------------------------|
| 0000                        | Т                      | True             | Always true                       |
| 0001                        | F                      | False            | Always false                      |
| 0010                        | HI                     | High             | C V Z = 0                         |
| 0011                        | LS                     | Low or Same      | C V Z = 1                         |
| 0100                        | CC                     | Carry Clear      | C = 0                             |
| 0101                        | CS                     | Carry Set        | C = 1                             |
| 0110                        | NE                     | Not Equal        | Z = 0                             |
| 0111                        | EQ                     | Equal            | Z = 1                             |
| 1000                        | VC                     | oVerflow Clear   | V = 0                             |
| 1001                        | VS                     | oVerflow Set     | V = 1                             |
| 1010                        | PL                     | Plus             | N = 0                             |
| 1011                        | MI                     | Minus            | N = 1                             |
| 1100                        | GE                     | Greater or Equal | N ⊕ V = 0                         |
| 1101                        | LT                     | Less Than        | N ⊕ V = 1                         |
| 1110                        | GT                     | Greater Than     | $Z \vee (N \oplus V) = 0$         |
| 1111                        | LE                     | Less or Equal    | Z ∨ (N ⊕ V) = 1                   |
| 1111<br>ecture Slides © Ste | LE<br>eve Engels, 2006 | Less or Equal    | $Z \lor (N \oplus V) = 1$<br>Slid |







- The first 256 long words in memory store the memory addresses of vital processor subroutines.
   – address 0 contains the address of the initial startup routine.
- This is also called the exception vector table.
- Locations 32-47 of this table are allocated to the trap vectors, and the contents of these entries can be set by the operating system (which you create).
- Calling Trap #14 would then look up entry 46 in the exception table, go to the address specified in that entry, and execute the subroutine at that address.



CSC258 Lecture Slides @ Steve Engels, 2006

# Memory-Mapped I/O

- The trap entries in the exception table contain the address of the exception code. How does that exception code actually read or write from external devices?
- The trap code assumes that the information to write is in a particular register, or that the information to read should be stored in a particular data register.
  - In the case of reading or writing strings, an address register is used instead to store the initial address of the string. A null character is used to indicate that the string has terminated.
- The actual address of the device's IO location can vary, depending on the hardware implementation.

CSC258 Lecture Slides © Steve Engels, 2006

Slide 29 of 38

### Memory-Mapped I/O

- When performing read or write operations, we're typically interested in the parallel or serial ports.
  - Printer/monitor  $\rightarrow$  parallel
- Keyboard/internet  $\rightarrow$  serial
- To perform these actions, the M68xxx systems either map specific devices to location in memory, or will implement a multi-function peripheral (MFP) interface.
- The MFP interface is a series of registers in memory that are responsible for the various aspects of I/O operations:
  - Data direction
  - Control register
  - Receiver/transmitter status register
  - Data register

CSC258 Lecture Slides © Steve Engels, 2006

Slide 30 of 38



#### **Opcodes**

- When an assembly language program is compiled by the assembler, it is translated into binary instructions that can be recorded in memory and understood by the instruction decoder.
  - Also called opcodes (short for operation codes)
- How does it do this translation? What do these binary instructions look like?
- Each instruction can be broken down into parts,
  - to see what assembly language instruction it corresponds to
  - to see how the instruction decoder understands its contents

CSC258 Lecture Slides © Steve Engels, 2006

Slide 32 of 38











