# Introducción al diseño de procesadores.

## ¿Qué necesito para comenzar el diseño de un procesador?

Primero vamos a establecer las instrucciones básicas que va a manejar.

| Instrucciones de carga y almacenamiento |                                      |                     |      |  |
|-----------------------------------------|--------------------------------------|---------------------|------|--|
| Instr.                                  | Sintaxis                             | Significado         | Tipo |  |
| LD                                      | LD ACCx, #n                          | ACCx = n            | I    |  |
|                                         | LD ACCx, dir                         | ACCx = [dir]        | D    |  |
| ST                                      | ST ACCx, dir                         | [dir] = ACCx        | D    |  |
|                                         | Instrucci                            | ones aritméticas    |      |  |
| ADD                                     | ADD ACCx                             | ACCx = ACCA+ACCB    | R    |  |
|                                         | ADD ACCx, #n                         | ACCx = ACCx+n       | I    |  |
|                                         | ADD ACCx, dir                        | ACCx = ACCx+[dir]   | D    |  |
| SUB                                     | SUB ACCx                             | ACCx = ACCA - ACCB  | R    |  |
|                                         | SUB ACCx, #n                         | ACCx = ACCA - n     | I    |  |
|                                         | SUB ACCx, dir                        | ACCx = ACCA - [dir] | D    |  |
|                                         | Instrucciones de salto incondicional |                     |      |  |
| В                                       | B #n                                 | PC = #n             | I    |  |

A estas instrucciones se le conoce como "Conjunto de instrucciones del lenguaje ensamblador". Los lenguajes ensambladores son diferentes de un microprocesador a otro, sin embargo, las funciones que realizan cada uno de ellos son las mismas, es decir, todos los lenguajes ensambladores tienen instrucciones de carga y almacenamiento, aritméticas y lógicas, de salto incondicional, etc.

Con estas instrucciones podemos realizar diversos programas. Por ejemplo: hacer un programa que inicie el acumulador A en 7 y lo incremente, el resultado se debe colocar en la dirección de memoria 90H.

| Versión 1    | Significado        | Versión 2    | Significado     |
|--------------|--------------------|--------------|-----------------|
| LD ACCA, #7  | ACCA = 7           | LD ACCA, #7  | ACCA = 7        |
| LD ACCB, #1  | ACCB = 1           | CICLO:       |                 |
| CICLO:       |                    | ADD ACCA, #1 | ACCA = ACCA + 1 |
| ADD ACCA     | ACCA = ACCA + ACCB | ST ACCA, 90H | [90H] = ACCA    |
| ST ACCA, 90H | [90H] = ACCA       | B CICLO      |                 |
| B CICLO      |                    |              |                 |

## ¿Cómo vamos a representar esas instrucciones para que puedan ser ejecutadas?

Para poder representarlas necesitamos definir un **formato para las instrucciones**. Este formato debe representar el tipo de instrucción (carga y almacenamiento, aritméticas, salto incondicional, etc.), sus operandos (Acumulador A ó B) y el modo de direccionamiento (tipo R, I, D). El **modo de direccionamiento** nos va a decir cuales son los operandos que puedo manejar con una instrucción del ensamblador, por ejemplo, una instrucción de suma (ADD), puede sumar dos registros, un registro y un número inmediato, un registro y una dirección de memoria (variable).

Un formato que permite representar todo esto, es el siguiente:

| 7      | 6 | 5 | 4 | 3    | 2  | 1   | 0 |
|--------|---|---|---|------|----|-----|---|
| OPCODE |   |   |   | ACCx | Mc | odo |   |

Cada formato de instrucción contiene un código de operación (OPCODE) que permite identificar una instrucción de otra. Este código esta formado por 5 bits que se encuentran de los bits 7 al 3. Con estos 5 bits podemos tener hasta 32 instrucciones diferentes en nuestro procesador. El bit 2 indica el acumulador que va a utilizar la instrucción para colocar el resultado. Bit2 con 1 significa acumulador B, con 0 significa acumulador A. Los bits 1 y 0 permiten especificar el modo de direccionamiento usado en las instrucciones. Con este formato de 8 bits podemos obtener los formatos específicos para cada modo de direccionamiento.

Formato Tipo R (Registro). No existe operando. Los operandos a usar en la instrucción se encuentran en los registros acumuladores (ACCA, ACCB). Esto quiere decir que previamente fueron almacenados los operandos en los registros acumuladores. Solo se usa un byte.



Tipo I (Inmediato). Se usa una byte para el formato de la instrucción y otro para el dato inmediato.



Tipo D (Directo). Se usa un byte para el formato de la instrucción y otro para la dirección de memoria donde se encuentra el dato a usar.



Con estos formatos de instrucción podemos representar las instrucciones con un código binario.

