

# Vari modi di specificare l'indirizzo degli operandi

- Immediato
- Diretto
- Indiretto
- Registro
- Registro indiretto
- Spiazzamento
- Pila



#### Indirizzamento immediato

- L'operando è parte dell'istruzione (campo indirizzo)
- Vantaggio: nessun accesso in M per prendere l'operando
- Svantaggio: valore limitato dalla dimensione del campo indirizzo



#### Indirizzamento immediato

Istruzione

Cod.Op. Operando



#### Indirizzamento diretto

- Campo indirizzo = indirizzo dell'operando
- Esempio: ADD A
  - □ Somma il contenuto della cella A all'accumulatore
  - □ Bisogna andare in M all'indirizzo A per trovare l'operando
- Un singolo accesso in M per prendere l'operando
- Spazio di indirizzamento limitato





#### Indirizzamento indiretto

- Il campo indirizzo contiene l'indirizzo di una cella di M, che contiene l'indirizzo dell'operando
- Vantaggio: parole di lunghezza N permettono di indirizzare 2<sup>N</sup> entità diverse
  - □ In realtà 2<sup>K</sup>, dove K è la lunghezza del campo indirizzo
- Svantaggio: due accessi in M per ottenere l'operando
- Esempio: ADD A
  - □ Somma il contenuto della cella puntata dal contenuto di A all'accumulatore





# Indirizzamento registro

