### **Addressing Modes**

# student workbook introduction to the pdp11

digital equipment corporation · maynard. massachusetts

1st Printing, March 1974 2nd Printing (Rev), November 1974 3rd Printing (Rev), April 1977

#### Copyright © 1974, 1977 by Digital Equipment Corporation

The reproduction of this workbook, in part or whole, is strictly prohibited. For copy information contact the Educational Services Department, Digital Equipment Corporation, Maynard, Massachusetts 01754.

Printed in U.S.A.





After completing this study unit, you should be able to ....

- ★ Explain how each of the eight basic addressing modes are used to locate operands stored in a PDP-11 system.
- ★ Point out the similarities and differences between the eight basic addressing modes and cite examples where each mode would be used.
- ★ Describe the difference between direct and deferred addressing.
- $\star$  Explain and use the four special addressing modes involving the program counter (PC).
- ★ Recognize and use the assembler syntax and octal code for all the addressing modes.
- ★ Define terms such as "base," "index," "pointer," "effective address," "offset," and "position-independent code" as they relate to the addressing modes.
- ★ Explain the difference between relative addressing and absolute addressing.



• PDP-11/04/05/10/35/40/45 Processor Handbook Read Chapter 3, Addressing Modes. (Paragraph 3.7 contains an excellent summary of the different addressing modes.)

Also, read Chapter 5, Paragraph 5.5 (Position-Independent Code).

# ----review material film cartridges A & B

The following material is covered in this study unit:

| Topic                            | Key Points                                                                                                                                                                                                                                   | Visual Ref. |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| GPRs                             | ★ All addressing within the PDP-11 system is accomplished by way of the general-purpose registers.                                                                                                                                           | 3-7         |
|                                  | • Register 7 also functions as the program counter. It's automatically incremented by two each time the CPU fetches another instruction word in the program.                                                                                 |             |
|                                  | • To fetch the next instruction from memory, the CPU takes the instruction's address stored in the PC and places it on the Unibus.                                                                                                           |             |
| basic<br>instruction<br>format   | ★ After the instruction is retrieved, it is decoded by the CPU.                                                                                                                                                                              | 8-10        |
|                                  | • Part of the decoded instruction tells the CPU what operation to perform. This is called the "op code" or operation code.                                                                                                                   |             |
|                                  | • The remainder of the instruction tells the CPU how to locate the value (or operand) that it is to operate upon. This part of the instruction further breaks down into an <i>addressing mode</i> and a <i>register</i> field.               |             |
| register<br>field                | ★ Three bits are required to select any one of the eight GPRs. They specify which GPR is to be used with the current instruction.                                                                                                            | 11          |
| addressing<br>modes              | ★ Three more bits specify <i>how</i> the selected GPR is to<br>be used in order to locate the operand. This is<br>called the "addressing mode." There are 8 different<br>ways of using the GPRs and, therefore, 8 basic<br>addressing modes. | 12          |
| addressing<br>modes:<br>examples | ★ Here are 3 examples showing how the GPRs can be used.                                                                                                                                                                                      | 13–15       |
|                                  | re                                                                                                                                                                                                                                           | ead on 🖡    |

-3-

# ------review material-----

| Topic             | Key Points                                                                                                                                            | Visual Ref. |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|                   | • We can store operands right in the GPRs.                                                                                                            |             |
|                   | • We can store an address in a GPR which directs the CPU to an operand located in memory.                                                             |             |
|                   | • We can store a pointer in a GPR. This pointer directs the CPU to a memory location containing the address of an operand stored in an I/O register.  |             |
| 8 basic<br>modes  | ★ By combining 8 basic addressing modes with any<br>of our general-purpose registers, we can locate<br>operands stored anywhere in the PDP-11 system. | 16-17       |
|                   | • Now let's examine each of the 8 basic modes and see how they are used to locate operands.                                                           |             |
| mode 0            | ★ Register mode: <i>operand</i> is stored in a GPR.                                                                                                   | 18-22       |
|                   | • Provides quickest access to data; there's no need to tie-up the bus to retrieve the operand.                                                        |             |
|                   | • Instruction operates directly on the contents of the GPR.                                                                                           |             |
|                   | • General-purpose registers are labelled R0 through R7 (R6=SP, R7=PC).                                                                                |             |
| mode 0:<br>symbol | ★ Assembler notation for mode 0: INC R3. This instruction tells the CPU to increment the value contained in register 3.                               | 20, 21      |
| mode 1            | ★ Register deferred mode: <i>address</i> of the operand is stored in a GPR.                                                                           | 23–28       |
|                   | • Address contained in the GPR directs the CPU to the operand. Operand is located outside the CPU – either in memory or an I/O register.              |             |
|                   | • Retrieval of the operand involves a DATI or DATIP bus cycle.                                                                                        |             |
|                   | r                                                                                                                                                     | ead on 🖡    |