|             | Instruccio                | ones de carga y almacena | miento                       |      |
|-------------|---------------------------|--------------------------|------------------------------|------|
| Instrucción | Modos de direccionamiento | Significado              | Formato de<br>la instrucción | Tipo |
| LD          | LD ACCx, #n               | ACCx = n                 | 00000 A 01                   | I    |
|             | LD ACCx, dir              | ACCx = [dir]             | 00000 A 10<br>dddd dddd      | D    |
| ST          | ST ACCx, dir              | [dir] = ACCx             | 00001 A 10<br>dddd dddd      | D    |
|             |                           | nstrucciones aritméticas |                              |      |
| ADD         | ADD ACCx                  | ACCx = ACCA+ACCB         | 00010 A 00                   | R    |
|             | ADD ACCx, #n              | ACCx = ACCx+n            | 00010 A <mark>01</mark>      | I    |
|             |                           |                          | nnnn nnnn                    |      |
|             | ADD ACCx, dir             | ACCx = ACCx+[dir]        | 00010 A 10                   | D    |
|             |                           |                          | dddd dddd                    |      |
| SUB         | SUB ACCx                  | ACCx = ACCA - ACCB       | 00011 A 00                   | R    |
|             | SUB ACCx, #n              | ACCx = ACCA - n          | 00011 A <mark>01</mark>      |      |
|             |                           |                          | nnnn nnnn                    |      |
|             | SUB ACCx, dir             | ACCx = ACCA - [dir]      | 00011 A 10                   | D    |
|             |                           |                          | dddd dddd                    |      |
|             |                           | Instrucciones de saltos  |                              |      |
| В           | B #n                      | PC = #n                  | 00100 x 01                   | 1    |
|             |                           |                          | nnnn nnnn                    |      |

Con estos formatos de instrucción podemos escribir el programa del ejemplo anterior en la memoria ROM (también llamada memoria de programa) de la siguiente forma:

Versión 1 Versión 2

| Dirección  | Formato de  | Instrucción  |
|------------|-------------|--------------|
| de memoria | instrucción |              |
| 0          | 00000 0 01  | LD ACCA, #7  |
| 1          | 0000 0111   |              |
| 2          | 00000 1 01  | LD ACCB, #1  |
| 3          | 0000 0001   |              |
| 4          | 00010 0 00  | CICLO:       |
|            |             | ADD ACCA     |
| 5          | 00001 0 10  | ST ACCA, 90h |
| 6          | 1001 0000   |              |
| 7          | 00100 0 01  | B CICLO      |
| 8          | 0000 0100   |              |

| Dirección  | Formato de  | Instrucción  |
|------------|-------------|--------------|
| de memoria | instrucción |              |
| 0          | 00000 0 01  | LD ACCA, #7  |
| 1          | 0000 0111   |              |
| 2          | 00010 0 01  | CICLO:       |
|            |             | ADD ACCA, #1 |
| 3          | 0000 0001   |              |
| 4          | 00001 0 10  | ST ACCA, 90h |
| 5          | 1001 0000   |              |
| 6          | 00100 0 01  | B CICLO      |
| 7          | 0000 0010   |              |

Este conjunto de instrucciones y este formato de instrucción dan como resultado la organización mostrada en la figura 1.



Figura 1 Organización del ESCOMICRO1.

Este microprocesador lo llamamos el ESCOMICRO1 y esta formado de los bloques siguientes:

Acc A, Acc B (Acumuladores A y B). Los registros acumuladores tiene los datos con los que opera directamente la ALU. Manejan las señales LA, LB que permiten controlar la carga de datos. También las señales EA, EB que coloca el bus de salida de los acumuladores en alta impedancia o permiten habilitarlos para colocar su dato almacenado en el bus de datos y direcciones.

| LA, LB | Operación | EA, EB | Operación       |
|--------|-----------|--------|-----------------|
| 0      | Retención | 0      | Alta impedancia |
| 1      | Carga     | 1      | Habilitación    |

**ALU (Unidad Aritmética y Lógica)**. Se encarga de las operaciones básicas de suma y resta. Maneja la señal Binvert que permite seleccionar la operación de suma o resta de los valores que contengan los acumuladores. También la señal EU que coloca el bus de salida de la ALU en alta impedancia o permite colocar su dato en el bus de datos y direcciones.

| BINVERT | Operación           | EU | Operación       |
|---------|---------------------|----|-----------------|
| 0       | Suma (ACCA + ACCB)  | 0  | Alta impedancia |
| 1       | Resta (ACCA - ACCB) | 1  | Habilitación    |

