

17-10-2019

## Estructura de Computadores

# Contenido

| Ejerd | icio 1:                               | . 2 |
|-------|---------------------------------------|-----|
| De    | ecisiones de diseño                   | . 3 |
|       | ld RDEST, RORIG                       | . 3 |
|       | ldi RDEST, U16                        | . 3 |
|       | ld RDEST, (RORIG)                     | . 3 |
|       | add_a RORIG                           | . 3 |
|       | addi_a RORIG                          | . 3 |
|       | inc RDEST                             | . 3 |
|       | dec RDEST                             | . 3 |
|       | jp S16                                | . 3 |
|       | jpz S16                               | . 3 |
|       | call U16                              | . 3 |
|       | ret                                   | . 4 |
|       | halt                                  | . 4 |
|       | push RORIG                            | . 4 |
|       | pop RDEST                             | . 4 |
| Ejero | cicio 2                               | . 5 |
| Co    | omparación del juego de instrucciones | . 6 |
|       | ldi:                                  | . 6 |
|       | ld:                                   | . 6 |
|       | add_a/addi_a:                         | . 6 |
|       | inc/dec:                              | . 6 |
|       | jp:                                   | . 6 |
|       | jpz:                                  | . 6 |
|       | call/ret                              | . 6 |
|       | halt:                                 | . 6 |
|       | pop/push:                             | . 6 |
| Cond  | clusiones                             | . 7 |

# Ejercicio 1:

Debido a la falta de espacio en la tabla, las decisiones de diseño se encuentran al final del documento. Para llegar a ellas pulsa el hipervínculo ubicado en la fila correspondiente de *Decisiones de diseño*.