# -----review material-----

| Topic             | Key Points                                                                                                                                                                                                            | Visual Ref. |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| mode 1:<br>symbol | ★ Assembler notation for mode 1: DEC (R0) or<br>DEC @ R0. Either symbol tells the CPU that<br>register 0 contains the address of the operand that<br>is to be decremented.                                            | 27          |
| mode 2            | ★ Autoincrement mode: GPR contains the <i>address</i><br>of the operand; address is <i>automatically</i><br><i>incremented</i> after the operand is retrieved. Address<br>now references the next sequential operand. | 29-39       |
|                   | • Allows a programmer to automatically step<br>through a list or series of operands stored in<br><i>consecutive</i> locations.                                                                                        |             |
|                   | • When an instruction calls for mode 2, the address stored in the GPR is autoincremented each time the instruction is executed.                                                                                       |             |
|                   | • Address is autoincremented by 1 if we are working with bytes, or by 2 if we are working with words.                                                                                                                 |             |
| mode 2:<br>symbol | ★ Assembler notation: CLRB (R4)+. Register 4 contains the address of a byte which is to be cleared; then the address is incremented by 1 so it points to the next byte in the list.                                   | 39          |
| mode 4            | ★ Autodecrement mode: GPR contains an address<br>that is automatically decremented; then the<br>decremented address is used to locate an operand.                                                                     | 42-45       |
|                   | • Similar to autoincrement, but allows a programmer to step through a list of words or bytes in the reverse order.                                                                                                    |             |
|                   | • Address is autodecremented by 1 for bytes and by 2 for words.                                                                                                                                                       |             |
| mode 4:<br>symbol | ★ Assembler notation: CLR-(R4). First, decrement<br>the address stored in register 4. Then clear the<br>word location specified by the decremented<br>address.                                                        | 48          |
|                   | r                                                                                                                                                                                                                     | ead on      |
|                   | · · · · · ·                                                                                                                                                                                                           | ead on 🖡    |

\_\_\_\_\_5 \_\_

### -----review material-----

| Topic                        | Key Points                                                                                                                                                                                                    | Visual Ref. |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| autoincr.<br>vs<br>autodecr. | ★ Both addressing modes automatically modify an address stored in a GPR. Each time the address is incremented or decremented, it advances us to the next operand in the list.                                 | 46–48       |
|                              | • Autoincrement <i>first</i> uses the address to locate an operand, <i>then</i> it <i>increments</i> the address.                                                                                             |             |
|                              | • Autodecrement <i>first</i> decrements the address, <i>then</i> it uses the new address to locate an operand.                                                                                                |             |
| mode 3                       | <ul> <li>★ Autoincrement deferred mode: GPR contains a pointer to an address that is stored outside the CPU. When the address is retrieved, the GPR's pointer is automatically incremented by two.</li> </ul> | 52-61       |
| mode 3:<br>example           | ★ One way of accessing operands stored in I/O<br>registers is to place a table of I/O addresses in<br>memory. Each entry in the table addresses a<br>different set of I/O registers.                          | 52–58       |
|                              | • To get to this table of I/O addresses, the table's starting address is placed in a GPR. Thus, the GPR "points" to the table.                                                                                |             |
|                              | • To step through this table of I/O addresses,<br>mode 3 is used to automatically increment the<br>pointer stored in the GPR.                                                                                 |             |
|                              | • Thus, mode 3 provides for automatic stepping through a table of addresses as a means of accessing operands.                                                                                                 |             |
| mode 3:<br>symbol            | ★ Assembler notation: CLR @ (R3)+.                                                                                                                                                                            | 60          |
|                              | • The "@" denotes this is a deferred addressing mode; i.e. R3 contains a pointer to an address.                                                                                                               |             |
|                              | • The "+" indicates the pointer in R3 is incremented by two after the address is located.                                                                                                                     | -           |
|                              | r                                                                                                                                                                                                             | ead on 🖡    |

# ------review material------