**PC (Contador de Programa).** El PC tiene la dirección de la siguiente instrucción a ejecutar por el microprocesador. Su función es la de emitir direcciones de memoria. Maneja la señal IPC que permite habilitar el conteo ascendente desde 0 hasta 255 (8 bits). También la señal EPC que coloca el bus de salida del PC en alta impedancia o permite colocar su dirección en el bus de datos y direcciones.

| IPC | Operación         | EPC | Operación       |
|-----|-------------------|-----|-----------------|
| 0   | Retención         | 0   | Alta impedancia |
| 1   | Conteo Ascendente | 1   | Habilitación    |

**IR (Registro de Instrucciones).** Este registro es donde se tiene que almacenar la instrucción tomada de memoria durante la fase de búsqueda de la instrucción denominada FETCH. Manejan la señal LIR que permite controlar la carga de la instrucción a ejecutar.

| LIR | Operación |
|-----|-----------|
| 0   | Retención |
| 1   | Carga     |

AR (Registro Auxiliar). Los registros auxiliares, siempre numerosos en cualquier microprocesador. Este registro sirve como depósito momentáneo de los datos usados en las microinstrucciones usadas en las instrucciones tipo D. Manejan la señal LAR que permite controlar la carga de datos. También la señales EAR que coloca el bus de salida del registro en alta impedancia o permite habilitarlo para colocar su dato almacenado en el bus de datos y direcciones.

| LAR | Operación | EAR | Operación       |
|-----|-----------|-----|-----------------|
| 0   | Retención | 0   | Alta impedancia |
| 1   | Carga     | 1   | Habilitación    |

MAR. (Registro de Direcciones de Memoria). Este registro es necesario sólo cuando nos encontremos en presencia de un microprocesador con un solo BUS para datos y direcciones (compartido). Con este tipo de bus, resulta evidente que no es posible usar el mismo BUS al mismo tiempo para los datos y para las direcciones. El registro MAR resuelve exactamente este problema ya que almacena la dirección que se va acceder por las memorias. Manejan la señal LM que permite controlar la carga de la dirección a decodificar.

| LM | Operación |
|----|-----------|
| 0  | Retención |
| 1  | Carga     |

**Unidad de Control.** Es la encargada de realizar la decodificación de la instrucción, es decir, analizar el código de operación para determinar la instrucción, su acumulador operando y el tipo de modo de direccionamiento. Una vez decodificada la instrucción genera las microinstrucciones en las fases de ejecución adecuadas para ejecutar cada instrucción del ensamblador. Este bloque activa TODAS las señales de cada bloque del procesador (Acumuladores, ALU, PC, IR, AR, MAR, Decodificador y memorias).

## Decodificador

Decodifica las direcciones de memoria para activar las señales de habilitación (CS) de cada memoria dependiendo de los rangos de direcciones asignadas a la memoria ROM, RAM o periféricos. También habilita la carga en los registros que funcionan como puertos de salida. Maneja la señal WMA (Valid Memory Address) que permite establecer cuando una dirección dentro del registro MAR es válida para su decodificación. También maneja la señal RW que permite seleccionar una operación de lectura o escritura en las memorias ROM o RAM y en los puertos.

| VMA | Operación           | RW | Operación |
|-----|---------------------|----|-----------|
| 0   | Dirección no válida | 0  | Escritura |
| 1   | Dirección válida    | 1  | Lectura   |

### **Memoria ROM**

Esta memoria se le denomina memoria de programa y es la encargada de contener las instrucciones a ejecutar por el microprocesador, esta mapeada en la parte baja del mapa de memoria en el rango de direcciones de 00H-7FH. Maneja un bus de direcciones de 7 bits (A6, ..., A0) y un bus de datos de 8 bits (D7, ..., D0), por lo que su organización es de 128 x 8.

### Memoria RAM

Esta memoria se le denomina memoria de datos y es la encargada de contener las variables usadas por las instrucciones del ensamblador en el microprocesador, esta mapeada en la parte media baja del mapa de memoria en el rango de direcciones de 80H-BFH. Maneja un bus de direcciones de 6 bits (A5, ..., A0) y un bus de datos de 8 bits (D7, ..., D0), por lo que su organización es de 64 x 8.

#### **Puertos**

Son dos registros mapeados en la parte alta del mapa de memoria, en las direcciones FFh y FEh, y están diseñados para manejar dos puertos de 8 bits de salida para el manejo de periféricos. Manejan las señales LP1, LP2 que permiten controlar la carga de datos.

LP1, LP2 Operación 0 Retención 1 Carga

Todas las señales etiquetadas como LA, LB, LPC, IPC, LAR, LM, LIR, RW (en la memoria RAM) son señales síncronas, es decir, su función se lleva a cabo cuando llega el flanco activo de la señal de reloj. Las señales EA, EB, EU, EPC, EAR, VMA, RW (en el decodificador) son señales asíncronas.