## Estructura y Tecnología de Computadores

Módulo C. Arquitectura del procesador

Tema 5. Repertorio de instrucciones y formato de la instrucción máquina

#### José Manuel Mendías Cuadros

Dpto. Arquitectura de Computadores y Automática Universidad Complutense de Madrid

• • • • •

2

### contenidos

#### 1. Repertorio de instrucciones

Clasificación de las instrucciones. Transferencia de datos. Instrucciones aritméticas. Instrucciones lógicas y de manipulación de bits. Desplazamiento y rotación. Control de flujo. Otras instrucciones

2. Aplicaciones del repertorio de instrucciones

Ejecución alternativa. Ejecución iterativa. Subrutinas

3. Formato de la instrucción máquina

Lenguaje ensamblador vs. código máquina. Elementos constitutivos de una instrucción máquina. Alternativas de diseño del formato de instrucción. Número de operandos explícitos de una instrucción. Ejemplo de diseño del formato de la instrucción máquina. Ciclo de instrucción

4. Arquitecturas CISC y RISC

Arquitecturas CISC. Problemas de las arquitecturas CISC. Características de las arquitecturas RISC. Ventajas y desventajas de las arquitecturas RISC. Computadores CISC y computadores RISC.

5. Ejemplos

MC68000. Arquitectura MIPS

# 1. repertorio de instrucciones

#### Clasificación de las instrucciones

- Transferencia de datos, permiten el movimiento entre distintos dispositivos de almacenamiento del computador
- Aritméticas, permiten realizar operaciones de tipo aritmético
- 🗵 Lógicas y de manipulación de bits, permiten realizar operaciones lógicas, bit a bit, entre los operandos o manipular un bit del operando
- Desplazamiento y rotación, permiten desplazar o rotar un operando a la decha. o la izda. un nº determinado de bits
- De Control de flujo, permiten romper la secuencia normal de ejecución
- Otras instrucciones
  - > Transformación de datos
  - Manipulación de direcciones
  - > Creación de marcos de almacenamiento local
  - > Control del sistema
  - F/S

estructura y tecnología de computadores

1. repertorio de instrucciones

# Trasferencia de datos

- Dermiten el movimiento entre distintos dispositivos de almacenamiento del computador:
  - ➤ Reg → Reg  $\blacktriangleright \quad \text{Reg} \to \text{Mem}$
- ➤ Mem → Reg
- ➤ Pila → Reg ightharpoonup Pila ightharpoonup Mem

- ➤ Reg → Pila
- $\blacktriangleright \quad \mathsf{Mem} \to \mathsf{Mem}$
- ightharpoonup Mem ightarrow Pila
- Necesario especificar:
  - > Tipo de movimiento
  - > Dirección de operandos fuente y destino
  - > Tamaño de datos a mover (byte, palabra, doble palabra, ...)
  - > Nº de elementos a mover (para movimientos múltiples)

| Instrucción |                 | Operación                                   | Descripción                                                                                                          |  |
|-------------|-----------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--|
| MOVE        | fuente,destino  | $destino \leftarrow fuente$                 | Transfiere palabra de reg. a reg., reg. a mem, mem. a reg o mem. a mem. (fuente= mem. o reg.; destino = mem. o reg.) |  |
| LOAD        | Ri, dir         | Ri ← dir                                    | Transfiere palabra de memoria a registro                                                                             |  |
| STORE       | dir, Ri         | Ri ← dir                                    | Transfiere palabra de registro a memoria                                                                             |  |
| PUSH        | fuente          | Pila ← fuente                               | Transfiere palabra de mem. o reg. a la cabecera de pila                                                              |  |
| POP         | destino         | $destino \leftarrow Pila$                   | Transfiere palabra de cabecera de pila a mem. o reg.                                                                 |  |
| MOVEM       | fnte., dest., n | $fnte_0 \leftarrow dest_0 \dots$            | Transfiere n palabras a partir de una dir. inicial fuente                                                            |  |
|             |                 | $\dots$ fnte $_{n-1} \leftarrow dest_{n-1}$ | y una dir. inicial destino                                                                                           |  |

## Instrucciones aritméticas

- Permiten realizar operaciones de tipo aritmético
- Necesario especificar:
  - > Tipo de operación (suma, resta, multiplicación, división, etc.)
  - > Tipo de operandos y de aritmética (con signo, sin signo, entera, punto flotante, BCD, ...)
  - > tamaño de datos sobre los que se opera
  - Dirección de operandos fuente y destino (0, 1, 2 ó 3, según el repertorio)

| Instrucción |                  | Operación                         | Descripción                                                                            |  |
|-------------|------------------|-----------------------------------|----------------------------------------------------------------------------------------|--|
| ADD         | fnte1,fnte2,dest | dest ← fnt1+fnt2                  | Suma dos operandos                                                                     |  |
| SUB         | fnte1,fnte2,dest | dest ← fnt1-fnt2                  | Resta dos operandos                                                                    |  |
| MULT        | fnte1,fnte2,dest | dest ← fnt1*fnt2                  | Multiplica dos operandos                                                               |  |
| DIV         | fnte1,fnte2,dest | dest ← fnt1/fnt2                  | Divide dos operandos                                                                   |  |
| NEG         | fnte,dest        | $dest \leftarrow \textbf{-}  fnt$ | Cambia de signo al operando                                                            |  |
| ABS         | fnte,dest        | $dest \leftarrow Abs(fnt)$        | Obtiene el valor absoluto del operando                                                 |  |
| INC         | fnte,dest        | dest ← fnt+1                      | Suma 1 al operando                                                                     |  |
| DEC         | fnte,dest        | dest ← fnt-1                      | Resta 1 al operando                                                                    |  |
| COMP        | fnte1,fnte2      | fnt1-fnt2<br>Activa Estado        | Compara dos operandos y activa los bits de estado según el resultado de la comparación |  |

estructura y tecnología de computadores

1. repertorio de instrucciones

5

### Instrucciones lógicas y de manipulación de bits

- Permiten realizar operaciones lógicas, bit a bit, entre los operandos o manipular un bit del operando
- Necesario especificar:
  - > Tipo de operación (AND, OR, NOT, Bit Clear, Bit Set, etc)
  - > Tamaño de datos sobre los que se opera (byte, palabra, doble palabra, ...)
  - > Dirección de operandos fuente y destino (0, 1, 2 ó 3, según el repertorio)
  - > El número de bit en las instrucciones de manipulación de bit

| Instrucción |                  | Operación              | Descripción                                |  |
|-------------|------------------|------------------------|--------------------------------------------|--|
| AND         | fnte1,fnte2,dest | dest ← fnt1 AND fnt2   | Realiza la Y lógica de dos operandos       |  |
| OR          | fnte1,fnte2,dest | dest ← fnt1 OR fnt2    | Realiza la O lógica de dos operandos       |  |
| NOT         | fnte,dest        | dest ← NOT fnt         | Realiza la negación lógica del operando    |  |
| XOR         | fnte1,fnte2,dest | dest ← fnt1 XOR fnt2   | Realiza la O exclusiva de dos operandos    |  |
| BCLR        | dest, n          | $dest(n) \leftarrow 0$ | Pone a cero el bit especificado            |  |
| BSET        | dest, n          | dest(n) ← 1            | Pone a uno el bit especificado             |  |
| BTST        | fnte, n          | Estado ← fnte(n)       | Activa estado según valor del bit indicado |  |

# 1. repertorio de instrucciones

### Desplazamiento y rotación

- igotimes Permiten desplazar o rotar un operando a la decha. o la izda. un  $n^{\text{o}}$  determinado de bits
- - > Tipo de operación (desplazamiento izda. o decha., rotación izda. o decha., )
  - > Tamaño de datos sobre los que se opera (byte, palabra, doble palabra, ...)
  - > Dirección del operando
  - > Nº de bits a desplazar o rotar