| Topic                  | Key Points                                                                                                                                                                                                                                                                                                                                                                                                             | Visual Ref. |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| mode 3<br>vs<br>mode 2 | <ul> <li>★ Mode 2 (autoincrement) is only used to access operands that are stored in <i>consecutive</i> locations. Mode 3 (autoincrement deferred) is used to access lists of operands stored anywhere in the system; i.e., the operands do not have to reside in adjoining locations. Mode 2 is used to step through a table of <i>values</i>; mode 3 is used to step through a table of <i>addresses</i>.</li> </ul> | 62–65       |
| mode 5                 | <ul> <li>Autodecrement deferred mode: GPR contains a pointer. The pointer is <i>first</i> decremented by two, <i>then</i> the new pointer is used to retrieve an address stored outside the CPU.</li> <li>Similar to autoingroment deformed, but allows a</li> </ul>                                                                                                                                                   | 67–72       |
|                        | • Similar to autoincrement deferred, but allows a programmer to step through a table of addresses in the reverse order.                                                                                                                                                                                                                                                                                                |             |
|                        | • Each address then redirects the CPU to an operand. Note that the operands do not have to reside in consecutive locations.                                                                                                                                                                                                                                                                                            |             |
| mode 5:                | ★ Assembler notation: CLR @ – (R0).                                                                                                                                                                                                                                                                                                                                                                                    | 73          |
| symbol                 | • The "@" denotes this is a deferred addressing mode; i.e. R0 contains a pointer.                                                                                                                                                                                                                                                                                                                                      |             |
|                        | • The "-" signifies an autodecrement function. It<br>is placed in front of (R0) because the pointer is<br>decremented by two before it is used for<br>retrieving an address.                                                                                                                                                                                                                                           |             |
| mode 6                 | ★ Index mode: a <i>base</i> address is summed with an <i>index</i> word to produce the effective address of an operand. The <i>base</i> address specifies the starting location of a table or list. The <i>index</i> word then represents the address of an entry in the table or list <i>relative</i> to the starting (base) address.                                                                                 | 77–101      |
|                        | • The base address may be stored in a GPR. In this case, the <i>index</i> word follows the current instruction. Or, the locations of the base address and <i>index</i> word may be reversed ( <i>index</i> word in GPR; base address following the current instruction).                                                                                                                                               |             |
|                        | re                                                                                                                                                                                                                                                                                                                                                                                                                     | ad on 🛊     |

7

#### ------review material--

| Topic                  | Key Points                                                                                                                                                                                                                                                                                                                                                         | Visual Ref. |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| mode 6:<br>example # 1 | ★ Suppose we have a table of operands.                                                                                                                                                                                                                                                                                                                             | 78–91       |
|                        | • To get to the table, we use the table's starting address. This starting address is <i>fixed</i> and can serve as our base address.                                                                                                                                                                                                                               |             |
|                        | • To get to <i>any</i> entry in the table, we use a displacement from the starting (base) address. This <i>variable</i> displacement serves as our <i>index</i> word. It defines the location of any entry relative to the base address.                                                                                                                           |             |
|                        | • To retrieve any entry from the table, we use<br>mode 6 to <i>sum</i> the <i>base</i> with the appropriate<br><i>index</i> word. The <i>base</i> can be stored in a GPR<br>and the <i>index</i> word in the first memory location<br>following the current instruction (or the<br>locations of the <i>base</i> and <i>index</i> word can be<br><i>reversed</i> ). |             |
| mode 6:<br>example # 2 | ★ Suppose we are working with several tables and wish to update the second entry in each table.                                                                                                                                                                                                                                                                    | 92-101      |
|                        | • We use a starting address to define the location<br>of each table. Since the starting address is<br>different for each table, it now becomes the<br><i>variable</i> component. This starting address serves<br>as our <i>index</i> word.                                                                                                                         |             |
|                        | • We are interested in the second entry in all tables. The displacement of this entry is <i>fixed</i> – it's always plus two. Because the displacement is fixed, it serves as our <i>base</i> .                                                                                                                                                                    |             |
|                        | • To locate the second entry in any table, we again use mode 6 to sum the <i>base</i> of plus two with the appropriate starting address or <i>index</i> word. The base can be stored in a GPR. The index word then follows the current instruction. Or, we could reverse the locations of these two address components.                                            |             |
|                        |                                                                                                                                                                                                                                                                                                                                                                    | read on 🖡   |

-8-

# -----review material------