| INSTRUCCIÓN          | DISEÑO EN LENGUAJE RT                                                                                       | SEÑALES DE CONTROL                                                                                                                                         | DECISONES<br>DE DISEÑO                |
|----------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|
| Id RDEST, RORIG      | BR[Rdest]←BR[Rorig]                                                                                         | (SELA=10000, SELC=10101, T9, LC, A0, B, C=0)                                                                                                               | <u>Decisiones de</u><br><u>diseño</u> |
| ldi Rdest, U16       | BR[Rdest]←U16                                                                                               | (SIZE=1111,OFFSET=0,T3,MR=0,SELC=10101,LC, A0,B,C=0)                                                                                                       | <u>Decisiones de</u><br><u>diseño</u> |
| ld Rdest,<br>(Rorig) | MAR←BR[Rorig]<br>MBR←M[MAR]<br>BR[Rdest]←MBR                                                                | (MR=0, SELA=10000, T9, C0),<br>(TA, R, BW=11, M1, C1),<br>(MR=0, SELC=10101, T1, LC, A0, B, C=0)                                                           | <u>Decisiones de</u><br><u>diseño</u> |
| add_a Rorig          | RT1←BR[Rorig]<br>BR[A]←RT1 + BR[A]                                                                          | (SELA=10101, MB=11, SELCOP=1100, MC, T6, C4),<br>(SELB=00100, MR, MA, SELCOP=1010, MC, T6,<br>SELC=00100, SELP=11, M7, C7, LC, A0, B, C=0)                 | Decisiones de diseño                  |
| addi_a S16           | RT1←S16<br>BR[A]←RT1 + BR[A]                                                                                | (SIZE=01111, OFFSET=00000, SE, T3, C5),<br>(MR, SELA=100, MB, MC, SELCOP=1010, T6, SELC=100,<br>LC, SELP=11, M7, C7, A0, B, C=0)                           | Decisiones de<br>diseño               |
| inc Rdest            | BR[RDEST]←BR[RDEST] + 1                                                                                     | (SELA=10101, MB=11, MC, SELCOP=1010, SELC=10101, SELP=11, M7, C7, LC, T6, A0, B, C=0)                                                                      | <u>Decisiones de</u><br><u>diseño</u> |
| dec RDEST            | BR[RDEST]←BR[RDEST - 1                                                                                      | (MR=0, SELA=10101, MA=0, MB=11, MC, SELCOP=1011, T6, SELC=10101, LC, SELP=11, M7, C7, A0, B, C=0)                                                          | <u>Decisiones de</u><br><u>diseño</u> |
| jp S16               | RT1←PC<br>RT2←S16<br>PC←RT1 + RT2                                                                           | (T2, C4),<br>(SE, OFFSET=0, SIZE=10000, T3, C5),<br>(MA, MB, MC, SELCOP=1010, T6, C2, A0, B, C=0)                                                          | Decisiones de diseño                  |
| jpz S16              | IF (SR.Z == 1) {     microsalto a backfetch }  RT1←PC     RT2←S16     PC←RT1 + RT2 backfetch: salto a fetch | (A0=0, B, C=110, MADDR=backfetch),  (T2, C4),  (SE, OFFSET=0, SIZE=10000, T3, C5),  (MA, MB, MC, SELCOP=1010, T6, C2, A0, B, C=0)  backfetch: (A0, B, C=0) | <u>Decisiones de</u><br><u>diseño</u> |
| call U16             | SP←SP - 4, MAR←SP<br>MBR←PC<br>M[MAR]←MBR, PC←U16                                                           | (SELA=11101, MR, MB=10, MC, SELCOP=1011, T6,<br>SELC=11101, LC, C0),<br>(T2, M1=0, C1),<br>(TA, BW=11, TD, W, SIZE=10000, T3, C2, A0, B, C=0)              | <u>Decisiones de</u><br><u>diseño</u> |
| ret                  | RT3←SP + 4, MAR←SP<br>MBR←M[MAR], SP←RT3<br>PC←MBR                                                          | (MR, SELA=11101, T9, C0, MA=0, MB=10, SELCOP=1010, MC, C6), (TA, R, BW=11, M1, C1, T7, MR, SELC=11101, LC), (T1, M2=0, C2, A0, B, C=0)                     | Decisiones de<br>diseño               |
| halt                 | PC←BR[1] - BR[1]                                                                                            | (SELA, SELB, SELCOP=1011, MR, MC, T6, C2, A0, B, C=0)                                                                                                      | <u>Decisiones de</u><br><u>diseño</u> |
| push Rorig           | MAR←SP - 4, SP←SP - 4<br>MBR←BR[Rorig]<br>M[MAR]←MBR                                                        | (MR, SELA=11101, MA=0, MB=10, SELCOP=1011, MC, T6, SELC=11101, LC, C0), (MR=0, SELA=10101, T9, M1=0, C1), (TA, TD, W, BW=11, A0, B, C=0)                   | <u>Decisiones de</u><br><u>diseño</u> |
| pop Rdest            | MAR←SP, RT3←SP + 4<br>MBR←M[MAR], SP←RT3<br>RDEST←MBR                                                       | (SELA=11101, MR, T9, C0, MB=10, MC, SELCOP=1010,C6),<br>(TA, BW=11, R, M1, C1, SELC=11101, MR, T7, LC),<br>(T1, SELC=10101, MR=0, LC, A0, B, C=0)          | Decisiones de<br>diseño               |

#### Decisiones de diseño

#### Id RDEST, RORIG

Debido a que se pide reducir al mínimo el número de ciclos en las instrucciones, hemos incorporado todo en un solo ciclo de reloj. <u>Ejercicio 1</u>

#### Idi RDEST, U16

Debido a que se pide reducir al mínimo el número de ciclos en las instrucciones, hemos incorporado todo en un solo ciclo de reloj. <u>Ejercicio 1</u>

#### Id RDEST, (RORIG)

En el primer ciclo enviamos a MAR el valor del registro Rorig, para tras esperar hasta el siguiente ciclo coger el valor de esa posición en memoria, ya que de lo contrario estaríamos atravesando el registro. De la misma forma, en el mismo segundo ciclo cogemos este valor y lo almacenamos en MBR, para finalmente en el último ciclo guardar el valor en el registro Rdest. Ejercicio 1

#### add a Rorig

Para acceder a Rorig hace falta tener MR=0, mientras que para acceder al registro A hace falta tenerlo a 1. Es por esto que en un primer ciclo sacamos Rorig, lo multiplicamos por 1 en la ALU y lo guardamos en RT1. En el siguiente ciclo activamos MR sacando así A y sobrescribimos su valor con su suma con RT1 (Rorig). Ejercicio 1

#### addi a Rorig

En el primer ciclo sacamos el valor inmediato y lo movemos al registro RT1, para en el siguiente ciclo operar con él en la ALU, puesto que debemos esperar a otro ciclo o estaríamos atravesando el registro. En el segundo ciclo sacamos el registro A del banco de registros y hacemos la suma. Como aún no se ha usado el bus interno en este ciclo, directamente guardamos el resultado en el registro A. Ejercicio 1

#### inc Rdest

Debido a que se pide reducir al mínimo el número de ciclos en las instrucciones, hemos incorporado todo en un solo ciclo de reloj. <u>Ejercicio 1</u>

#### dec RDEST

Debido a que se pide reducir al mínimo el número de ciclos en las instrucciones, hemos incorporado todo en un solo ciclo de reloj. Ejercicio 1

#### jp S16

Con el fin de que esta instrucción se asemeje a su contrapartida en MIPS-32 (Branch), hemos decidido que recibiera direcciones relativas a PC, de tal forma que si se ejecuta "jp b1", PC apuntará a la etiqueta b1, al igual que en MIPS-32. Ejercicio 1

### jpz S16

En esta instrucción hemos tenido la misma filosofía que con *jp*, puesn que queríamos que los saltos fueran relativos a PC. Ejercicio 1

#### call U16

Para ahorrar ciclos de ejecución, en el mismo ciclo en el que restamos a SP 4, lo enviamos al MAR. En el siguiente ciclo PC envía su dirección a MBR. En el siguiente ciclo, en el que se guarda PC en memoria, aprovechamos para sobrescribir PC con U16 aprovechando que el bus de datos está libre. Ejercicio 1

#### UC3M, Colmenarejo 15/11/209

#### ret

Como en la instrucción anterior, con el fin de ahorrar ciclos, realizamos en el primer ciclo tanto la suma a SP 4, guardándola en RT3, como llevar a MAR el valor de SP. En el siguiente ciclo llevamos a MBR el contenido en memoria de la dirección almacenada en MAR. Como no se ha usado el bus interno aún, aprovechamos para en el mismo ciclo llevar a SP el valor de RT3. En el tercer ciclo llevamos a PC el valor de MBR. Ejercicio 1

#### halt

Dado que el objetivo es sobrescribir PC con un 0, podríamos activar C2 y cargar el contenido del bus, 0 al no haber nada activado. Sin embargo, no nos fiamos de la estabilidad eléctrica del bus, por lo que hemos tomado otra vía para generar un 0 en el bus de datos. Para ellos, restamos cualquier registro con sí mismo, sin actualizar el registro de estado, cargando el resultado de la operación en PC. Ejercicio 1

#### push Rorig

Con la intención de reducir el número de ciclos al mínimo, en el primer ciclo restamos a SP 4, y enviamos el resultado tanto a MAR como a SP. En el siguiente ciclo enviamos a MBR el valor del registro a guardar en pila. En el último ciclo sobrescribimos el valor en la posición de memoria contenida en MAR por el valor contenido en MBR. <u>Ejercicio 1</u>

#### pop Rdest

En el primer ciclo de esta instrucción enviamos SP a MAR, a la vez que guardamos en RT3 SP+4. En el siguiente ciclo, mientras MBR recibe la dirección almacenada en MAR, SP se sobrescribe con el valor de RT3 ahorrándonos así un ciclo de ejecución. En el siguiente ciclo sobrescribimos Rdest con el valor de MBR. Ejercicio 1

# Ejercicio 2

Tras correr el código pedido implementado con el juego de instrucciones del Z80, estos son los resultados obtenidos:

| REGISTRO | VALOR EN DECIMAL             |
|----------|------------------------------|
| R5       | 10                           |
| R7       | 55                           |
| R8       | 10                           |
| R9       | 4096 (dir de <i>vector</i> ) |
| PC       | 0                            |

Para comparar el juego de instrucciones del Z80 con el de MIPS32, hemos considerado oportuno visualizar a la vez el programa en ensamblador con el juego de instrucciones de MIPS32 que se nos ha proporcionado en la práctica con su equivalente usando las instrucciones del Z80, para ver cómo se aplican las mismas funcionalidades con el nuevo juego de instrucciones, viendo directamente las ventajas y desventajas del juego de instrucciones del Z80.

Pinchando en los rectángulos de colores irá a la explicación de porque la instrucción en cuestión es mejor/peor respecto a su contrapartida en MIPS32.



## Comparación del juego de instrucciones

#### ldi:

Idéntica a la instrucción li de MIPS. Ejercicio 2

#### ld:

Instrucción para mover a un registro, desde otro (move) o desde memoria (lw), dependiendo de cómo se invoca. Ejercicio 2

## add a/addi a:

Z80 no goza de instrucciones para sumar registros directamente, si no que tiene que recurrir al registro acumulador, A, como un registro temporal a la hora de hacer operaciones con registros. En este aspecto consideramos que el Z80 es bastante inferior a MIPS32. Ejercicio 2

### inc/dec:

Sin embargo, el Z80 posee instrucciones más sencillas para incrementar o decrementar en uno cualquier registro, lo cual simplifica significativamente el código. <u>Ejercicio 2</u>

#### ip:

Idéntico a su contrapartida en MIPS-32 (Branch), gracias a las decisiones de diseño implementadas. <u>Ejercicio 2</u>

#### jpz:

Esta instrucción es mucho más limitada que su contrapartida en MIPS-32, donde se pueden realizar todo tipo de saltos condicionales, mientras que esta instrucción solo funciona con una única condición, la cual además es compleja de implementar. Ejercicio 2

#### call/ret

Estas instrucciones son idénticas a *jal* y *jr \$ra* en MIPS32, pues llaman a subrutinas y retornan al punto de invocación. <u>Ejercicio 2</u>

#### halt:

Consideramos que esta es una forma más eficaz de terminar la ejecución de un programa, puesto que es más corto que hacer syscall 10. Ejercicio 2

## pop/push:

Esta operación es de gran utilidad pues simplifica mucho el código respecto a MIPS32, en el cual push y pop se realiza en mínimo dos operaciones. Ejercicio 2

#### Estructura de Computadores

## Conclusiones

Creemos que la práctica ha estado muy bien orientada, puesto que nos ha permitido aplicar y profundizar en los conceptos vistos en clase.

La única dificultad encontrada fue a la hora de realizar jp/jpz, puesto que no supimos si debería hacerse de forma relativa a PC o de forma absoluta. Al final salimos de dudas y nos decidimos a hacerla de forma relativa.

El número de horas destinadas a la práctica ronda las seis horas: cuatro fueron usadas en la realización del ejercicio 1, una en el ejercicio dos y otra en la memoria.