

**ECE 242**

# Digital Computers and Computing

**Lecture 5. Intro to MC68K – Part 2**  
Spring 2021

Won-Jae Yi

## Status Register – Examples

→ SR: 

- $SR = \underline{\underline{0202}}$  → 0000 0100 0000 0100  
 $T=0 \rightarrow$  trace node off  
 $S=0 \rightarrow$  user mode  
 $T_2, T_0 = 010_2 = 2 \rightarrow$  (at. level 2, 1, 0 will not be recognized)
- $SR = \underline{\underline{A002}}$   
 $C=0$  → CCR  
 $X=0$  → extended  
 $Z=0$  → non-negative  
 $J=1$  → non-local occurred  
 $C=0$  → no carry.
- $SR = \underline{\underline{0100}}$  → 0000 0000 0000 0100  
trace or supervisor mode  
state always possible

# MC68000 Instruction Set

- Information can be found in Appendix IV of the textbook
- Also, can be found under Motorola MC68000 Programmer's Reference Manual (Section 4)
  - [https://www.nxp.com/files-static/archives/doc/ref\\_manual/M68000PRM.pdf](https://www.nxp.com/files-static/archives/doc/ref_manual/M68000PRM.pdf)
- Programmers refer to this manual when programming in assembly/machine language

# MC68000 Instruction Set

- Symbolic instruction to add two 16-bit operands

ADD.W      X,Y

- (Instruction).(Length) (operand),(operand)

# Example – CLR (Clear) CLR

Clear an Operand

**Operation:** 0 → Destination

**Assembler Syntax:** CLR <ea>

**Attributes:** Size = (Byte, Word, Long)

**Description:** The destination is cleared to all zero bits. The size of the operation may be specified to be byte, word, or long.

**Condition Codes:**

| X | N               | Z | V | C |
|---|-----------------|---|---|---|
| — | 0               | 1 | 0 | 0 |
| N | Always cleared. |   |   |   |
| Z | Always set.     |   |   |   |
| V | Always cleared. |   |   |   |
| C | Always cleared. |   |   |   |
| X | Not affected.   |   |   |   |

**Instruction Format:**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7                      | 6        | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|------|------------------------|----------|---|---|---|---|---|---|
| Dn |    |    |    |    |    |   |      |                        |          |   |   |   |   |   |   |
| 0  | 1  | 0  | 0  | 0  | 1  | 0 | Size | Effective Address Mode | Register |   |   |   |   |   |   |
|    |    |    |    |    |    |   |      |                        |          |   |   |   |   |   |   |

**Instruction Fields:**

Size field — Specifies the size of the operation:

00 — byte operation.

01 — word operation.

10 — long operation.  
Effective Address field — Specifies the destination location. Only data alterable addressing modes are allowed as shown:

| Addressing Mode                | Mode | Register        | Addressing Mode                     | Mode | Register        |
|--------------------------------|------|-----------------|-------------------------------------|------|-----------------|
| Dn                             | 000  | register number | d(A <sub>n</sub> , X <sub>i</sub> ) | 110  | register number |
| A <sub>n</sub>                 | —    | —               | Abs.W                               | 111  | 000             |
| (A <sub>n</sub> )              | 010  | register number | Abs.L                               | 111  | 001             |
| (A <sub>n</sub> ) <sup>+</sup> | 011  | register number | d(PC)                               | —    | —               |
| -(A <sub>n</sub> )             | 100  | register number | d(PC, X <sub>i</sub> )              | —    | —               |
| d(A <sub>n</sub> )             | 101  | register number | Imm                                 | —    | —               |

**Note:** A memory destination is read before it is written to.

|       |       | Instruction |       | Contents of the Destination |  |
|-------|-------|-------------|-------|-----------------------------|--|
|       |       |             |       | After Instruction Executes  |  |
| CLR.B | (EAd) | CLR.B       | (EAd) | FFFF FF00                   |  |
| CLR.W | (EAd) | CLR.W       | (EAd) | FFFF 0000                   |  |
| CLR.L | (EAd) | CLR.L       | (EAd) | 0000 0000                   |  |

*Note:* Destination contains FFFF FFFF before each instruction executes.

# Example – MOVE (Move)

MOVE.X <EA<sub>SD</sub>>

- X is B, W or L (length/size of the operand)
- <EA<sub>S</sub>> : Effective Address source
- <EA<sub>D</sub>> : Effective Address destination
- Can include registers or memory locations



(a) Operands for Byte, Word, or Longword Length



B

When D2 is 0FFF 0105... Content of D1 for:

- MOVE.B D2, D1
- MOVE.W D2, D1
- MOVE.L D2, D1



B



W



L

Note: Source operand is FFFF FFFF<sub>16</sub>.

# Example – MOVE (Move)

## Integer Instructions

| <b>MOVE</b> | Move Data from Source to Destination<br>(M68000 Family) |
|-------------|---------------------------------------------------------|
|-------------|---------------------------------------------------------|

Operation: Source → Destination

Assembler Syntax: MOVE < ea > , < ea >

Attributes: Size = (Byte, Word, Long)

Description: Moves the data at the source to the destination location and sets the condition codes according to the data. The size of the operation may be specified as byte, word, or long. Condition Codes:



- X — Not affected.
- N — Set if the result is negative; cleared otherwise.
- Z — Set if the result is zero; cleared otherwise.
- V — Always cleared.
- C — Always cleared.

## Instruction Format:

| 15          | 14 | 13   | 12       | 11   | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3        | 2 | 1 | 0 |
|-------------|----|------|----------|------|----|---|---|--------|---|---|---|----------|---|---|---|
| DESTINATION |    |      |          | MODE |    |   |   | SOURCE |   |   |   | REGISTER |   |   |   |
| 0           | 0  | SIZE | REGISTER |      |    |   |   |        |   |   |   |          |   |   |   |

## Instruction Fields:

Size field—Specifies the size of the operand to be moved.

01 — Byte operation

11 — Word operation

10 — Long operation

| <b>MOVE</b> | Move Data from Source to Destination<br>(M68000 Family) | <b>MOVE</b> | Move Data from Source to Destination<br>(M68000 Family) |
|-------------|---------------------------------------------------------|-------------|---------------------------------------------------------|
|-------------|---------------------------------------------------------|-------------|---------------------------------------------------------|

Destination Effective Address field—Specifies the destination location. Only data alterable addressing modes can be used as listed in the following tables:

| Addressing Mode | Mode | Register      |
|-----------------|------|---------------|
| Dn              | 000  | reg number Dn |
| An              | —    | —             |
| (An)            | 010  | reg number An |
| (An) +          | 011  | reg number An |
| – (An)          | 100  | reg number An |
| (d16-An)        | 101  | reg number An |
| (d8-An)         | 110  | reg number An |

| Addressing Mode | Mode | Register      |
|-----------------|------|---------------|
| (bd-An,Xn)*     | 110  | reg number An |
| (bd-An,Xn,od)   | 110  | (bd,PC,Xn,od) |
| (bd-An,Xn,od)   | 110  | (bd,PC,Xn,od) |

\*Can be used with CPU32.

Source Effective Address field—Specifies the source operand. All addressing modes can be used as listed in the following tables:

| Addressing Mode | Mode | Register      |
|-----------------|------|---------------|
| Dn              | 000  | reg number Dn |
| An              | 001  | reg number An |
| (An)            | 010  | reg number An |
| (An) +          | 011  | reg number An |
| – (An)          | 100  | reg number An |
| (d16-An)        | 101  | reg number An |
| (d8-An)         | 110  | reg number An |

| Addressing Mode | Mode | Register      |
|-----------------|------|---------------|
| (bd-An,Xn)*     | 110  | reg number An |
| (bd-An,Xn,od)   | 110  | (bd,PC,Xn,od) |
| (bd-An,Xn,od)   | 110  | (bd,PC,Xn,od) |

\*For byte size operation, address register direct is not allowed.

\*\*Can be used with CPU32.

## NOTE

Most assemblers use MOVEA when the destination is an address register.  
MOVEQ can be used to move an immediate 8-bit value to a data register.

# MC68000 Instruction Set

- JMP <EA>
  - BRA <disp>
- if D2 contains 0FFF 0105, D1 is...
- ADD.B      D2, D1
  - ADD.W      D2, D1
  - ADD.L      D2, D1

# Addressing Modes for MC68K

- Determine the ways in which a processor can reference an operand held in one of its registers or in memory
- Specifies how the processor is to locate or calculate the actual address (effective address) of the operand
- Broad categories of addressing
  - Direct addressing
  - Indirect addressing
  - Relative addressing
  - Immediate addressing

# Notation of MC68K Assembly Language

- An absolute address can be expressed in either <decimal address> or \$<hexadecimal address>
- Symbol “\*” represents current value of PC
- Symbol “#” preceding a number indicates immediate addressing (or a number)
- HEX number in the text itself is preceded by a “\$”
  - e.g., \$1000 vs 1000
- Immediate value in the text is preceded by a “#”
  - e.g., #\$1000 vs \$1000 vs #1000 vs 1000
- When writing an MC68K assembly code, must define where your code begins in memory
  - e.g., ORG \$8000

# Addressing Modes for MC68K

Table 5.7 MC68000 Addressing Modes

| Mode                              | Effective Address Calculation            |
|-----------------------------------|------------------------------------------|
| <i>Register direct addressing</i> |                                          |
| Data register direct              | $EA = D_n$                               |
| Address register direct           | $EA = A_n$                               |
| <i>Absolute data addressing</i>   |                                          |
| Absolute short                    | $EA = (\text{next word})$                |
| Absolute long                     | $EA = (\text{next two words})$           |
| <i>Indirect addressing</i>        |                                          |
| Address register indirect         | $EA = (A_n)$                             |
| Indirect with postincrement       | $EA = (A_n); (A_n) \leftarrow (A_n) + N$ |
| Indirect with predecrement        | $(A_n) \leftarrow (A_n) - N; EA = (A_n)$ |
| Indirect with displacement        | $EA = (A_n) + (d_{16})$                  |
| Indirect with index               | $EA = (A_n) + (X_n) + (d_8)$             |
| <i>Relative addressing</i>        |                                          |
| PC relative with offset           | $EA = (PC) + (d_{16})$                   |
| PC relative with index            | $EA = (PC) + (X_n) + (d_8)$              |
| <i>Immediate data addressing</i>  |                                          |
| Immediate                         | $DATA = \text{next word(s)}$             |
| Quick immediate                   | Inherent data                            |
| <i>Implied addressing</i>         |                                          |
| Implied register                  | $EA = SR, USP, SP, \text{ or } PC$       |

Notes:

1. EA Effective address  
An Address register  
Dn Data register  
Xn Address or data register used as index register  
SR Status register  
PC Program counter  
 $(d_8)$  8-bit offset (displacement)  
 $(d_{16})$  16-bit offset (displacement)  
 $( )$  Contents of  
← Replaces
2.  $N = 1$  for byte,  $2$  for words, and  $4$  for longwords. If An is the stack pointer and the operand size is byte,  $N = 2$  to keep the stack pointer on a word boundary.
3. The designation Ri is also used to indicate a register used for indexing. Motorola literature also uses Xi or ix for an index register as in Appendix IV.

# Direct Addressing – Register

- No calculation needed of an effective address
- Operand is in one of the address (Ax) or data (Dx) registers
  - Address register direct and data register direct mode
- Examples:
  - CLR.W D2
  - MOVE.W D1,D2
  - MOVE.L A1,D1
  - MOVEA.L A1,A2

# Direct Addressing – Absolute

- Absolute Short/Word Addressing Mode
- 16-bit address for an operand in memory
- Used to represent address ranges in the operand of the following:
  - from \$00 0000 to \$00 7FFF
  - from \$FF 8000 to \$FF FFFF
- Examples:
  - MOVE.W D1,\$1000
  - MOVE.W D1,\$9000
  - MOVE.L \$2000,D1



Figure 5.11 Effect of absolute short addressing.

# Direct Addressing – Absolute

- Absolute **Long** Addressing Mode
- More than 16-bit address for an operand in memory
- Used to represent address ranges in the operand of the following:
  - from \$00 8000 to \$FF FFFF
- Examples:
  - MOVE.W \$12000,D1
  - MOVE.B \$3FFF,\$12000



Figure 5.11 Effect of absolute short addressing.

# Indirect Addressing

- Use of the contents of an address register as the address of an operand in memory

- MOVE.W (A1), D1

- MOVE.W D1, -(A1)

- MOVE.W (A1)+, D2

# Indirect Addressing



Figure 5.13 Examples of indirect addressing.

## Relative Addressing

- An address that the CPU calculates by adding a displacement to the value in the program counter.

$$EA = (PC) + <\text{displacement}>$$

- BRA \*+10

# Immediate Addressing

- Used to specify a constant 8, 16 or 32 bits long

- ADD.W      #5, D1

- MOVE.L      #1234,D1

- MOVE.L      #'1234',D1

- MOVE.W      #\$F0,D1

- MOVE.W      \$F0,D1

- MOVE.B      1000,#10000

→ Can't be done because destination is an immediate operand

## Immediate Addressing

- BSR <address or label>
- RTS or RTE (no address needed!)
  - Where is it stored then?

# Machine Language for MC68K

- The instructions that the processor executes are coded in machine language format in memory (BINARY!)
  - A programmer can directly code these binary on the memory by modifying the content of the memory
- Assembly program is translated by the assembler from symbolic notation to machine language instructions.
  - Rarely works directly with the machine language program, but knowing its format is necessary to gain full understanding of a processor
- MC68K machine language instructions consist of from 1 to 5 of 16-bit words in memory

# Machine Language for MC68K

- MC68K machine language instructions consist of from 1 to 5 of 16-bit words in memory



- Other than Operation Word (opword), additional extension words may contain
  - Immediate data
  - Absolute addresses for source/destination operands
    - Short Absolute address = 16 bits → 1 word (Abs.W)
    - Long Absolute address = 32 bits → 2 words (Abs.L)

# Single-Address Instructions

- CLR.B

D1

- Refer to Appendix IV of textbook or Page 5 of this slide



(a) General Format



Instruction Fields:

Size field – Specifies the size of the operation:

00 – byte operation

01 – word operation

10 – long operation

- Other instructions such as..

- NEG (negate)

- NOT (1's complement)

- NBCD (negate BCD)

(b) CLR Instruction



(c) CLR Instruction Example

- No need to memorize! Just look at the Instruction Set Details document!

# Double-Address Instructions

- An instruction that uses two operands, addressing modes for both (source & destination) must be specified on op-word
- MOVE.W D1, D3
  - See Appendix IV MOVE

MOVE Byte

|    |    |    |    |             |          |      |   |        |      |          |   |   |   |   |   |
|----|----|----|----|-------------|----------|------|---|--------|------|----------|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11          | 10       | 9    | 8 | 7      | 6    | 5        | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 1  |             |          |      |   |        |      |          |   |   |   |   |   |
|    |    |    |    | Destination | Register | Mode |   | Source | Mode | Register |   |   |   |   |   |

Note Register and Mode location

MOVE Long

|    |    |    |    |             |          |      |   |        |      |          |   |   |   |   |   |
|----|----|----|----|-------------|----------|------|---|--------|------|----------|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11          | 10       | 9    | 8 | 7      | 6    | 5        | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  |             |          |      |   |        |      |          |   |   |   |   |   |
|    |    |    |    | Destination | Register | Mode |   | Source | Mode | Register |   |   |   |   |   |

Note Register and Mode location

MOVE Word

|    |    |    |    |             |          |      |   |        |      |          |   |   |   |   |   |
|----|----|----|----|-------------|----------|------|---|--------|------|----------|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11          | 10       | 9    | 8 | 7      | 6    | 5        | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 1  |             |          |      |   |        |      |          |   |   |   |   |   |
|    |    |    |    | Destination | Register | Mode |   | Source | Mode | Register |   |   |   |   |   |

Note Register and Mode location

(a) Instruction Format



(b) MOVE.W D1,D3

# Double-Address Instructions

## • ADD.X <EA>,Dn or Dn,<EA>

- X can be B or W or L

### ADD

(MC68000 family)

Source + Destination → Destination

Assembler  
Syntax:

ADD Dn, <ea>

Attributes:  
Size = (Byte, Word, Long)

Description: Adds the source operand to the destination operand using binary addition and stores the result in the destination location. The size of the operation may be specified as byte, word, or long. The mode of the instruction indicates which operand is the source and which is the destination, as well as the operand size.

Condition Codes:



X — Set the same as the carry bit.  
N — Set if the result is negative; cleared otherwise.  
Z — Set if the result is zero; cleared otherwise.  
V — Set if an overflow is generated; cleared otherwise.  
C — Set if a carry is generated; cleared otherwise.

Instruction Format:

| 15 | 14 | 13 | 12 | 11       | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1        | 0    |
|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|----------|------|
| 1  | 1  | 0  | 1  | REGISTER |    |   |   |   |   |   |   |   |   | REGISTER | MODE |

Instruction Fields:

Register field—Specifies any of the eight data registers.

Opmode field

| Byte | Word | Long | Operation | Dn  | <ea> | → + | Dn | → Dn | Dn + <ea> | → <ea> |
|------|------|------|-----------|-----|------|-----|----|------|-----------|--------|
| 000  | 010  | 110  |           | 001 |      |     |    |      |           |        |
| 100  | 101  | 110  |           | 101 |      |     |    |      |           |        |

a. If the location specified is a source operand, all addressing modes can be used as listed in the following tables:

| Addressing Mode          | Mode | Register       |
|--------------------------|------|----------------|
| Dn                       | 000  | reg. number An |
| An*                      | 001  | reg. number An |
| (An)                     | 010  | reg. number An |
| (An) *                   | 011  | reg. number An |
| -(An)                    | 100  | reg. number An |
| (d <sub>16</sub> ,An)    | 101  | reg. number An |
| (d <sub>16</sub> ,An,Xn) | 110  | reg. number An |

| MC68020, MC68030, and MC68040 only |
|------------------------------------|
| (ld,PC,Xn)*                        |
| (ld,An,Xn 0x0)                     |
| (ld,An,Xn 0x0)                     |

NOTE

The Dmode is used when the destination is a data register; the Dmode is invalid for a data register.  
ADD is used when the destination is an address register. ADDI and ADDQ are used when the source is immediate data. Most assemblers automatically make this distinction.

b. If the location specified is a destination operand, only memory alterable addressing modes can be used as listed in the following tables:

| Addressing Mode          | Mode | Register       |
|--------------------------|------|----------------|
| Dn                       | —    | —              |
| An                       | —    | —              |
| (An)                     | 010  | reg. number An |
| (An) *                   | 011  | reg. number An |
| -(An)                    | 100  | reg. number An |
| (d <sub>16</sub> ,An)    | 101  | reg. number An |
| (d <sub>16</sub> ,An,Xn) | 110  | reg. number An |

| MC68020, MC68030, and MC68040 only |
|------------------------------------|
| (ld,An,Xn)*                        |
| (ld,An,Xn 0x0)                     |

\*Can be used with CPU32

# Assembly Language Examples

- MOVE.B      \$3FFF,\$12000
- MOVE.W      \$12000,D1
- ADD.L        #\$1000,D1
- ADD.B        \$1000,D1

# Memory Organization of MC68K

- Data signal lines = 16 bits
- Address signal lines = 24 bits
  - Each address indicates a **byte location in memory or address of a location associated with an interface**
- Can be accessed in byte, word or longword
- Addressing space after  $3FF_{16}$  can be utilized for system designers
  - “Vectors” include addresses that point to routines for servicing interrupts or processing traps
    - “*Vector Tables*”



# Memory Organization of MC68K

- Although each byte in the word can be addressed by the processor, **instructions and word operands must be referenced only at even addresses**

- n, n+2, n+4, ... where n is an even address
  - applies to .W and .L operations
  - .B operations can manage odd address



- Example: MOVE.W \$1001, D1

- Causes error, “addressing error”

# Data Organization

- Within a byte, bit 0 is the rightmost, bit 7 is the leftmost bit
  - Bit 0 represents LSB for a byte or a word value (integer data)
  - High-order 16bits in location  $n$ , low-order 16bits in location  $n+2$  for longword value ( $n$  is even integer)



# Data Organization of MC68K

- MC68K is a Big-Endian system
  - Most-significant byte at least address of a word
    - c.f. Little-Endian: least-significant byte at least address

| Memory Address | Big Endian (Motorola) | Little Endian (Intel) |
|----------------|-----------------------|-----------------------|
| \$1000         | 00                    | F6                    |
| \$1001         | 02                    | 00                    |
| \$1002         | 00                    | 02                    |
| \$1003         | F6                    | 00                    |

• Storing  $0002\ 00F6_{16}$  at memory location \$1000