| Topic             | Key Points                                                                                                                                         | Visual Ref. |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| mode 6:           | * Assembler notation: $CLR \pm X (R2)$ .                                                                                                           | 85          |
| symbol            | • "X" represents the index word (or base address) that is stored in the <i>first</i> location following the clear instruction.                     |             |
|                   | • Register 2 contains a base address (or index word) that is summed with "X" to produce the effective address of the operand.                      |             |
| mode 7            | ★ Index deferred mode: a base address is summed with an index word. The result is a <i>pointer</i> to an address - rather than the actual address. | 103-106     |
|                   | • Similar to mode 6, except that it produces a pointer to an address. The address, in turn, redirects the CPU to the desired operand.              |             |
|                   | • Provides for the random access of operands using a table of operand addresses.                                                                   |             |
| mode 7:<br>symbol | ★ Assembler notation: INC $@ \pm X(R1)$ .                                                                                                          | 106         |
| Symbol            | • The "@" indicates this is a deferred addressing mode.                                                                                            |             |
|                   | • "X" represents the index word (or base) that is stored in the first location following the increment instruction.                                |             |
|                   | • Register 1 contains a value that is summed with "X." Since this is a deferred mode, the result is a pointer instead of the actual address.       |             |
|                   | NOTE 1<br>Visuals 108–116, and the                                                                                                                 |             |
|                   | accompanying narration, summarize<br>the eight basic addressing modes.                                                                             |             |
|                   | NOTE 2                                                                                                                                             |             |
|                   | A review of the special PC addressing                                                                                                              |             |
|                   | modes covered in film cartridge C begins on the next page.                                                                                         |             |
|                   |                                                                                                                                                    |             |

9.

# -review materialfilm cartridge C

| Topic                        | Key Points                                                                                                                                                                                                                          | Visual Ref. |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| special<br>PC modes          | ★ There are 4 special addressing modes involving just<br>the program counter.                                                                                                                                                       | 119-122     |
|                              | • The PC is unique from the other GPR's in one important respect. Whenever the processor retrieves an instruction, it automatically advances the PC by 2.                                                                           |             |
|                              | • By combining this automatic advancement of<br>the PC with four of the <i>basic</i> addressing modes,<br>we produce the 4 special PC<br>modes – immediate, absolute, relative, and<br>relative deferred.                           |             |
| immediate<br>mode            | ★ This special mode is equivalent to the autoincrement (mode 2) using the PC. In this case, the operand immediately follows the instruction.                                                                                        | 123-128     |
|                              | • The PC is incremented twice when used with addressing mode two.                                                                                                                                                                   |             |
|                              | • First, it's automatically updated by 2 when the instruction is retrieved. The new value in the PC (PC+2) is the address of the operand; i.e. the operand follows the instruction.                                                 |             |
|                              | • Then, the PC is <i>autoincremented</i> by 2. The new value, PC+4, addresses the next instruction in the program.                                                                                                                  |             |
| immediate<br>mode:<br>symbol | ★ Assembler notation: INC #100.                                                                                                                                                                                                     | 128         |
|                              | • This instruction tells the CPU to increment the value 100.                                                                                                                                                                        |             |
|                              | • The "#" designates the immediate addressing<br>mode. Therefore, the value to be incremented<br>(100) immediately follows the instruction word.<br>The value 100 is actually part (a second word)<br>of the increment instruction. |             |
|                              |                                                                                                                                                                                                                                     | read on 🕨   |

# -review material-

| Topic                       | Key Points                                                                                                                                                                                                           | Visual Ref. |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| absolute<br>mode            | ★ This special mode is equivalent to the autoincrement deferred mode using the PC. In this case, the <i>address</i> of the operand immediately follows the instruction.                                              | 130–140     |
|                             | • The PC is incremented twice during the absolute mode.                                                                                                                                                              |             |
|                             | • First, it's automatically updated by 2 when the instruction is retrieved. The new value, PC+2, points to a memory location containing the <i>address</i> of the operand; i.e. the address follows the instruction. |             |
|                             | • Then, the PC is <i>autoincremented</i> by 2. The new value, PC+4, addresses the next instruction in the program.                                                                                                   |             |
| absolute<br>mode:<br>symbol | ★ Assembler notation: INC @ $\#1000$ .                                                                                                                                                                               | 137, 138    |
|                             | • This instruction tells the CPU to increment the operand stored in memory location 1000.                                                                                                                            |             |
|                             | • The "@" denotes this is a deferred mode.<br>Therefore, the PC points to the address 1000.<br>This address is actually the second word of this<br>2-word instruction.                                               |             |
| "absolute"<br>address       | ★ When the absolute addressing mode is used, the location of the operand remains fixed no matter where the instruction is located in memory.                                                                         | 139, 140    |
|                             | • The operand's address is constant (absolute);<br>therefore, this is called the <i>absolute</i> addressing<br>mode.                                                                                                 |             |
|                             |                                                                                                                                                                                                                      |             |
|                             | 11                                                                                                                                                                                                                   | read on 🖡   |

# ------review material-----