- L'operando è in un registro indicato nel campo indirizzo
- Numero limitato di registri
- Pochi bit necessari per il campo indirizzo
  - □ Istruzioni più corte
  - □ Fase di fetch più veloce (nessun accesso in M per prendere l'operando)





## Indirizzamento registro indiretto

- Stesso principio dell'indirizzamento indiretto
- L'operando è in una cella di M puntata dal contenuto del registro R
- Grande spazio di indirizzamento (2<sup>n</sup>)
- Un accesso in meno in M rispetto all'indirizzamento indiretto





#### Indirizzamento con spiazzamento

- Combinazione di indirizzamento diretto e indirizzamento registro indiretto
- Il campo indirizzo ha due sottocampi
  - □ A = valore di base (diretto)
  - □R = registro che contiene l'indirizzo di un valore da sommare ad A per ottenere l'indirizzo
  - □o viceversa (R base e A spiazzamento)





#### Indirizzamento relativo

- Una versione dell'indirizzamento con spiazzamento
- R = registro PC (program counter)
- Indirizzo dell'operando = A + (PC)
  - □ A celle dalla cella di M puntata da PC



# Indirizzamento registro-base

- A contiene lo spiazzamento
- R contiene il puntatore all'indirizzo base
  - □R può essere esplicito o implicito



#### Indicizzazione

- A = base
- R = spiazzamento
- Esempio: elenco di dati memorizzati in M a partire da un indirizzo A
  - □ Per accedere a tutti, la sequenza di indirizzi è A, A+1, A+2, ...
  - □ A viene messo nel campo indirizzo e il registro (indice) contiene 0 all'inizio e viene incrementato di 1 dopo ogni accesso



## Indirizzamento a pila

- Pila: sequenza lineare di locazioni riservate di M
- Puntatore (nel registro SP, stack pointer)
   con l'indirizzo della cima della pila
- L'operando è sulla cima della pila
- Quindi è un esempio di indirizzamento a registro indiretto





#### Modi di indirizzamento x86

| Mode                                    | Algorithm                            |
|-----------------------------------------|--------------------------------------|
| Immediate                               | Operand = A                          |
| Register Operand                        | LA = R                               |
| Displacement                            | LA = (SR) + A                        |
| Base                                    | LA = (SR) + (B)                      |
| Base with Displacement                  | LA = (SR) + (B) + A                  |
| Scaled Index with Displacement          | $LA = (SR) + (I) \times S + A$       |
| Base with Index and Displacement        | LA = (SR) + (B) + (I) + A            |
| Base with Scaled Index and Displacement | $LA = (SR) + (I) \times S + (B) + A$ |
| Relative                                | LA = (PC) + A                        |

 $\begin{array}{lll} LA = linear \ address & R = register \\ (X) = contents \ of \ X & B = base \ register \\ SR = segment \ register & I = index \ register \\ PC = program \ counter & S = scaling \ factor \\ \end{array}$ 

A = contents of an address field in the instruction



#### Formato delle istruzioni

- Struttura dei campi dell'istruzione
- Include il codice operativo
- Include (in modo implicito o esplicito) uno o più operandi
- Di solito più di un formato per un linguaggio macchina



# Lunghezza delle istruzioni

- Condiziona ed è condizionata da:
  - □ Dimensione della M
  - □ Organizzazione della M
  - □ Struttura del bus
  - □ Complessità della CPU
  - □ Velocità della CPU
- Compromesso tra repertorio di istruzioni potente e necessità di risparmiare spazio



#### Allocazione dei bit

- Vari modi di indirizzamento
- Vari numeri di operandi (di solito 1 o 2)
- Registri verso M (di solito almeno 32 registri)
- Banchi di registri (esempio: Pentium ha due banchi)
  - □ Due banchi da 8 registri ciascuno → solo 3 bit per indicare un registro (il codice operativo indica il banco)
- Intervallo di indirizzi
- Granularità degli indirizzi (es.: byte o parola)
  - ☐ L'indirizzamento di byte richiede più bit ma è utile (es. per manipolare caratteri)

# Formato delle istruzioni del PDP-8

|                                                                                                                                                                                                                                             | Memory reference instructions |         |        |                           |              |                                                                                                                                                                                                                                                                   |                                 |     |     |        |     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---------|--------|---------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-----|-----|--------|-----|
| Opcode D/I Z/C                                                                                                                                                                                                                              |                               |         |        |                           | Displacement |                                                                                                                                                                                                                                                                   |                                 |     |     |        |     |
| 0                                                                                                                                                                                                                                           |                               | 2       | 3      | 4                         | 5            |                                                                                                                                                                                                                                                                   |                                 |     |     |        | 11  |
|                                                                                                                                                                                                                                             |                               |         |        | Input/output instructions |              |                                                                                                                                                                                                                                                                   |                                 |     |     |        |     |
| 1                                                                                                                                                                                                                                           | 1                             | 0       |        |                           | Dev          | vice                                                                                                                                                                                                                                                              |                                 |     |     | Opcode |     |
| 0                                                                                                                                                                                                                                           |                               | 2       | 3      |                           |              |                                                                                                                                                                                                                                                                   |                                 | 8   | 9   |        | 11  |
|                                                                                                                                                                                                                                             |                               |         |        |                           |              |                                                                                                                                                                                                                                                                   | Register reference instructions |     |     |        |     |
| 1                                                                                                                                                                                                                                           | 1                             | 1       | 0      | CLA                       | CLL          | CMA                                                                                                                                                                                                                                                               | CML                             | RAR | RAL | BSW    | IAC |
| 0                                                                                                                                                                                                                                           | 1                             | 2       | 3      | 4                         | 5            | 6                                                                                                                                                                                                                                                                 | 7                               | 8   | 9   | 10     | 11  |
| Grou                                                                                                                                                                                                                                        | ıp 2 micı                     | oinstru | ctions |                           |              |                                                                                                                                                                                                                                                                   |                                 |     |     |        |     |
| 1                                                                                                                                                                                                                                           | 1                             | 1       | 0      | CLA                       | SMA          | SZA                                                                                                                                                                                                                                                               | SNL                             | RSS | OSR | HLT    | 0   |
| 0                                                                                                                                                                                                                                           | 1                             | 2       | 3      | 4                         | 5            | 6                                                                                                                                                                                                                                                                 | 7                               | 8   | 9   | 10     | 11  |
| Group 3 microinstructions                                                                                                                                                                                                                   |                               |         |        |                           |              |                                                                                                                                                                                                                                                                   |                                 |     |     |        |     |
| 1                                                                                                                                                                                                                                           | 1                             | 1       | 0      | CLA                       | MQA          | 0                                                                                                                                                                                                                                                                 | MQL                             | 0   | 0   | 0      | 1   |
| 0                                                                                                                                                                                                                                           | 1                             | 2       | 3      | 4                         | 5            | 6                                                                                                                                                                                                                                                                 | 7                               | 8   | 9   | 10     | 11  |
| D/I = Direct/Indirect address  Z/C = Page 0 or Current page  CLA = Clear Accumulator  CLL = Clear Link  CMA = CoMplement Accumulator  CML = CoMplement Link  RAR = Rotate Accumulator Right  RAL = Rotate Accumulator Left  BSW = Byte SWap |                               |         |        |                           |              | IAC = Increment ACcumulator SMA = Skip on Minus Accumulator SZA = Skip on Zero Accumulator SNL = Skip on Nonzero Link RSS = Reverse Skip Sense OSR = Or with Switch Register HLT = HaLT MQA = Multiplier Quotient into Accumulator MQL = Multiplier Quotient Load |                                 |     |     |        |     |



#### Formato delle istruzioni del PDP-10

| Opcode           |   | Reg | ister | I | l  | dex<br>gister |    | Memory address |
|------------------|---|-----|-------|---|----|---------------|----|----------------|
| 0                | 8 | 9   | 12    |   | 14 | 17            | 18 | 35             |
| I = indirect bit |   |     |       |   |    |               |    |                |



# Formato a lunghezza variabile

- Fino ad ora abbiamo visto esempi di formati a lunghezza fissa
- Alcune architetture utilizzano formati a lunghezza variabile o ibrida

Formato a lunghezza fissa

| Op.                           | (Indir.) Operando 1 | (Indir.) Operando 2 | (Indir.) Operando 3 |  |  |  |  |  |
|-------------------------------|---------------------|---------------------|---------------------|--|--|--|--|--|
| Formato a lunghezza variabile |                     |                     |                     |  |  |  |  |  |

Formato a lunghezza variabile



Formato ibrido

| Op. | (Indir.) Operando 1 |                     |
|-----|---------------------|---------------------|
| Op. | (Indir.) Operando 1 | (Indir.) Operando 2 |