| Instrucción |         | Operación  | Descripción                                        |  |
|-------------|---------|------------|----------------------------------------------------|--|
| LSL         | fnte,n  | <b>←</b> 0 | Desplaz. lógico izda. n bits (Logic Shift Left)    |  |
| LSR         | fnte,n  | 0 -        | Desplaz. lógico decha. n bits (Logic Shift Right)  |  |
| ASL         | fnte,n  | ← 0        | Desplaz. aritm. izda. n bits (Arith. Shift Left)   |  |
| ASR         | fnte,n  |            | Desplaz. aritm. decha. n bits (Arith. Shift Right) |  |
| RL          | dest, n |            | Rotación izda. n bits (Rotate Left)                |  |
| RR          | dest, n |            | Rotación decha. n bits (Rotate Right)              |  |

estructura y tecnología de computadores

1. repertorio de instrucciones

3

### Control de flujo

- Permiten romper la secuencia normal de ejecución y saltar a una determinada dirección especificada en la instrucción o implícita
- - > Dirección de siguiente instrucción a ejecutar si el salto es explícito

| Instrucción |     | Operación                                                                   | Descripción                                                              |  |
|-------------|-----|-----------------------------------------------------------------------------|--------------------------------------------------------------------------|--|
| JMP         | dir | PC ← dir                                                                    | Salta (Jump) a la dirección especificada                                 |  |
| Всс         | dir | If cc=TRUE then PC $\leftarrow$ dir<br>Else PC $\leftarrow$ PC + long_instr | Bifurca (Branch) a la dirección especificada si la condición es cierta   |  |
| JSR         | dir | Estado, PC $\rightarrow$ Pila; PC $\leftarrow$ dir                          | Salto a subrutina; guarda en pila PC y estado                            |  |
| RTS         |     | Estado, PC ← Pila                                                           | Retorno de subrutina; recupera de pila PC y estado                       |  |
| SKIP        | n   | $PC \leftarrow PC + n^* long_instr$                                         | Salta el nº de instrucciones especificado                                |  |
| NOP         |     | $PC \leftarrow PC + long\_instr$                                            | No ejecuta ninguna operación, pero la ejecución continúa secuencialmente |  |

# 1. repertorio de instrucciones

#### Control de flujo (cont.)

- Las instrucciones de bifurcación o salto condicional (Bcc), saltan o no en función de la condición especificada
- 🗵 Esta condición se calcula a partir de los bits de condición del registro de estado
  - > Los bits de condición se activan según el resultado de las instrucciones ejecutadas anteriormente

| Condic. | Nombre                     | Es cierta si                                                                 |
|---------|----------------------------|------------------------------------------------------------------------------|
| EQ      | Igual (Equal)              | En una comparación previa los operandos son iguales                          |
| NEQ     | No igual (No equal)        | En una comparación previa los operandos son distintos                        |
| GT      | Mayor que (Greater Than)   | En una comparación previa el primer operando es mayor que el segundo         |
| GE      | Mayor o igual (Gr. or Eq.) | En una comparación previa el primer operando es mayor o igual que el segundo |
| LT      | Menor que (Less Than)      | En una comparación previa el primer operando es menor que el segundo         |
| LE      | Menor o igual (Les.or Eq.) | En una comparación previa el primer operando es menor o igual que el segundo |
| Z       | Cero (Zero)                | El resultado de una operación anterior es cero                               |
| NZ      | No cero (No Zero)          | El resultado de una operación anterior es distinto de cero                   |
| P       | Positivo                   | El resultado de una operación anterior es positivo                           |
| N       | Negativo                   | El resultado de una operación anterior es negativo                           |
| С       | Acarreo (Carry)            | El resultado de una operación anterior ha producido acareo                   |
| NC      | No acarreo (No Carry)      | El resultado de una operación anterior no ha producido acareo                |
| V       | Desbord. (Overflow)        | El resultado de una operación anterior ha producido desbordamiento           |
| NV      | No desbord. (No Overfl.)   | El resultado de una operación anterior no ha producido desbordamiento        |
| Т       | Verdad (True)              | Siempre cierta                                                               |
| F       | Falso (False)              | Siempre falsa                                                                |

estructura y tecnología de computadores

10

# 1. repertorio de instrucciones

#### **Otras instrucciones**

- 🖾 En este grupo están englobadas distintas instrucciones
  - > Transformación de datos
    - Cambian el formato de los datos, por ej. de decimal a binario
  - > Manipulación de direcciones
    - > Permiten calcular la dirección efectiva de un operando y almacenarla en un registro o en pila, p. ej.
      - ✓ LEA fnte, reg (Load effective address: reg  $\leftarrow$  Dirección de fnte)
      - ✓ PEA fnte (Push Effective Address: Pila ← Dirección de fnte)
  - > Creación de marcos de almacenamiento local
    - ✓ Permiten reservar espacio en la pila del sistema, p. ej:
      - ✓ LINK reg, #tam (Pila  $\leftarrow$  reg, reg  $\leftarrow$  SP, SP  $\leftarrow$  SP+tam)
      - ✓ UNLK reg (SP  $\leftarrow$  reg, reg  $\leftarrow$  Pila)
  - Control del sistema
    - > Suelen ser instrucciones privilegiadas que usa el sistema operativo, p. ej.:
      - $\checkmark$  RESET, para reiniciar el computador (PC  $\leftarrow$  valor inicial)
      - ✓ RTE: retorno de excepción o interrupción
  - > E/S
    - > Para entrada y salida de datos entre el computador y dispositivos periféricos, p. ej.:
      - ✓ IN dir\_perif, reg (reg  $\leftarrow$  perif)
      - ✓ OUT dir\_perif, reg (perif ← reg )

# 2. aplicaciones del repertorio de instrucciones

#### Ejecución alternativa

Según el valor de cierta condición o valor, se decide entre varios caminos de ejecución



12

# 2. aplicaciones del repertorio de instrucciones

### Ejecución iterativa

Según el valor de cierta condición, se decide repetir la ejecución de cierto bloque de código



#### con un número definido de iteraciones



# 2. aplicaciones del repertorio de instrucciones

#### **Subrutinas**



#### Suponiendo:

- ✓ una memoria direccionada por bytes
  - ✓ un tamaño palabra de 16 bits
  - ✓ un tamaño de dirección de 32 bits
  - que un integer se representa mediante palabra





estructura y tecnología de computadores

14

# 2. aplicaciones del repertorio de instrucciones



16

# 2. aplicaciones del repertorio de instrucciones



# 3. formato de la instrucción máquina



#### 

- > Resuelve las etiquetas de instrucciones y datos
  - ⇒ Relativas a PC para instrucciones
  - ⇒ Relativas a algún registro para datos
- > Expande macros y pseudo-instrucciones
- Interpreta las directivas de ensamblaje
- > Fija la representación de los datos
- > Traduce las instrucciones a código máquina
- Crea el fichero objeto
  - Determina cabeceras, segmentos de código y segmentos de datos
  - ⇒ Crea tablas de símbolos: símbolos no resueltos + símbolos visibles
  - ⇒ Añade información para la depuración

#### 

- > Combina varios códigos objeto, resolviendo las referencias cruzadas
- > Crea un código ejecutable

#### 

- > Lee y carga sobre memoria el código ejecutable
- > Inicializa registros, pila y argumentos
- > Fija los vectores de excepción
- > Salta a la rutina de inicio del programa

estructura y tecnología de computadores

18

# 3. formato de la instrucción máquina

#### Elementos constitutivos de una instrucción máquina

#### 

Especifica el tipo de operación a realizar: Suma, Resta, Y lógica, Movimiento de datos, etc.

#### 

- > La instrucción puede involucrar uno o más operandos fuente (o ninguno)
- > Estos podrán especificarse utilizando distintos modos de direccionamiento

#### 

- > Si la instrucción produce un resultado deberá especificar el operando destino
- > Este podrá especificarse utilizando distintos modos de direccionamiento

#### 

- > En ocasiones es necesario especificar cuál es la siguiente instrucción a ejecutar
- > Normalmente la ejecución del programa es secuencial
  - ⇒ La dirección de la siguiente instrucción suele ser implícita:
    - Dir. instrucción siguiente = Dir. instrucción actual + Longitud instrucción actual
- > En las instrucciones de salto sí es necesario especificar la dir. de la siguiente instrucción
  - ⇒ Ruptura de la secuencia normal del programa