| Topic                        | Key Points                                                                                                                                                                                                                          | Visual Ref. |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| relative<br>mode             | ★ This special mode is the same as index mode 6<br>except that it uses the PC. The operand's address is<br>calculated by adding the word that follows the<br>instruction (called an "offset") to the updated<br>contents of the PC. | 141-151     |
|                              | • PC+2 directs the CPU to the offset that follows the instruction.                                                                                                                                                                  |             |
|                              | • PC+4 is summed with this offset to produce the effective address of the operand. PC+4 also represents the address of the next instruction in the program.                                                                         |             |
| "relative"<br>address        | ★ With the relative addressing mode, the address of<br>the operand is always determined with respect to<br>the updated PC. Therefore, when the instruction is<br>relocated, the operand is moved by the same<br>amount.             | 150         |
| offset                       | ★ The distance between the updated PC and the operand is called an "offset." When a program is assembled, this offset appears in the first word location that follows the instruction.                                              | 150         |
| relative<br>mode:            | ★ Assembler notation: INC A.                                                                                                                                                                                                        | 151         |
| symbol                       | • "A" is a label that identifies the location of the operand to be incremented.                                                                                                                                                     |             |
| relative<br>deferred<br>mode | ★ This special mode is the same as index deferred<br>(mode 7) except that it uses the PC. A <i>pointer</i> to<br>an operand's address is calculated by adding an<br>offset (that follows the instruction) to the updated<br>PC.     | 153–158     |
|                              | • This mode is similar to the relative mode, except that it involves one additional level of addressing to obtain the operand.                                                                                                      |             |
|                              | • The sum of the offset and updated PC (PC+4) serves as a pointer to an address. When the address is retrieved, it can be used to locate the operand.                                                                               |             |
|                              |                                                                                                                                                                                                                                     | read on 🖡   |

#### review material-

Topic

Key Points

Visual Ref.

relative deferred: symbol ★ Assembler notation: INC @ A.

• The "@" denotes a deferred addressing mode.

• "A" is a label that identifies the location that contains the *address* of the operand.

NOTE

V is uals 159-167, and the accompanying narration, summarize the four special PC addressing modes.

# RELATIVE vs ABSOLUTE ADDRESSING & POSITION INDEPENDENT CODE

The description that follows should be read carefully. (This information is not included in the sound-filmstrip cartridges.)

position independent code (PIC)

- ★ On the PDP-11, it is possible to write program code which, although originally designed to run in one set of memory locations, will work equally well if the code is relocated in another area of memory. Such code is called "position-independent code" or PIC.
  - Programs written in PIC do not directly reference any absolute locations within the moving code. Instead, all such references are given relative to the PC; that is, the locations are specified in terms of offsets from the current value of the PC.
  - Thus, if an instruction and the location it is addressing are moved (relocated), and the *relative* distance between them is not changed, the *same offset* (relative to the PC) can be used.

•13 ·

read on

#### -review material-

problem: accessing locations

location

not in moving

code

location

within

moving

code

★ One problem in writing PIC is how to correctly access various locations. Two situations occur:

- 2. The location to be accessed is *within* the moving code.
- ★ If the location we wish to access is *not* in the moving code, we use *absolute* addressing.

Example: INC @#TKS, where TKS = 177 560 (the absolute address of the Teletype<sup>®</sup> keyboard status register).

★ In the example below, the location labelled "SAVE" that we wish to address is *within* the moving code and moves with it. Therefore, the *relative* mode is used (mode 6 indexed on the PC).

PC INC SAVE

PC+2 (offset to SAVE)

PC+4 BR AWAY

PC+6 SAVE: 0

Wherever these instructions are loaded, the offset (2) is added to the updated PC (PC+4). The result (PC+6) is the effective address of location SAVE. Thus, the INCREMENT instruction always adds one to the contents of SAVE.

<sup>1.</sup> The location to be accessed is *not* part of the moving code, or

#### exercise a-

### basic addressing modes

Complete the following chart. This is an instruction list, not a program. Assume the initial conditions apply for each instruction.

#### NOTE TO STUDENT

If you find it difficult to complete this exercise, review the material on pages 3–9 of this workbook and work through the examples contained in Chapter 3 of the PDP-11 Processor Handbook. Then return to this workbook exercise.

|             |        |   |      |        |   |     |       |   | `` | NOTE                     |
|-------------|--------|---|------|--------|---|-----|-------|---|----|--------------------------|
| INITIAL     | (R0)   | = | 1000 | (1000) | = | 100 | (100) | = | 10 | The contents of a reg-   |
| CONDITIONS: | (R2)   | = | 3000 | (3000) | = | 300 | (300) | = | 30 | ister or memory loca-    |
|             | (R5)   | = | 4000 | (4000) | = | 400 | (400) | = | 40 | tion are symbolized by   |
|             | (R7)   | = | 7000 | (6504) | = | 654 | (654) | = | 64 | enclosing the address in |
|             | (2776) | = | 276  | (276)  | = | 26  | (26)  | = | 6  | parentheses. For         |
|             | (3500) | = | 350  | (350)  | = | 30  | (30)  | = | 0  | example, (100)=10        |
|             | (4100) | = | 410  | (410)  | = | 40  | (40)  | = | 0  | means location 100       |
|             | (2777) | = | 177  |        |   |     |       |   | )  | contains 10.             |
|             | . ,    |   |      |        |   |     |       |   |    |                          |

