







on II, Spring 2010, Tiina Nikl





## Lecture 12: Recapitulation















































25.2.2010













Comp. Org II, Spring 2010

| -                            |                                        | -3: | sing modes (050                  | itustavat)           |  |  |  |  |  |
|------------------------------|----------------------------------------|-----|----------------------------------|----------------------|--|--|--|--|--|
| x86 Addressing Mode          |                                        |     | Algor                            | ithm                 |  |  |  |  |  |
| Immediate                    |                                        | _   | Operand = A                      | 1, 2, 4, 8B          |  |  |  |  |  |
| Register Operand             |                                        |     | Operand $-(\mathbf{R})$          |                      |  |  |  |  |  |
| Displacement                 |                                        |     | LA = (SR) + A                    | Registers:           |  |  |  |  |  |
| Base                         |                                        |     | LA = (SR) + (B)                  | 1, 2, 4, 8B          |  |  |  |  |  |
| Base with Displacement       |                                        |     | LA = (SR) + (B) + A              | For indexing arrays  |  |  |  |  |  |
| Scaled Index with Displaceme | nt                                     |     | $LA = (SR) + (I) \times S + A$   | For arrays in stack  |  |  |  |  |  |
| Base with Index and Displace | ment                                   |     | IA = (SR) + (R) + (I) +          | A two dimensional ar |  |  |  |  |  |
| Base with Scaled Index and D | isplacem                               | ent | $LA = (SR) + (I) \times S + (I)$ | (A) + A              |  |  |  |  |  |
| Relative                     |                                        |     | LA = (PC) + A                    | element siz          |  |  |  |  |  |
| LA = linear address          | R                                      | =   | register                         |                      |  |  |  |  |  |
| (X) = contents of X          | в                                      | =   | base register                    |                      |  |  |  |  |  |
| SR = segment register        | I                                      | =   | index register                   |                      |  |  |  |  |  |
| PC = program counter         | S                                      | =   | scaling factor                   |                      |  |  |  |  |  |
| A = contents of an addres    | of an address field in the instruction |     |                                  |                      |  |  |  |  |  |





| ARM Instruction Formats               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |            |      |    |    |        |     |    |    |    |             |               |                         |          |       |    |     |    |    |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------|----|----|--------|-----|----|----|----|-------------|---------------|-------------------------|----------|-------|----|-----|----|----|
| data proce                            | ssina                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 31 30 29 2 | 8 27 | 26 | 25 | 24     | 23  | 22 | 21 | 20 | 19 18 17 16 | 15 14 13 12   | 11 10 9 8               | 7        | 65    | 4  | 3   | 2  | 10 |
| immediate                             | shift                                                                                                                                                                                                                                                                                                                                                                                                                                                                | cond       | 0    | 0  | 0  | opcode |     | S  | Rn | Rd | shift amou  | nt            | shift                   | 0        |       | Rm |     |    |    |
| data proce<br>register                | ssing<br>shift                                                                                                                                                                                                                                                                                                                                                                                                                                                       | cond       | 0    | 0  | 0  | 0      | ppc | od | e  | s  | Rn          | Rd            | Rs                      | 0        | shift | 1  |     | Rn | n  |
| data proce<br>imme                    | ssing<br>diate                                                                                                                                                                                                                                                                                                                                                                                                                                                       | cond       | 0    | 0  | 1  | opcode |     |    | e  | s  | Rn          | Rd            | rotate                  | immediat |       |    | ate |    |    |
| /load<br>immediate o                  | store<br>offset                                                                                                                                                                                                                                                                                                                                                                                                                                                      | cond       | 0    | 1  | 0  | Ρ      | U   | В  | w  | L  | Rn          | Rd            | immediate               |          |       |    |     |    |    |
| load/<br>register o                   | store<br>offset                                                                                                                                                                                                                                                                                                                                                                                                                                                      | cond       | 0    | 1  | 1  | Ρ      | U   | В  | W  | L  | Rn          | Rd            | shift amount shift 0 Rm |          |       |    |     | n  |    |
| load/<br>mu                           | store<br>Itiple                                                                                                                                                                                                                                                                                                                                                                                                                                                      | cond       | 1    | 0  | 0  | Ρ      | U   | S  | w  | L  | Rn          | register list |                         |          |       |    |     |    |    |
| branch/br<br>with                     | anch<br>h link                                                                                                                                                                                                                                                                                                                                                                                                                                                       | cond       | 1    | 0  | 1  | L      |     |    |    |    |             | 24-bit offset |                         |          |       |    |     |    |    |
| S :<br>S :<br>P,<br>B :<br>L :<br>L : | <ul> <li>S = For data processing instructions, updates condition codes</li> <li>S = For load/store multiple instructions, execution restricted to supervisor mode</li> <li>P, U, W = distinguish between different types of addressing mode</li> <li>B = Unsigned byte (B==1) or word (B==0) access</li> <li>L = For load/store instructions, Load (L==1) or Store (L==0)</li> <li>L = For branch instructions, is return address stored in link register</li> </ul> |            |      |    |    |        |     |    |    |    |             |               |                         | •        |       |    |     |    |    |





# 25.2.2010













# Lecture 12: Recapitulation























### Lecture 12: Recapitulation