| Instrucción máquina: | opcode | op. fuente 1 | <br>op. fuente n | op. destino | instruc. siguiente | ı |
|----------------------|--------|--------------|------------------|-------------|--------------------|---|
|                      |        |              |                  |             |                    |   |

20

# 3. formato de la instrucción máquina

#### Alternativas de diseño del formato de instrucción

- 🗵 A la hora de diseñar el formato de las instruc. máquina de un repertorio, debemos decidir:
  - > Cuál será la longitud de las instrucciones
    - ⇒ Todas las instrucciones de igual longitud
    - ⇒ Instrucciones de distinta longitud, según el tipo de operación a realizar
  - > De cuántos campos constará la misma (dependiendo del tipo de instrucción)
  - Cuántos bits ocuparán cada uno de esos campos
  - Codificación de cada campo
- 🖾 Los principales factores a tener en cuenta para decidir este formato son:
  - > Número de operaciones distintas presentes en el repertorio
    - ⇒ Aritméticas, lógicas, de control, de movimiento de datos, ...
  - > Número de operandos de la instrucción (incluyendo operandos fuente y destino)
    - ⇒ Instrucciones sin operandos
    - ⇒ Instrucciones con 1, 2, 3, ... operandos
  - Modos de direccionamiento disponibles para cada operando
    - ⇒ Inmediato, absoluto, de registro, indirecto, .....
  - > Tamaño y tipos de datos soportados
    - ⇒ Bit, byte, palabra, doble palabra, ....
    - ⇒ Caracteres, BCD, magnitud y signo, complemento a 2, punto flotante, ....

estructura y tecnología de computadores

3. formato de la instrucción máquina

#### Número de operandos explícitos en una instrucción

- ☑ Una operación típica de un computador (p. ej. A = B + C) suele tener tres operandos
  - > Dos operandos fuente (B y C) y un operando destino (A)
- - Instrucciones con tres operandos explícitos
  - Instrucciones con dos operandos explícitos
  - Instrucciones con un único operando explícito
  - > Instrucciones sin operandos explícitos

Instrucciones con tres operandos explícitos

- Se especifican los tres operandos en la instrucción máquina
  - > Cada operando puede soportar distintos modos de direccionamiento
- ➣ Formato flexible, pero ocupa mucho espacio

**Ejemplo** 

 $ADD A, B, C A \neg B + C$ 

Instrucciones con dos operandos explícitos

- Dos operandos explícitos y uno implícito
  - > Uno de los operandos actúa como fuente y destino
- > Cada operando puede soportar distintos modos de direccionamiento
- Es menos flexible, pero ocupa menos espacio

**Ejemplo** 

ADD B, C B ¬ B + C

# Número de operandos explícitos en una instrucción (cont.)

### Instrucciones con un único operando explícito

- 🗵 Se especifican un sólo operando en la instrucción máquina
  - > Uno de los operandos y el resultado se almacenan en un registro especial del procesador: el **acumulador**
- El operando puede soportar distintos modos de direccionamiento
- ➣ Formato muy reducido, pero poco flexible

### **Ejemplo**

ADD B Acum. ¬ B + Acum.

#### Instrucciones sin operandos explícitos

- Tanto los operandos como el resultado se almacenan en la pila del sistema
- Requiere varias instrucciones previas de acceso a la pila







estructura y tecnología de computadores

22

3. formato de la instrucción máquina

### Número de operandos explícitos en una instrucción: EJEMPLO

 $\boxtimes$  Escribir los programas simbólicos para la siguiente operación:  $Y = (A-B)/(C+D^*E)$ 

en un computador de 0, 1, 2 ó 3 direcciones, utilizando las instrucciones que sean necesarias y sin sobreescribir el contenido de ninguno de los operandos fuente

#### 3 operandos

| SUB  | Y, A, B | (Y ¬ A-B)   |
|------|---------|-------------|
| MULT | T, D, E | (T ¬ D*É)   |
| ADD  | T, T, C | (T - T + C) |
| DIV  | Y, Y, T | (Y - Y/T)   |
|      |         |             |

#### 2 operandos

| MOVE<br>SUB<br>MOVE<br>MULT<br>ADD<br>DIV | Y, A<br>Y, B<br>T, D<br>T, E<br>T, C<br>Y, T | (Y ¬ A)<br>(Y ¬ Y-B)<br>(T ¬ D)<br>(T ¬ T*E)<br>(T ¬ T+C)<br>(Y ¬ Y/T) |
|-------------------------------------------|----------------------------------------------|------------------------------------------------------------------------|
|                                           |                                              |                                                                        |

## 1 operando

| MULT<br>ADD<br>STORE<br>LOAD<br>SUB<br>DIV<br>STORE | DECYABYY | (Ac - D)<br>(Ac - Ac*E)<br>(Ac - Ac+C)<br>(T - Ac)<br>(Ac - A)<br>(Ac - Ac-B)<br>(Ac - Ac/Y)<br>(Y - Ac) |
|-----------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------|
| OTORL                                               | ٠.       | (1 . Ac)                                                                                                 |

#### 0 operandos

| PUSH                | E |
|---------------------|---|
| PUSH                | D |
| MULT<br>PUSH<br>ADD | С |
| PUSH                | B |
| PUSH                | A |
| SUB<br>DIV<br>POP   | Υ |

### Ejemplo de diseño del formato de la instrucción máquina

- Diseñar el formato de las instrucciones de un computador con 8 registros de propósito general que permita codificar en una instrucción de 32 bits lo siguiente:
  - > 12 instrucciones de 3 operandos
    - > Dos operandos que permiten direccionamiento absoluto e indirecto de memoria
    - > Un operando que permite direccionamiento de registro en indirecto de registro
  - > 150 instrucciones de 2 operandos
    - > Un operando que permite direccionamiento absoluto e indirecto de memoria
    - > Un operando que permite direccionamiento de registro en indirecto de registro
  - > 30 instrucciones de 0 operandos
- Nota: El campo dirección de los operandos con direccionamiento absoluto e indirecto de memoria será de 11 bits.

#### Solución

- - → 1 bit para especificar el modo de direccionamiento (m=0 → absoluto; m=1 → indirecto)
  - 11 bits para especificar la dirección
- - $\blacktriangleright$  1 bit para especificar el modo de direccionamiento (m=0  $\rightarrow$  de registro; m=1  $\rightarrow$  indirecto de reg.)
  - > 3 bits para especificar el número de registro (ya que tenemos 8 registros)

estructura y tecnología de computadores

. . . . . .

24

# 3. formato de la instrucción máquina

#### Solución (Cont.)

- Para las 12 instrucciones de tres operandos necesitamos:
  - ➤ 4 bits para especificar el tipo de operación: del 0 (0000) al 11 (1011)
    - 12 bits para especificar el primer y segundo operando respectivamente
  - 4 bits para especificar el tercer operando
- Para las 150 instrucciones de dos operandos necesitamos:
  - > 8 bits para especificar el tipo de operación: del 0 (0000000) al 149 (1010101)
  - > 12 bits para especificar el primer operando
  - > 4 bits para especificar el tercer operando
- - > 5 bits para especificar el tipo de operación: del 0 (00000) al 29 (11101)









#### Ciclo de instrucción

estructura y tecnología de computadores

• • • •

26

# 4. arquitecturas CISC y RISC

#### Arquitecturas CISC (Computador de conjunto de instrucciones complejo)

- Desde los años 60 (en que aparece la unidad de control microprogramada) hasta principio de los años 80 la tendencia ha sido incrementar la complejidad de la CPU
  - > Gran número de instrucciones en el repertorio e instrucciones complejas
  - > Uso de gran número de modos de direccionamiento complejos
- Esta tendencia se debe a varias razones:
  - > Aparecen lenguajes de programación de alto nivel cada vez más sofisticados
    - ➡ Diseño de instrucciones complejas que permitan implementar instrucciones de alto nivel directamente o con un pequeño número de instrucciones máquina
    - ⇒ Una instrucción de alto nivel compleja implementable directamente en hardware, mejora la eficiencia del programa ya que se ejecuta mucho más rápidamente
  - Gracias al uso de unidad de control microprogramada, se pueden implementar estas instrucciones máquinas complejas de forma simple, sin demasiado coste para el diseñador
  - Facilidad para mantener la compatibilidad hacia abajo con los miembros de la misma familia
    - Añadir nuevas instrucciones al repertorio, manteniendo las antiguas