|                  |                       |                        |                                         | OPERAND             |                    |           |
|------------------|-----------------------|------------------------|-----------------------------------------|---------------------|--------------------|-----------|
| INSTRUCTION      | MODE<br>OCTAL<br>CODE | EFFECTIVE<br>ADDRESS * | CONTENT OF<br>SELECTED GPR<br>AFTER USE | BEFORE<br>EXECUTION | AFTER<br>EXECUTION | NEW<br>PC |
| INC @ R5         | 1                     | 4000                   | 4000                                    | 400                 | 401                | 7002      |
| DEC (R2) +       |                       |                        |                                         |                     |                    |           |
| CLR @ -(R2)      |                       |                        |                                         |                     |                    |           |
| CLR R5           |                       |                        |                                         |                     |                    |           |
| INC 100 (R5)     |                       |                        |                                         |                     |                    |           |
| DECB @ (R2) +    |                       |                        |                                         |                     |                    |           |
| CLRB (R5)        |                       |                        |                                         |                     |                    |           |
| CLRB - (R2)      |                       |                        |                                         |                     |                    |           |
| INC @ 1000 (R2)  |                       |                        |                                         |                     |                    |           |
| CLRB (R0) +      |                       |                        |                                         |                     |                    |           |
| INC - 300 (R5)   |                       |                        |                                         |                     |                    |           |
| INC @ - 300 (R5) |                       |                        |                                         |                     |                    |           |

\*Effective Address is the final address after all address decoding has been completed.

read on 🌢

NOTE

### -exercise a-answer sheet-

# basic addressing modes

| ) =   | 1000                                | (1000)                                                    | =                                                                                                                                                                                                        | 100                                                                       | (100)                                                                      | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10                                                   |
|-------|-------------------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|
| ) =   | 3000                                | (3000)                                                    | =                                                                                                                                                                                                        | 300                                                                       | (300)                                                                      | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 30                                                   |
| ) =   | 4000                                | (4000)                                                    | =                                                                                                                                                                                                        | 400                                                                       | (400)                                                                      | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 40                                                   |
| ) =   | 7000                                | (6504)                                                    | =                                                                                                                                                                                                        | 654                                                                       | (654)                                                                      | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 64                                                   |
| 76) = | 276                                 | (276)                                                     | =                                                                                                                                                                                                        | 26                                                                        | (26)                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 6                                                    |
| )) =  | 350                                 | ( 350)                                                    | =                                                                                                                                                                                                        | 30                                                                        | ( 30)                                                                      | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0                                                    |
| )) =  | 410                                 | ( 410)                                                    | =                                                                                                                                                                                                        | 40                                                                        | (40)                                                                       | =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0                                                    |
| 77) = | 177                                 |                                                           |                                                                                                                                                                                                          |                                                                           |                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                      |
|       | ) =<br>) =<br>) =<br>76) =<br>00) = | $\begin{array}{l} = 3000 \\ = 4000 \\ = 7000 \end{array}$ | $\begin{array}{l} \begin{array}{l} & = & 3000 & (3000) \\ & = & 4000 & (4000) \\ & = & 7000 & (6504) \\ & 76) & = & 276 & (& 276) \\ & 00) & = & 350 & (& 350) \\ & 00) & = & 410 & (& 410) \end{array}$ | $\begin{array}{l} \begin{array}{l} \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \$ | $\begin{array}{l} \begin{array}{l} \  \  \  \  \  \  \  \  \  \  \  \  \ $ | $\begin{array}{l} \begin{array}{l} &= 3000 \\ (3000) &= 300 \\ (4000) &= 400 \\ (4000) &= 400 \\ (400) \\ \end{array} \\ \begin{array}{l} &= 4000 \\ (400) \\ (400) \\ (400) \\ \end{array} \\ \begin{array}{l} &= 2700 \\ (6504) &= 654 \\ (654) \\ (654) \\ (654) \\ (654) \\ \end{array} \\ \begin{array}{l} &= 276 \\ (276) &= 26 \\ (26) \\ (20) \\ \end{array} \\ \begin{array}{l} &= 350 \\ (350) \\ \end{array} \\ \begin{array}{l} &= 300 \\ (30) \\ (30) \\ (30) \\ \end{array} \\ \begin{array}{l} &= 410 \\ (0) \\ \end{array} \\ \begin{array}{l} &= 410 \\ (410) \\ \end{array} \\ \begin{array}{l} &= 40 \\ (40) \\ \end{array} \end{array}$ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ |

| INSTRUCTION      | MODE<br>OCTAL | EFFECTIVE<br>ADDRESS | CONTENT OF<br>SELECTED GPR | OPE<br>BEFORE<br>EXECUTION | RAND<br>AFTER<br>EXECUTION | NEW<br>PC |
|------------------|---------------|----------------------|----------------------------|----------------------------|----------------------------|-----------|
|                  | CODE          |                      | AFTER USE                  |                            |                            |           |
| INC @ R5         | 1             | 4000                 | 4000                       | 400                        | 401                        | 7002      |
| DEC (R2) +       | 2             | 3000                 | 3002                       | 300                        | 277                        | 7002      |
| CLR @ - (R2)     | 5             | 276                  | 2776                       | 26                         | 00                         | 7002      |
| CLR R5           | 0             | R5                   | 0000                       | 4000                       | 0000                       | 7002      |
| INC 100 (R5)     | 6             | 4100                 | 4000                       | 410                        | 411                        | 7004      |
| DECB @ (R2) +    | 3             | 300                  | 3002                       | 30                         | 27                         | 7002      |
| CLRB (R5)        | ĺ             | 4000                 | 4000                       | 400                        | 400                        | 7002      |
| CLRB ~ (R2)      | 4             | 2777                 | 2777                       | 177                        | 000                        | 7002      |
| INC @ 1000 (R2)  | 7             | 400                  | 3000                       | 40                         | 41                         | 7004      |
| CLRB (R0) +      | 2             | 1000                 | 1001                       | 100                        | 000                        | 7002      |
| INC - 300 (R5)   | 6             | 3500                 | 4000                       | 350                        | 351                        | 7004      |
| INC @ - 300 (R5) | 7             | 350                  | 4000                       | 30                         | 31                         | 7004      |



RETURN TO A/V FILM CARTRIDGE C

# special pc addressing modes

Complete the following chart. Assume the initial conditions apply for each instruction.

 INITIAL
 (R7) = 5000 

 CONDITIONS:
 (1000) = 100, and (100) = 10, and (10) = 1 

 (SUM) = 2700; assume SUM is offset +600<sub>8</sub> relative to PC.

 (LIMIT) = 4000; assume LIMIT is offset - 500<sub>8</sub> relative to PC.

 (7500) = 1000 

|                   |                       |                               |                      | OPE                 | RAND               |
|-------------------|-----------------------|-------------------------------|----------------------|---------------------|--------------------|
| INSTRUCTION       | MODE<br>OCTAL<br>CODE | 2nd WORD<br>OF<br>INSTRUCTION | EFFECTIVE<br>ADDRESS | BEFORE<br>EXECUTION | AFTER<br>EXECUTION |
| CLR #1234         | 27                    | 001234                        | 5002                 | 1234                | all O's            |
| DEC @ #1000       |                       |                               |                      |                     |                    |
| CLR @ 7500        |                       |                               |                      |                     |                    |
| CLR 7500          |                       |                               |                      |                     |                    |
| INC @ #100        |                       |                               |                      |                     |                    |
| CLR 1000          |                       |                               |                      |                     |                    |
| INC #1234         |                       |                               |                      |                     |                    |
| INC @ 1000        |                       |                               |                      |                     |                    |
| INC @ - 4004 (R7) |                       |                               |                      |                     |                    |
| INC SUM           |                       |                               |                      |                     |                    |
| CLR LIMIT         |                       |                               |                      |                     |                    |

read on 🌢

### —exercise b-answer sheet special pc addressing modes

INITIAL (R7) = 5000 CONDITIONS: (1000) = 100, and (100) = 10, and (10) = 1 (SUM) = 2700; assume SUM is offset +600<sub>8</sub> relative to PC. (LIMIT) = 4000; assume LIMIT is offset -500<sub>8</sub> relative to PC. (7500) = 1000