# 4. arquitecturas CISC y RISC

#### Problemas de las arquitecturas CISC

- - > La mayor parte de las instrucciones complejas apenas si se utilizan en programas reales
  - > Lo mismo ocurre con modos de direccionamiento complejos
- Dificultad para diseñar compiladores eficientes
  - Al aumentar la complejidad del repertorio se hace cada vez más difícil diseñar compiladores que aprovechen realmente esta gran variedad y versatilidad de instrucciones máquina
- - Al existir un gran número de instrucciones y de modos de direccionamiento se necesita mucho espacio para codificar las instrucciones máquina y se tarda más tiempo en leerlas de memoria
  - > El tiempo de acceso a memoria para captar instrucciones (Fetch) resulta cada vez más crítico conforme evolucionan los computadores
- Debido a estos problemas a principio de los 80 surge la arquitectura RISC (Computador de conjunto de instrucciones reducido)
  - Idea básica: hacer rápidos y eficientes los casos más comunes a costa de reducir la velocidad en los casos menos comunes

estructura y tecnología de computadores

• • • • •

28

# 4. arquitecturas CISC y RISC

#### Características de las arquitecturas RISC

- Repertorio de instrucciones simple y ortogonal
  - > Sólo se dispone de instrucciones máquina básicas
  - > Repertorio ortogonal: no existen varias instrucciones distintas para realizar la misma operación
- Modos de direccionamiento sencillos
  - > Cada operando sólo soporta unos pocos modos de direccionamiento simples
- - > Número reducido de formatos de instrucciones distintos
  - > Todas las instrucciones de longitud similar
- - > Las instrucciones sólo soportan unos pocos tipos de datos básicos distintos
- Arquitectura de tipo registro-registro
  - ightharpoonup Sólo las instrucciones LOAD (Mem ightarrow Reg) y STORE (Reg ightarrow Mem) hacen referencia a memoria
  - > El resto de instrucciones (aritméticas, lógicas, etc.) son de tipo registro-registro,
    - > Tanto los operandos fuente como destino son registros de la arquitectura
  - Las arquitecturas RISC suelen caracterizarse por disponer de un gran número de registros de propósito general

# 4. arquitecturas CISC y RISC

#### Ventajas de las arquitecturas RISC

- Su estructura es mucho más simple
  - > Es más rápido y puede trabajar a mayor velocidad
  - > Su diseño es más sencillo y barato
- - > Tardan menos tiempo en leerse de memoria
- Mayor simplicidad para generar código máquina
  - > Los compiladores son más eficientes y más sencillos de diseñar

#### Desventajas de las arquitecturas RISC

- 🖾 El compilador genera un mayor número de instrucciones máquina
  - > Se necesitan varias instrucciones para ejecutar las instrucciones de alto nivel
  - ightharpoonup Mayor número de instrucciones  $\leftrightarrow$  Instrucciones más rápidas
- Más difícil mantener la compatibilidad entre computadores de la misma familia
  - > Para diseñar un repertorio simple no se pueden "heredar" todas las instrucciones

estructura y tecnología de computadores •

30

# 4. arquitecturas CISC y RISC

#### **Computadores CISC**

- ∨ VAX 11 (desaparecido)
- ☑ Intel 80x86 (i8086, i80286, i80386, i80486, Pentium, Pentium II, Pentium III)
- **™ Motorola MC68xxx** (MC68000, MC68010, MC68020, MC68030, MC68040, MC68060)

### **Computadores RISC**

- Motorola MC88000 (desaparecido)
- Sun SPARC (SPARC, Super SPARC 2, Ultra SPARC I, Ultra SPARC II, Ultra SPARC III)
- **PowerPC** (601, 602, 603, 604, 620, 630, Power3)
- **DEC Alpha** (21064, 21064a, 21066a, 21164, 21164a, 21264)

#### Características del MC68000

- Procesador CISC de 16 bits
  - > Aprox. 90 instrucciones máquina
  - > 12 modos de direccionamiento
  - > 9 formatos de instrucción distintos y con tamaños de una a cinco palabras
  - > Ancho del bus de datos: 16 bits
  - > Tamaño mínimo direccionable: 1 byte
  - $\succ$  Ancho del bus de direcciones: 24 bits ( $2^{24}$  bytes = 16 Mbytes de memoria direccionables)
- Modos de funcionamiento
  - > Modo usuario
    - > Modo normal de ejecución de programas
    - > No tiene acceso a determinadas instrucciones privilegiadas
    - > No tiene acceso a determinados registros del supervisor
  - > Modo supervisor
    - > Modo de ejecución del Sistema Operativo y durante el tratamiento de interrupciones
    - > Tiene acceso a todas las instrucciones privilegiadas y a registros del supervisor

estructura y tecnología de computadores

32

# 5. ejemplos: MC68000

#### Tipos de datos y organización de la memoria

- Bit
- Enteros sin signo o con signo (complemento a 2)

  - Tamaño **Byte** (8 bits)  $\rightarrow$  se representa como .b (byte) Tamaño **Palabra** (16 bits)  $\rightarrow$  se representa como .w (word)
- Tamaño **Doble Palabra** o Palabra Larga (16 bits) → se representa como .*I (long word)*
- Decimal BCD empaquetado (dos dígitos BCD por byte)

| <u>Palabra</u> | Memoria (Ordenación Big-Endian) |               | \$000000 7Byte       | 0 (8 bits)     |
|----------------|---------------------------------|---------------|----------------------|----------------|
| \$000000       | Byte \$000000                   | Byte \$000001 |                      |                |
| \$000002       | Byte \$000002 Byte \$000003     |               |                      | 0 (16 bits)    |
|                |                                 |               | \$000000 Doble Palab | ra 0 (32 bits) |
| \$FFFFE        | Byte \$FFFFFE                   | Byte \$FFFFFF | \$000000 BCD 0 0     | 2 dígitos)     |
|                |                                 |               |                      |                |

#### Registros de la arquitectura



#### 

- > Para operaciones con datos
- Tamaños: .b, .w, .l

#### □ Registros de direcciones (A0-A6)

- > Para operaciones con direcciones
- Tamaños: .w, .l

#### 