|   |                   |                       |                               |                      | OPE                 | RAND               |
|---|-------------------|-----------------------|-------------------------------|----------------------|---------------------|--------------------|
|   | INSTRUCTION       | MODE<br>OCTAL<br>CODE | 2nd WORD<br>OF<br>INSTRUCTION | EFFECTIVE<br>ADDRESS | BEFORE<br>EXECUTION | AFTER<br>EXECUTION |
|   | CLR #1234         | 27                    | 001234                        | 5002                 | 1234                | all O's            |
| ĺ | DEC @ #1000       | 37                    | 001000                        | 1000                 | 100                 | 77                 |
| Ĩ | CLR @ 7500        | 77                    | 002474                        | 1000                 | 100                 | all O's            |
| [ | CLR 7500          | 67                    | 002474                        | 7500                 | 1000                | all O's            |
|   | INC @ #100        | 37                    | 000100                        | 100                  | 10                  | 11                 |
|   | CLR 1000          | 67                    | 173774                        | 1000                 | 100                 | all O's            |
|   | INC #1234         | 27                    | 001234                        | 5002                 | 1234                | 1235               |
|   | INC @ 1000        | 77                    | 173774                        | 100                  | 10                  | 11                 |
| ĺ | INC @ - 4004 (R7) | 77                    | 173774                        | 100                  | 10                  | 11                 |
| İ | INC SUM           | 67                    | 000600                        | 5604                 | 2700                | 2701               |
|   | CLR LIMIT         | 67                    | 177300                        | 4304                 | 4000                | all O's            |

\* The instruction CLR 7500 assembles as follows:

(5000) = CLR 7500 (5002) = Offset (5004) = Next Instruction

\*\*

Offset = Effective Address-Updated PC Offset =  $7500_8 - 5004_8 = 2474_8$ 

\*\* The instruction INC @ 1000 assembles as follows:

(5000) = INC @1000 (5002) = Offset (5004) = Next Instruction

Offset = Address of Effective Address-Updated PC Offset = 1000-5004 Offset = 173774 (2's complement since result is negative)

#### -test-addressing modes-

When you have completed the study unit, please take this self-scoring test. Then compare your answers against the "answer sheet" which can be obtained from your supervisor. Based on your test results, either review the appropriate material in this study unit or proceed to the next unit in the series.

- 1. Match the following statements with the corresponding addressing mode.
  - a. Operand address is computed as an offset to the updated PC.
  - b. Contents of R3 are summed with a index word to produce an effective address.
  - c. No bus cycle is required to retrieve operand.
  - d. Operand follows the instruction.
  - e. Base plus index word produces a pointer to the operand's address.
  - f. Automatic advancement through a list of items stored in *consecutive* locations.
  - g. Fixed address of operand follows the instruction.
  - h. Directs the CPU to a series of operands via a table of addresses stored in memory.
  - i. Address of operand is stored in a GPR; contents of GPR are not modified.

21

read on

- () Register mode 0
- ( ) Register deferred mode 1
- () Autoincrement mode 2
- () Autoincrement deferred mode 3
- () Index mode 6
- () Index deferred mode 7
- () Immediate mode 2 with PC
- () Absolute mode 3 with PC
- () Relative mode 6 with PC

# -test-addressing modes-

2. Complete the following chart. Assume the initial conditions apply for each instruction.

#### INITIAL CONDITIONS:

| (R1) = 700<br>(1000) = 100<br>(1776) = 176<br>(1777) = 177 | (R4) = 2000<br>(100) = 10<br>(176) = 16<br>(177) = 17 | (R5) = 1777<br>(R7) = 4000<br>(10) = 1<br>(16) = 6<br>(17) = 7 |
|------------------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------|
| (2000) = 200<br>(7000) = 700                               | (200) = 20<br>(700) = 70                              | (20) = 2<br>(70) = 7                                           |
| (TABLE) = 7000<br>relative to the PC                       | ; assume TABLE i<br>2.                                | s offset - 1700 <sub>8</sub>                                   |

| INSTRUCTION     | MODE<br>OCTAL<br>CODE | 2nd WORD<br>OF<br>INSTRUCTION | EFFECTIVE<br>ADDRESS | OPERAND<br>BEFORE<br>EXECUTION |
|-----------------|-----------------------|-------------------------------|----------------------|--------------------------------|
| INC 7000        | 67                    | 002774                        | 7000                 | 700                            |
| DEC @ 1100 (R1) |                       |                               |                      |                                |
| DEC #60         |                       |                               |                      |                                |
| CLRB (R5) +     |                       | $\ge$                         |                      |                                |
| DEC @-(R4)      |                       | $\mathbf{>}$                  |                      |                                |
| INC @ 1776      |                       |                               |                      |                                |
| INC - 600 (R1)  |                       |                               |                      |                                |
| CLR R4          |                       | $\geq$                        |                      |                                |
| CLR TABLE       |                       |                               |                      |                                |
| CLRB -(R4)      |                       | $\ge$                         |                      |                                |
| INC @ #7000     |                       |                               |                      |                                |
| CLR @ R4        |                       | $\geq$                        |                      |                                |

read on

### -test-addressing modes-

3. Given:

DEC @ 50 (R2) with (R2) = 350 (420) = 220 (220) = 100 (400) = 300

a. The operand is stored in location \_\_\_\_\_.

\_ .

b. After the instruction is executed, the contents of that location are