- Uno para usuario (A7=USP)
- Otro para supervisor (A7'=SSP)

#### 

- Parte más significativa: sólo accesible en modo supervisor
- Parte menos significativa: códigos de condición (CCR)

#### 

Apunta a la siguiente instrucción a ejecutar

estructura y tecnología de computadores

. . . . . . .

34

# 5. ejemplos: MC68000

#### Registro de estado (SR)



#### Códigos de condición

#### C ("Carry" o acarreo)

Se activa cuando se produce un arrastre de suma o de resta

#### V ("oVerflow" o desbordam.)

Se activa cuando el resultado de una operación no se puede expresar en C'2 dentro del tamaño seleccionado

### Z ("Zero" o cero)

Se activa cuando el resultado de una operación es cero

### N (Negativo)

Se activa cuando el resultado de una operación es negativo

#### X (eXtensión)

Se activa cuando hay arrastre decimal en operaciones BCD

#### Modos de direccionamiento

| Modo de direccionamiento                          | Cálculo de EA                      | Sintaxis                 |
|---------------------------------------------------|------------------------------------|--------------------------|
| Direccionamiento directo de registro              |                                    |                          |
| Directo de registro de datos                      | EA = Dn                            | Dn                       |
| Directo de registro de direcciones                | EA = An                            | An                       |
| Direccionamiento indirecto de registro            |                                    |                          |
| Indirecto de registro                             | EA = (An)                          | (An)                     |
| Indirecto de registro con postincremento (*)      | $EA = (An); An + N \rightarrow An$ | (An)+                    |
| Indirecto de registro con predecremento (*)       | $An + N \rightarrow An; EA = (An)$ | -(An)                    |
| Indirecto de registro con desplazamiento          | $EA = (An) + d_{16}$               | d <sub>16</sub> (An)     |
| Indirecto de registro indexado con desplazamiento | $EA = (An) + (Ri) + d_8$           | d <sub>8</sub> (An,Ri.X) |
| Direccionamiento absoluto                         |                                    |                          |
| Absoluto corto                                    | EA = XXXX                          | XXXX                     |
| Absoluto largo                                    | EA = XXXXXX                        | XXXXXX                   |
| Direccionamiento relativo al contador de programa |                                    |                          |
| Relativo al PC con desplazamiento                 | $EA = (PC) + d_{16}$               | d <sub>16</sub> (PC)     |
| Relativo al PC indexado con desplazamiento        | $EA = (PC) + (Ri) + d_8$           | d <sub>8</sub> (PC,Ri.X) |
| Direccionamiento inmediato                        | Operando = XXXXXXXX                | #XXXXXXXX                |

NOTAS
EA = Dirección Efectiva
Dn = Registro de datos
An = Registro de direcciones
N = 1 si .B, 2 si .W, 4 si .L

 $\begin{aligned} &\text{Ri} = \text{Registro indice (de datos o direcc.)} \\ &\text{d}_8 = \text{Desplazamiento de 8 bits} \\ &\text{d}_{16} = \text{Desplazamiento de 16 bits} \\ &\text{PC} = \text{Contador de Programa} \end{aligned}$ 

estructura y tecnología de computadores

36

# 5. ejemplos: MC68000

#### Formato de las instrucciones

- - > Instrucciones de 0, 1 y 2 operandos
  - 9 formatos distintos
  - > Longitud entre 1 y 5 palabras
- De Contenidos de una instrucción máquina
  - > Palabra operación (OW, siempre presente)
    - > Primera palabra de la instrucción
      - √ Código de operación
      - ✓ Modos de direccionamiento y tamaño de los operandos
  - ➤ Palabras de extensión (EW, de 0 a 4)
    - > Información adicional de los operandos
      - √ Valor inmediato
      - ✓ Desplazamiento
- De Codificación modos de direccionamiento
  - > Dos campos: *Modo* y *Registro* (6 bits)

#### Formato genérico de la instrucción máquina

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1

OW: Palabra operación( opcode, tamaño, EA)

EW para operando inmediato (si existe, una o dos palabras)

EW para dirección efectiva fuente (si existe, una o dos palabras)

EW para dirección efectiva destino (si existe, una o dos palabras)

### Instrucciones de 0 operandos

Sintáxis: OP

#### Instrucciones de 1 operando

Sintáxis: OP destino

Operación: destino - OP (destino)

### Instrucciones de 2 operando

Sintáxis: OP fuente, destino

Operación: destino ¬ (fuente) OP (destino)

#### Formato de las instrucciones (cont.)

|                                       |      | EA              |
|---------------------------------------|------|-----------------|
| Codificación de los modos de          | modo | Registro        |
| direccionamiento                      |      |                 |
| Directo de reg. de datos              | 000  | Nº de reg. (Dn) |
| Directo de reg. de direcciones        | 001  | Nº de reg. (An) |
| Indirecto de reg.                     | 010  | Nº de reg. (An) |
| Indirecto de reg. con postincremt.    | 011  | Nº de reg. (An) |
| Indirecto de reg. con predecrem.      | 100  | Nº de reg. (An) |
| Indirecto de reg. con desplaz.        | 101  | Nº de reg. (An) |
| Indirecto de reg. Index. con desplaz. | 110  | Nº de reg. (An) |
| Absoluto corto                        | 111  | 000             |
| Absoluto largo                        | 111  | 001             |
| Relativo al PC con desplaz.           | 111  | 010             |
| Relativo al PC index. con desplaz.    | 111  | 011             |
| Inmediato                             | 111  | 100             |

#### Instrucciones sin operandos (1 formato)



#### Instrucciones con un operando (2 formatos)



estructura y tecnología de computadores

38

# 5. ejemplos: MC68000

#### Formato de las instrucciones (cont.)

Instrucciones con 2 operandos (3 formatos)



Instrucciones de dos operandos con operando inmediato corto (2 formatos)



Instrucciones de bifurcación condicional (Bcc, 1 formato)



### Repertorio de instrucciones

### Notación utilizada

#### CÓDIGOS DE CONDICIÓN:

- Afectado.
- No afectado.
0 Puesto a 0 (clear).
1 Puesto a 1 (set).
U No definido.

| Modo de                  |    |     |     | Categorí | as de EA |      |      |      |
|--------------------------|----|-----|-----|----------|----------|------|------|------|
| direccionamiento         | ea | dea | mea | cea      | aea      | adea | amea | acea |
| Dn                       | Х  | Χ   |     |          | Χ        | Х    |      |      |
| An                       | Χ  |     |     |          | Χ        |      |      |      |
| (An)                     | Χ  | Χ   | Χ   | Χ        | Χ        | Χ    | Χ    | Χ    |
| (An)+                    | X  | X   | X   |          | X        | Χ    | Χ    |      |
| -(An)                    | X  | X   | X   |          | Χ        | X    | X    |      |
| d <sub>16</sub> (Án)     | X  | X   | X   | X        | X        | Χ    | Χ    | X    |
| d <sub>s</sub> (An,Ri.X) | X  | X   | X   | Χ        | X        | Χ    | Χ    | X    |
| XXXX                     | Χ  | Χ   | Х   | Х        | Χ        | Χ    | Χ    | Х    |
| XXXXXX                   | Χ  | Χ   | Χ   | Χ        | Χ        | Χ    | Χ    | Χ    |
| d <sub>16</sub> (PC)     | Χ  | Χ   | Χ   | Х        |          |      |      |      |
| d <sub>s</sub> (PC,Ri.X) | X  | X   | X   | X        |          |      |      |      |
| #XXXXXXXX                | Χ  | Χ   | Χ   |          |          |      |      |      |

estructura y tecnología de computadores • • • •

40

5. ejemplos: MC68000

### Repertorio de instrucciones

### MOVIMIENTO DE DATOS

| Mnemotécnico | Sintaxis                                                                              | Tamaño | Función                                     | XNZVC   |
|--------------|---------------------------------------------------------------------------------------|--------|---------------------------------------------|---------|
| EXG          | EXG Rm,Rn                                                                             | L      | Rm↔Rn                                       |         |
| LEA          | LEA <cea>,An</cea>                                                                    | L      | dirección fuente→An                         |         |
| LINK         | LINK An,# <d16></d16>                                                                 | No     | An→-(SP); SP→An<br>SP+d16→SP                |         |
| MOVE         | MOVE.t <ea>,<adea></adea></ea>                                                        | L,W,B  | (fuente)→destino                            | -**00   |
| MOVE from SR | MOVE SR, <adea></adea>                                                                | W      | SR→destino                                  |         |
| MOVE to CCR  | MOVE <adea>,CCR</adea>                                                                | W      | (fuente)→CCR                                | ****    |
| MOVE to SR   | MOVE <adea>,SR</adea>                                                                 | W      | IF S=1 SR→destino<br>ELSE EXCEPCIÓN         | ****    |
| MOVE USP     | MOVE USP,An                                                                           | L      | IF S=1 USP→An<br>ELSE EXCEPCIÓN             | ****    |
| MOVE USP     | MOVE An,USP                                                                           | L      | IF S=1 An→USP<br>ELSE EXCEPCIÓN             | ****    |
| MOVEA        | MOVEA.t <ea>,An</ea>                                                                  | L,W    | (fuente)→destino                            |         |
| MOVEM        | MOVEM.t <li>sta_reg&gt;,<cea><br/>MOVEM.t <lista_reg>,-(An)</lista_reg></cea></li>    | L,W    | registros→destino                           |         |
| MOVEM        | MOVEM.t <cea>,<lista_reg><br/>MOVEM.t (An)+,<lista_reg></lista_reg></lista_reg></cea> | L,W    | (fuente)→registros                          |         |
| MOVEP        | MOVEP.t Dn,d(Am)<br>MOVEP.t d(Am),Dn                                                  | L,W    | (fuente)→destino                            |         |
| MOVEQ        | MOVEQ # <d8>,Dn</d8>                                                                  | L      | dato (8 bits)→destino                       | -**00   |
| PEA          | PEA <cea></cea>                                                                       | L      | dirección →-(SP)                            |         |
| SWAP         | SWAP Dn                                                                               | W      | Dn[31:16]↔Dn[15:0]                          | - **0 0 |
| UNLK         | UNLK An                                                                               | No     | $An \rightarrow SP$ ; $(SP)+\rightarrow An$ |         |

#### ARITMÉTICA ENTERA

| Mnemotécnico | Sintaxis                             | Tamaño | Función                       | XNZVC     |
|--------------|--------------------------------------|--------|-------------------------------|-----------|
| ADD          | ADD.t <ea>,Dn</ea>                   | L,W,B  | (fuente)+(destino)→destino    |           |
|              | ADD.t Dn, <amea></amea>              |        | . , , ,                       |           |
| ADDA         | ADDA.t <ea>&gt;,An</ea>              | L,W    | (fuente)+(destino)→destino    |           |
| ADDI         | ADDI.t # <dato>,<adea></adea></dato> | L,W,B  | Dato+(destino)→destino        |           |
| ADDQ         | ADDQ.t# <d3>, <aea></aea></d3>       | L,W,B  | d3+(destino)→destino          |           |
| ADDX         | ADDX.t Dm,Dn o                       | L,W,B  | (fuente)+(destino)+X→destino  |           |
|              | ADDX.t -(Am),-(An)                   |        | , , , , ,                     |           |
| CLR          | CLR.t <adea></adea>                  | L,W,B  | 0→destino                     | -0100     |
| CMP          | CMP.t <ea>,Dn</ea>                   | L,W,B  | (destino)-(fuente);activa CCR | -***      |
| CMPA         | CMPA.t <ea>,An</ea>                  | L,W    | (destino)-(fuente);activa CCR | -***      |
| CMPI         | CMPI.t # <dato>,<adea></adea></dato> | L,W,B  | (destino)-Dato; activa CCR    | - * * * * |
| СМРМ         | CMPM.t (Am)+,(An)                    | L,W,B  | (destino)-(fuente);activa CCR | -****     |
| DIVS         | DIVS <dea>,Dn</dea>                  | W      | (destino)/(fuente) → destino; | -***0     |
|              |                                      |        | Cociente→destino[15:0],       |           |
|              |                                      |        | Resto→destino[31:16]          |           |
| DIVU         | DIVU <dea>,Dn</dea>                  | W      | (destino)/(fuente) → destino; | - * * * 0 |
|              |                                      |        | Cociente→destino[15:0],       |           |
|              |                                      |        | Resto→destino[31:16]          |           |
| EXT          | EXT.t Dn                             | L,W    | Dn(Extend en signo)→Dn        | - * * 0 0 |
| MULS         | MULS <dea>,Dn</dea>                  | W      | (fuente)*(destino)→destino    | -**00     |
| MULU         | MULU <dea>,Dn</dea>                  | W      | (fuente)*(destino)→destino    | -**00     |
| NEG          | NEG.t <adea></adea>                  | L,W,B  | 0-(destino)->destino          |           |
| NEGX         | NEGX.t <adea></adea>                 | L,W,B  | 0-(destino)-X→destino         | ****      |
| SUB          | SUB.t <ea>,Dn</ea>                   | L,W,B  | (destino)-(fuente)-destino    |           |
|              | SUB.t Dn, <amea></amea>              |        | , , , , , ,                   |           |
| SUBA         | SUBA.t <ea>,An</ea>                  | L,W    | (destino)-(fuente)->destino   |           |
| SUBI         | SUBI.t # <dato>,<adea></adea></dato> | L,W,B  | (destino)-Dato→destino        |           |
| SUBQ         | SUBQ.t# <d3>, <aea></aea></d3>       | L,W,B  | (destino)-d3→destino          | ****      |
| SUBX         | SUBX.t Dm,Dn                         | L,W,B  | (destino)-(fuente)-X→destino  |           |
|              | SUBX.t -(Am),-(An)                   |        |                               |           |
| TAS          | TAS <adea></adea>                    | В      | Test (destino)→CCR;           | -**00     |
|              |                                      |        | 1→destino[bit 7]              |           |
| TST          | TST <adea></adea>                    | L.W.B  | Test (destino)→CCR            | -**00     |

estructura y tecnología de computadores

42

# 5. ejemplos: MC68000

#### OPERACIONES LÓGICAS

| Mnemotécnico | Sintaxis                                        | Tamaño | Función                                        | XNZVC     |
|--------------|-------------------------------------------------|--------|------------------------------------------------|-----------|
| AND          | AND.t <dea>,Dn<br/>AND.t Dn,<amea></amea></dea> | L,W,B  | (fuente) <and>(destino)→destino</and>          | -**00     |
| ANDI         | ANDI.t # <dato>,<adea></adea></dato>            | L,W,B  | dato <and>(destino)→destino</and>              | - * * 0 0 |
| ANDI to CCR  | ANDI # <d8>,CCR</d8>                            | В      | d8 <and>CCR →CCR</and>                         | * * * * * |
| ANDI to SR*  | ANDI # <d16>,SR</d16>                           | W      | IF S=1 d16 <and>SR→SR<br/>ELSE EXCEPCIÓN</and> | ****      |
| EOR          | EOR.t Dn, <adea></adea>                         | L,W,B  | (fuente) <xor>(destino)→destino</xor>          | -**00     |
| EORI         | EORI.t # <dato>,<adea></adea></dato>            | L,W,B  | dato <xor>(destino)→destino</xor>              | -**00     |
| EORI to CCR  | EORI # <d8>,CCR</d8>                            | В      | d8 <xor>CCR →CCR</xor>                         | ****      |
| EORI to SR*  | EORI # <d16>,SR</d16>                           | W      | IF S=1 d16 <xor>SR→SR<br/>ELSE EXCEPCIÓN</xor> | ****      |
| NOT          | NOT.t <adea></adea>                             | L,W,B  | <not>(destino)→destino</not>                   | - * * 0 0 |
| OR           | OR.t <dea>,Dn<br/>OR.t Dn,<amea></amea></dea>   | L,W,B  | (fuente) <or>(destino)→destino</or>            | -**00     |
| ORI          | ORI.t # <dato>, <adea></adea></dato>            | L,W,B  | dato <or>(destino)→destino</or>                | -**00     |
| ORI to CCR   | ORI # <d8>,CCR</d8>                             | В      | d8 <or>CCR→CCR</or>                            | * * * * * |
| ORI to SR*   | ORI # <d16>,SR</d16>                            | W      | IF S=1 d16 <or>SR→SR<br/>ELSE EXCEPCIÓN</or>   | ****      |

#### DESPLAZAMIENTOS Y ROTACIONES

| Mnemotécnico | Sintaxis                                | Tamaño                  | Función                                                        | XNZVC |
|--------------|-----------------------------------------|-------------------------|----------------------------------------------------------------|-------|
| ASL/ASR      | ASL/ASR Dm,Dn<br>ASL/ASR # <d3>,Dn</d3> | L,W,B                   | (destino) desplaz. aritmet. de<br><num> bits→destino</num>     | ****  |
| ASL/ASR      | ASL/ASR <amea></amea>                   | W (contador desplaz.=1) | (destino) desplaz. aritmet. de<br>1 bit →destino               | ****  |
| LSL/LSR      | Igual que ASL/ASR                       | Idem                    | (destino) desplaz. logico de<br><num> (o 1)bits→destino</num>  | ***0* |
| ROL/ROR      | Igual que ASL/ASR                       | Idem                    | (destino) rotado<br><num> (o 1)bits→destino</num>              | -**0* |
| ROXL/ROXR    | Igual que ASL/ASR                       | Idem                    | (destino) rotado (con exten.)<br><num> (o 1)bits→destino</num> | ***0* |

#### MANIPULACIÓN DE BITS

| Mnemotécnico | Sintaxis                       | Tamaño         | Función                                | XNZVC |
|--------------|--------------------------------|----------------|----------------------------------------|-------|
| BCHG         | BCHG Dm,Dn o                   | L (bit mod 32) | <not>(destino[bit])→flag Z;</not>      | *     |
|              | BCHG # <d8>,Dn</d8>            |                | <not>(destino[bit])→destino[bit]</not> |       |
| BCHG         | BCHG Dm, <amea> o</amea>       | B (bit mod 8)  | Igual                                  | *     |
|              | BCHG # <d8>,<amea></amea></d8> |                |                                        |       |
| BCLR         | Igual que BCHG                 |                | <not>(destino[bit])→flag Z;</not>      | *     |
|              |                                |                | 0→destino[bit]                         |       |
| BSET         | Igual que BCHG                 |                | <not>(destino[bit])→flag Z;</not>      | *     |
|              |                                |                | 1 → destino[bit]                       |       |
| BTST         | BTST Dm,Dn o                   | L (bit mod 32) | <not>(destino[bit])→flag Z</not>       | *     |
|              | BTST # <d8>,Dn</d8>            |                |                                        |       |
| BTST         | BTST Dm, <mea> o</mea>         | B (bit mod 8)  | Igual                                  | *     |
|              | BTST # <d8>,<mea></mea></d8>   |                |                                        |       |

### OPERACIONES DE CONTROL DE PROGRAMA

| Mnemotécnico | Sintaxis                      | Tamaño             | Función                                                                      | XNZVC     |
|--------------|-------------------------------|--------------------|------------------------------------------------------------------------------|-----------|
| Bcc          | Bcc <etiqueta></etiqueta>     | Desplaz. 16 bits   | IF cc True PC+despl.→PC                                                      |           |
| Bcc.S        | Bcc.S <etiqueta></etiqueta>   | Desplaz. 8 bits    | IF cc True PC+despl.→PC                                                      |           |
| BRA          | BRA <etiqueta></etiqueta>     | Despl. 8 o 16 bits | PC+desp.→PC                                                                  |           |
| BSR          | BSR <etiqueta></etiqueta>     | Despl. 8 o 16 bits | PC→-(SP); PC+desp.→PC                                                        |           |
| DBcc         | DBccDm, <etiqueta></etiqueta> | Desplaz. 16 bits   | IF cc False Dm-1 → Dm IF Dm $\neq$ -1 PC+desp.→PC ELSE PC+2→PC (instr. sig.) |           |
| JMP          | JMP <cea></cea>               | No                 | destino→PC                                                                   |           |
| JSR          | JSR <cea></cea>               | No                 | PC→-(SP); destino→PC                                                         |           |
| Scc          | Scc <adea></adea>             | В                  | IF cc True \$FF→destino<br>ELSE \$00 →destino                                |           |
| RTR          | RTR                           | No                 | (SP)+→CCR; (SP)+→PC                                                          | * * * * * |
| RTS          | RTS                           | No                 | (SP)+→PC                                                                     |           |

estructura y tecnología de computadores

44

5. ejemplos: MC68000

#### OPERACIONES EN BCD

| Mnemotécnico | Sintaxis                       | Tamaño | Función                                                                      | XNZVC     |
|--------------|--------------------------------|--------|------------------------------------------------------------------------------|-----------|
| ABCD         | ABCD Dm,Dn<br>ABCD -(Am),-(An) | В      | (fuente <sub>10</sub> )+(destino <sub>10</sub> )+X→<br>destino <sub>10</sub> | * U * U * |
| NBCD         | NBCD <adea></adea>             | В      | 0-(destino <sub>10</sub> )-X→destino <sub>10</sub>                           | * U * U * |
| SBCD         | SBCD Dm,Dn<br>SBCD -(Am),-(An) | В      | (fuente <sub>10</sub> )–(destino <sub>10</sub> )–X→<br>destino <sub>40</sub> | * U * U * |

#### OPERACIONES DE CONTROL DEL SISTEMA

| Mnemotécnico | Sintaxis           | Tamaño | Función                                                                     | XNZVC   |
|--------------|--------------------|--------|-----------------------------------------------------------------------------|---------|
| RESET*       | RESET              | No     | IF S=1 activa RESET<br>ELSE EXCEPCIÓN                                       |         |
| RTE*         | RTE                | No     | IF S=1 (SP)+→SP;(SP)+→PC<br>ELSE EXCEPCIÓN                                  | ****    |
| STOP*        | STOP # <d16></d16> | No     | IF S=1 d16→SR;PC+4→PC;<br>Pausa hasta excepcion<br>ELSE EXCEPCIÓN           | ****    |
| СНК          | CHK <dea>,Dn</dea> | W      | IF Dn<0 OR Dn>(fuente)<br>EXCEPCIÓN                                         | - * UUU |
| ILLEGAL      | ILLEGAL            | No     | $PC \rightarrow -(SSP);SR \rightarrow -(SSP)$<br>Vector #4 $\rightarrow$ PC |         |
| TRAP         | TRAP # <d4></d4>   | No     | PC→-(SSP);SR→-(SSP)<br>Vector #4→PC                                         |         |
| TRAPV        | TRAPV              | No     | IF V=1 EXCEPCIÓN                                                            |         |
| NOP          | NOP                | No     | PC+2→PC                                                                     |         |

# 5. ejemplos: arquitectura MIPS

#### Características generales

- Procesador RISC de 32 bits
  - > ~70 instrucciones máquina
    - ⇒ Repertorio ortogonal
    - ⇒ Instrucciones clasificadas en cuatro grupos

      - ✓ Movimiento de datos✓ Aritmética entera, logicas y desplazamiento

      - ✓ Control de flujo ✓ Aritmética en punto flotante
  - > 4 modos de direccionamiento
    - ⇒ Inmediato
    - ⇒ Directo de registros
    - ⇒ Indirecto con desplazamiento
    - ⇒ Indirecto con desplazamiento relativo al PC
  - > Banco de 64 registros (32 bits cada uno)
    - ⇒ 32 de propósito general (R0-R31)
    - ⇒ 32 para instrucciones en punto flotante (F0-F31). Pueden usarse como:
      - 32 registros para operaciones en simple precisión (32 bits)
         16 registros para operaciones en doble precisión (64 bit)
  - > 3 formatos de instrucción distintos con longitud única de 32 bits
  - Arquitectura registro-registro
    - ⇒ Sólo las instrucciones de LOAD y STORE hacen referencia a memoria
    - ⇒ El resto de instrucciones operan sobre registros
      - Instrucciones con tres operandos: 2 op. fuente y 1 op. Destino
      - Notación ensamblador: op x, y, z  $x \leftarrow (y)$  op (z)

estructura y tecnología de computadores

# 5. ejemplos: arquitectura MIPS

### Tipos de datos

#### 

46

- > Tamaño Byte (8 bits)
- > Tamaño Media palabra (16 bits)
- > Tamaño Palabra (32 bits)

### 

- > Simple precisión (32 bits)
- > Doble precisión (64 bits)

|                         | Memoria (Ordenación Little-Endian)   |                                      | Bit signo                                    |
|-------------------------|--------------------------------------|--------------------------------------|----------------------------------------------|
| <u>Palabra</u>          | Media palabra \$0                    | Media palabra \$2                    | \$0 [ <u>0</u> ::::::: <del>7</del> ]        |
| \$00000000<br>\$0000004 | Byte \$0 Byte \$1  Byte \$4 Byte \$5 | Byte \$2 Byte \$3  Byte \$6 Byte \$7 | \$0 [0:::::::::::::::::::::::::::::::::::    |
| \$0000004               | Media palabra \$4                    | . Media palabra \$6                  | Palabra \$0 (32 bits) \$0 0 31               |
|                         |                                      | ·<br>·                               | Real Simple precisión \$0 (32 bits) \$0 0 31 |
| \$FFFFFFC               |                                      |                                      | Real Doble Precisión \$0 (64 bits)           |

48

# 5. ejemplos: arquitectura MIPS

#### Modos de direccionamiento



# 5. ejemplos: arquitectura MIPS

### Formato de la instrucción máquina



# 5. ejemplos: arquitectura MIPS

## Repertorio de instrucciones

### Instrucción de movimiento de datos

| Instrucción | Significado             | Ejemplo |              | Operación                                                                                                                     |
|-------------|-------------------------|---------|--------------|-------------------------------------------------------------------------------------------------------------------------------|
| LB          | Load byte               | LB      | \$2, 40(\$3) | $ \text{R2 [24-31]} \leftarrow \text{Mem(40+(R3))}_8; \ \text{R1[0-23]} \leftarrow (\text{signo}(\text{Mem(40+(R3))}))^{24} $ |
| LBU         | Load byte unsigned      | LBU     | \$2, 40(\$3) | R2 [24-31] $\leftarrow$ Mem(40+(R3)) <sub>8</sub> ; R1[0-23] $\leftarrow$ (0) <sup>24</sup>                                   |
| LH          | Load half word          | LH      | \$2, 40(\$3) | R2 [16-31] $\leftarrow$ Mem(40+(R3)) <sub>16</sub> ; R1[0-15] $\leftarrow$ (signo(Mem(40+(R3)))) <sup>16</sup>                |
| LHU         | Load half word unsigned | LHU     | \$2, 40(\$3) | R2 [16-31] $\leftarrow$ Mem(40+(R3)) <sub>16</sub> ; R1[0-15] $\leftarrow$ (0) <sup>16</sup>                                  |
| LW          | Load word               | LW      | \$2, 40(\$3) | R2 [0-31] $\leftarrow$ Mem(40+(R3)) <sub>32</sub>                                                                             |
| LF          | Load Float              | LF      | \$2, 40(\$3) | F2 [0-31] $\leftarrow$ Mem(40+(R3)) <sub>32</sub>                                                                             |
| LD          | Load double float       | LD      | \$2, 40(\$3) | F2 [0-31], F3 [0-31] $\leftarrow$ Mem(40+(R3)) <sub>64</sub>                                                                  |
| SB          | Store byte              | SB      | 40(\$3),\$2  | $Mem(40+(R3))_8 \leftarrow R2 [24-31]$                                                                                        |
| SH          | Store half word         | SB      | 40(\$3),\$2  | $Mem(40+(R3))_{16} \leftarrow R2 [16-31]$                                                                                     |
| SW          | Store word              | SB      | 40(\$3),\$2  | $Mem(40+(R3))_{32} \leftarrow R2 [0-31]$                                                                                      |
| SF          | Store float             | SB      | 40(\$3),\$2  | $Mem(40+(R3))_{32} \leftarrow F2 [0-31]$                                                                                      |
| SD          | Store double float      | SB      | 40(\$3),\$2  | $Mem(40+(R3))_{64} \leftarrow F2 [0-31], F3 [0-31]$                                                                           |

estructura y tecnología de computadores • • • •

50

# 5. ejemplos: arquitectura MIPS

### Repertorio de instrucciones

### Instrucción de aritmética entera, lógicas y desplazamiento

| Instrucción                     | Significado                        | Ejemplo          | Operación                                                   |  |
|---------------------------------|------------------------------------|------------------|-------------------------------------------------------------|--|
| ADD/ADDU                        | Suma con/sin signo                 | ADD \$1,\$2,\$3  | R1 ← (R2) + (R3)                                            |  |
| ADDI/ADDIU                      | Suma inmediato con/sin signo       | ADDI \$1,\$2,#5  | R1 ← (R2) + 5                                               |  |
| SUB/SUBU                        | Resta con/sin signo                | SUB \$1,\$2,\$3  | R1 ← (R2) - (R3)                                            |  |
| SUBI/SUBIU                      | Resta inmediato con/sin signo      | SUBI \$1,\$2,#5  | R1 ← (R2) - 5                                               |  |
| MULT/MULTU                      | Multiplicación con/sin signo       | MULT \$1,\$2,\$3 | $R1 \leftarrow (R2) * (R3)$                                 |  |
| DIV/DIVU                        | División con/sin signo             | DIV \$1,\$2,\$3  | R1[0-15] ← Cociente ((R2) / (R3))                           |  |
|                                 |                                    |                  | R1[16-31] ← Resto ((R2) mod (R3))                           |  |
| AND                             | Y lógica                           | AND \$1,\$2,\$3  | $R1 \leftarrow (R2) \text{ AND } (R3)$                      |  |
| ANDI                            | Y lógica con inmediato             | ANDI \$1,\$2,#5  | R1 ← (R2) AND 5                                             |  |
| OR                              | O lógica                           | OR \$1,\$2,\$3   | R1 ← (R2) OR (R3)                                           |  |
| ORI                             | O lógica con inmediato             | ORI \$1,\$2,#5   | R1 ← (R2) OR 5                                              |  |
| XOR                             | O exclusiva                        | XOR \$1,\$2,\$3  | R1 ← (R2) XOR (R3)                                          |  |
| XORI                            | O exclusiva con inmediato          | XORI \$1,\$2,#5  | R1 ← (R2) XOR 5                                             |  |
| SLL/SRL                         | Desplaz. lógico Izda./decha.       | SLL \$1,\$2,\$3  | $R1 \leftarrow (R2) \ll (R3)$                               |  |
| SLLI/SRLI                       | Desp. Lóg. Izda./decha. con inmed. | SLLI \$1,\$2,#4  | $R1 \leftarrow (R2) \ll 4$                                  |  |
| SRA                             | Desplaz. aritmético derecha        | SRA \$1,\$2,\$3  | R1 ← (R2) << (R3) (mantiene signo)                          |  |
| SRAI                            | Desplaz. aritm. Dcha. con inmed.   | SRA \$1,\$2,#4   | R1 ← (R2) << 4 (mantiene signo)                             |  |
| Scc *                           | Set condicional                    | SLT \$1,\$2,\$3  | if (R2)<(R3) then R1 $\leftarrow$ 1, else R1 $\leftarrow$ 0 |  |
| Sccl *                          | Set condicional con inmediato      | SEQI \$1,\$2,#0  | if (R2) = 0 then R1 $\leftarrow$ 1, else R1 $\leftarrow$ 0  |  |
| (A) I T. OT I F. OF FO NE       |                                    |                  |                                                             |  |
| (*) cc = LT, GT, LE, GE, EQ, NE |                                    |                  |                                                             |  |

# 5. ejemplos: arquitectura MIPS

### Repertorio de instrucciones

## Instrucción de control de flujo

| Instrucción | Significado                             | Ejemplo        | Operación                                       |
|-------------|-----------------------------------------|----------------|-------------------------------------------------|
| J           | Salto (jump)                            | J dir          | $PC \leftarrow dir$                             |
| JR          | Salto con registro                      | JR \$2         | $PC \leftarrow (R2)$                            |
| BEQZ        | Bifurcación condic. si igual a cero     | BEQZ dir, \$4  | if $(R4) = 0$ then $PC \leftarrow (R4)$         |
| BNEQZ       | Bifurcación condic. si distinto de cero | BNEQZ dir, \$4 | if $(R4) \neq 0$ then $PC \leftarrow (R4)$      |
| JAL         | Salto y link                            | JAL dir        | $R31 \leftarrow (PC) + 4$ ; $PC \leftarrow dir$ |
| JALR        | Salto y link con registro               | JALR dir, \$2  | $R31 \leftarrow (PC) + 4; PC \leftarrow (R2)$   |
| TRAP        | Provoca una excepción                   |                |                                                 |
| RFE         | Retorno de excepción                    |                |                                                 |

## Instrucción de aritmética en punto flotante

| Instrucción   | Significado                                                     |
|---------------|-----------------------------------------------------------------|
| ADDF/ADDD     | Suma en punto flotante simple/doble precisión                   |
| SUBF/SUBD     | Resta en punto flotante simple/doble precisión                  |
| MULTF/MULTD   | Multiplicación en punto flotante simple/doble precisión         |
| DIVF/DIVD     | División en punto flotante simple/doble precisión               |
| CVTI2F/CVTI2D | Convierte entero a real simple precisión / doble precisión      |
| CVTF2I/CVTF2D | Convierte real simple precisión a entero / real doble precisión |
| CVTD2I/CVTD2F | Convierte real doble precisión a entero / real simple precisión |