# Guía de ejercicios # 3 Memoria, Buses, Q2 y Accesos

Organización de Computadoras 2017

### UNQ

# 1 Escribir Programas en Q2

La arquitectura Q2 agrega a la arquitectura Q1 un nuevo modo de direccionamiento: **Directo**, el cual especifica la direccion de memoria donde se encuentra el valor del operando.

Para usar este nuevo modo de direccionamiento la dirección del operando se escribe entre corchetes, por ejemplo: SUB [0x000A], 0x0001. El efecto de esta instrucción es el de decrementar en 1 el valor que tenía la celda cuya dirección es 000A.

Si antes de ejecutar teníamos en memoria:

| A000x0 | 29C8 |
|--------|------|
| 0x000B | AOAO |
|        |      |

Luego de ejecutar se tendrá:

| A000x0 | 29C7 |
|--------|------|
| 0x000B | AOAO |
|        |      |

Ejemplos de otras instrucciones:

- MOV R1, [0x000A]
- ADD [0x000A], 0x000A
- SUB [0x000A], [0x000B]
- 1.1 Hacer un programa que multiplique por 12 el valor de la celda 0x0007
- 1.2 Escriba un programa que inicialice la celda 0xA000 con la cadena que representa el valor 25 en hexadecimal de 4 dígitos.
- 1.3 Escriba un programa que sume el valor de la celda 0xB000 con el valor de la celda 0x2000
- 1.4 Escriba un programa que duplique el valor de la celda 0xA305
- 1.5 Hacer un programa que sume el valor de la celda 0x7000 con el valor de R1 y guarde el resultado en la celda 0xABCD
- 1.6 Escribir un programa que sume los valores de las celdas 0x0F80 y 0x0F81 y ponga el resultado en R2 (sin modificar las celdas).
- 1.7 Escribir un programa que calcule el **promedio** entre los valores almacenados en las celdas 0x089A y 0x089B.

- 1.8 Escribir un programa que intercambie los valores de las celdas 0x0F80 y 0x0F81
- 1.9 Suponiendo que la celda 0x089A tiene almacenado el costo en pesos de un producto, y la celda 0x089B contiene el porcentaje descuento a aplicar, calcule el valor final de venta a ser almacenado en la celda 0x089C. Por ejemplo, si se un producto de \$50 y se le aplica un descuento del 20%, el resultado final es

$$50 - (50 * 20/100)$$

No puede usar registros para resolverlo.

# 1.1 Probar los programas

Para estar seguro de que un programa cumple con su objetivo, se realizan **pruebas de escritorio** que son ejecuciones paso a paso. Considerar por ejemplo el siguiente programa

MOV R6, R0 ADD R6, R1 MUL R6, 0x0010

Si se toma como precondición R0=0x0060 y R1=0x0025 entonces la ejecución paso a paso es como sigue:

| Instrucción    | Efecto                        |
|----------------|-------------------------------|
| MOV R6, R0     | $R6 \leftarrow 0060$          |
| ADD R6, R1     | $R6 \leftarrow 0085$          |
| MUL R6, 0x0010 | $R7,R6 \leftarrow 0000\ 0850$ |

- 1.1.1 Hacer una prueba de escritorio para el programa del ejercicio 1.7 (promedio)
- 1.1.2 Hacer una prueba de escritorio para el programa del ejercicio 1.8 (intercambio).
- 1.1.3 Hacer una prueba de escritorio para el programa del ejercicio 1.9 (descuento).

# 2 Ensamblar y desensamblar

Para incorporar un nuevo modo de direccionamiento se necesita modificar la tabla de modos de direccionamiento como sigue:

| Modo      | Codificación |
|-----------|--------------|
| Inmediato | 000000       |
| Directo   | 001000       |
| Registro  | 100rrr       |

donde rrr es una codificación (en 3 bits) del número de registro.

Además, el siguiente es el formato de las instrucciones de  $\mathbf{Q2}$ , de dos operandos (origen y destino). Es importante destacar en comparación con  $\mathbf{Q1}$ , que se agrega un campo mas: **Destino**.

| Cod_Op | Modo Destino | Modo Origen | Destino | Origen |
|--------|--------------|-------------|---------|--------|
| (4b)   | (6b)         | (6b)        | (16b)   | (16b)  |

Con este formato, el campo <code>Destino</code> puede contener una dirección de memoria (si el modo correspondiente es <code>directo</code>) o no se utiliza si es un registro. Por otro lado, el campo <code>Origen</code> puede contener una dirección de memoria, un registro o una constante (modo <code>inmediato</code>).

Algunos ejemplos:

| Código fuente   | Código máquina                        |
|-----------------|---------------------------------------|
| MOV R7,[0x0001] | 0001 100111 001000 000000000000000000 |
| ADD [0x0001],R7 | 0010 001000 100111 00000000000000000  |

**Nota:** Es bueno tener a mano la especificación completa de Q (ver sección **Referencias** al final)

# **Ejercicios**

2.1 Ensamblar el siguiente programa:

MOV [0x0001], R0

MUL [0x00FE], 0x00A1

ADD [OxFFAB], [OxBBA7]

SUB RO, [0x2DC6]

2.2 A partir del siguiente mapa de memoria:

| 0x9999 | 29C8 |
|--------|------|
| 0x999A | AOAO |
|        |      |

y sabiendo que a partir de la primer celda (0x9999) hay ensamblada una instrucción.

- (a) ¿Cuál es dicha instrucción?
- (b) ¿Cuántas celdas ocupa?
- (c) ¿Qué se modifica al ejecutarla?
- 2.3 A partir del siguiente mapa de memoria:

|        | 1    |
|--------|------|
|        |      |
| 0x9999 | 1200 |
| 0x999A | FFFF |
| 0x999B | 0000 |
|        |      |

y sabiendo que a partir de la primer celda (0x9999) hay ensamblada una instrucción.

- (a) ¿Cuál es dicha instrucción?
- (b) ¿Cuántas celdas ocupa?
- (c) ¿Qué se modifica al ejecutarla?

### 3 Memoria

3.1 Considerar el siguiente esquema del circuito de la memoria principal



¿Cuántas entradas debería tener el decodificador?

- 3.2 Teniendo en cuenta lo analizado en el ejercicio 3.1, te parece que las direcciones se guardan en la memoria?
- 3.3 Generalizando tu respuesta al ejercicio 3.1, cuantas entradas se necesitan para direccionar n celdas?
- 3.4 ¿Es cierto que en la memoria se almacenan solamente las instrucciones mientras que los datos en registros del CPU? Justificar con un ejemplo
- 3.5 ¿Es cierto que el contenido de la memoria no es volátil?

  Justificar
- 3.6 ¿Porqué se dice que en la memoria RAM la lectura de cualquier dirección insume el mismo tiempo?
- 3.7 Sabiendo que 1 byte equivale a 8 bits, y suponiendo una memoria principal con tamaño de celda de **2** bytes y direcciones de 16 bits. ¿Qué cantidad de bits puede almacenar?
- 3.8 Sabiendo que 1 byte equivale a 8 bits, y suponiendo una memoria principal con tamaño de celda de **2** bytes y tamaño total de **64** bytes. ¿Cuántas celdas tiene?

#### 4 Buses del sistema

- 4.1 Si la memoria tiene 8 celdas, cada una de 1 byte:
  - (a) ¿Cuántas líneas de direcciones se necesitan?
  - (b) ¿Cuántas líneas de datos se necesitan?
- 4.2 Sabiendo que 1 byte equivale a 8 bits, suponga una memoria principal con tamaño de celda de **2** bytes y tamaño total de **64** bytes. ¿Cuántos bits tendrá el bus de direcciones?
- 4.3 Si se quiere cuadruplicar el tamaño de una memoria ¿Cómo debe modificarse el bus de direcciones? (No es posible alterar el bus de datos)
- 4.4 Si se quiere cuadruplicar el tamaño de una memoria ¿Cómo debe modificarse el bus de datos? (No es posible alterar el bus de direcciones)
- 4.5 La arquitectura **Q2** tiene un bus de direcciones y un bus de datos ambos de **16 bits**. ¿Qué capacidad tiene la memoria principal?

### 5 Funcionamiento de buses

Para cada instrucción completaremos un **cuadro de actividad de buses** que describe el contenido de los buses en cada operación de lectura o escritura a memoria al *ejecutar todo el ciclo de la instrucción*. Para todas las instrucciones asumir:

- 1. que están ensambladas a partir de la celda A000,
- 2. el siguiente estado parcial de registros y memoria

| R.O | 0001 | 9000 | AB02 |
|-----|------|------|------|
| R.1 | 9002 | 9001 | 9004 |
|     |      | 9002 | 0043 |
| R2  | 9004 | 9003 | BBBB |
| R3  | 0003 | 9004 | OFFF |
|     |      | 3004 | OPTT |
|     |      |      |      |

Como ejemplo, considerar la instrucción:

MOV RO, [0x9001].

| Bus de ctrl | Bus de dir | Bus de datos          |
|-------------|------------|-----------------------|
| L=1         | A000       | 1808 (codigo maquina) |
| L=1         | A001       | 9001 (codigo maquina) |
| L=1         | 9001       | 9004 (operando)       |

Nota: en el bus de control se debe indicar L=1 cuando es una lectura o E=1 cuando es una escritura

# **Ejercicios**

5.1 MOV [0x9001], RO

5.2 ADD RO, [0x9000]

5.3 ADD [0x9000], RO

5.4 ADD [0x9001], [0x9002]

5.5 SUB [0x9001], [0x9002]

# 6 Ciclo de ejecución de instrucción

Importante: Para esta sección es importante la información del apunte en la página de la materia (ver sección Referencias al final)

- 6.1 Enumerar las celdas que se leen durante la **busqueda de instrucción** en cáda una de las instrucciones siguientes. Suponer que todas están ensambladas a partir de la celda ox9999
  - (a) SUB R7, RO
  - (b) ADD R7, OXAOAO
  - (c) ADD R7, [OxAOAO]
  - (d) MOV [OXFFFF], OXOOOO
- 6.2 Enumerar las celdas se leen durante la etapa de **busqueda de operandos** en cáda una de las instrucciones del inciso anterior
- 6.3 Enumerar las celdas se escriben durante la etapa de almacenamiento de resultados en cáda una de las instrucciones del inciso anterior

6.4 Analice las siguientes instrucciones en forma individual indicando **qué** celdas de memoria son leídas y escritas en cada etapa del ciclo. Asuma que las instrucciones están alojadas consecutivamente a partir de 0x0000.

| Instrucción           | BI      | В0   | AR   |
|-----------------------|---------|------|------|
| ADD [0xCOCO],R7       | 0x0000, | COCO | COCO |
| ADD [OXCOCO],RI       | 0x0001  | 0000 | 0000 |
| ADD R2, R5            | 0x0003  |      |      |
| MOV [0xA001],R0       |         |      |      |
| SUB RO, 0x0005        |         |      |      |
| ADD [0x9123],R3       |         |      |      |
| MUL [0x3401],[0xA001] |         |      |      |

6.5 Idem anterior, pero además indicar el valor del Operando destino en la columna **efecto**, dado el siguiente estado de memoria y registros.

| R.O | 0001 | 9000 | AB02 |
|-----|------|------|------|
| R.1 | 9002 | 9001 | 9004 |
|     |      | 9002 | 0043 |
| R2  | 9004 | 9003 | BBBB |
| R3  | 0003 | 9004 | OFFF |
|     |      |      |      |

| Instrucción      | BI | В0 | AR | Efecto |
|------------------|----|----|----|--------|
| MOV RO, [ox9000] |    |    |    |        |
| ADD [0x9001], R1 |    |    |    |        |
| MOV R1, 0x9002   |    |    |    |        |

6.6 Considerando el siguiente estado parcial de registros y memoria:



Simular la ejecución del programa (que comienza donde indica el registro PC) para completar el siguiente cuadro de actividad de buses, indicando además con qué etapa del ciclo se corresponde cada acceso.

Tomar como ejemplo el siguiente cuadro para la instrucción SUB [OxABCD], R5 , ensamblada en la celda 0000, y siendo R5=0001 y [ABCD]=000A

| Bus de ctrl | Bus de dir | Bus de datos | Etapa |
|-------------|------------|--------------|-------|
| L=1         | 0000       | 3225         | B.I.  |
| L=1         | 0001       | ABCD         | B.I.  |
| L=1         | ABCD       | 000A         | B.O.  |
| E=1         | ABCD       | 0009         | A.R.  |

6.7 Teniendo en cuenta lo resuelto en el último ejercicio ¿En qué etapas del ciclo de ejecución se accede a la memoria?

# 7 Tiempo de ejecución

En los siguientes ejercicios compararemos diferentes programas a partir del tiempo que lleva su ejecución. Para cada uno responder:

- a ¿Cuántos bytes (1 byte = 8 bits) ocupa una vez ensamblado?
- b ¿Cuantos accesos a memoria se llevan a cabo durante su ejecución?
- c Si cada acceso a memoria se realiza en  $0.1\mu s$ , y el tiempo de computo de CPU es despreciable. ¿Cuanto tarda la ejecución del programa?
- 7.1 MOV RO,OxE1E1 ADD RO,R1
- 7.2 MOV RO,[0xE1E1] ADD RO,0x0111 MUL [0x67AB],RO
- 7.3 ADD [0x5001],R6 MUL [0x5000],[0x5001]
- 7.4 MOV R6,0x9867 ADD [0xA000],R6 MUL [0xA001],[0xA000]

# 8 Ejercicios adicionales

8.1 Ensamblar el siguiente programa a partir de la celda E000:

MOV RO, [0x9000] ADD [0x9001], R1 MOV R1, 0x9002

8.2 A partir del siguiente mapa de memoria:



y sabiendo que a partir de la primer celda (0x9999) hay ensamblada una instrucción.

- (a) ¿Cuál es dicha instrucción?
- (b) ¿Cuántas celdas ocupa?
- (c) ¿Qué se modifica al ejecutarla?
- 8.3 ¿Cuántos bits transmite a la vez una línea de un bus?
- 8.4 ¿Es cierto que el bus de datos está relacionado con cuantas celdas tiene una memoria?
- 8.5 ¿Es cierto que el bus de direcciones lleva señales tales como: leer, escribir, quiero usar el bus?
- 8.6 Completar la siguiente tabla de **cantidad de accesos**, que es similar a las de la sección 6 pero se pide que se complete la cantidad de accesos a memoris (no los registros!)

| Instrucción            | BI | В0 | AR | Total |
|------------------------|----|----|----|-------|
| DIV RO, 0x9876         | 2  | 0  | 0  | 2     |
| MOV RO, R1             |    |    |    |       |
| ADD RO, OxFOCA         |    |    |    |       |
| SUB [0x1111], 0x1111   |    |    |    |       |
| MUL [0x0010], [0xFEDE] |    |    |    |       |
| DIV R1, [Ox43AE]       |    |    |    |       |

8.7 Dado el siguiente estado de registros y memoria:

| RO | 000F         | OOAB | R.4 | 0x2000 | 2001 |
|----|--------------|------|-----|--------|------|
| R1 | 0013         | 000A | R.5 | 0x2001 | FF00 |
| R2 | 0085         | 0009 | R.6 |        |      |
| R3 | 0083<br>00E2 | 2001 | R.7 |        | :    |
| nЭ | UUEZ         | 2001 | n/  | 0x200B | 0050 |
|    |              |      |     |        |      |

- (a) ¿Qué registro o celda de memoria se modifica al ejecutar ADD RO, [0x2000]? ¿Qué valor toma?
- (b) ¿Qué registro o celda de memoria se modifica al ejecutar ADD R3,0x2000? ¿Qué valor toma?
- (c) ¿Qué registro o celda de memoria se modifica al ejecutar ADD [0x2000], R3? ¿Qué valor toma?
- (d) ¿Qué registro o celda de memoria se modifica al ejecutar ADD [0x2001],[0x2000]? ¿Qué valor toma?
- (e) ¿Qué registro o celda de memoria se modifica al ejecutar ADD R3,R7? ¿Qué valor toma?

**Nota**: Analice cada caso **independientemente**, no considere las instrucciones como un programa.

### References

- [1] Williams Stallings, Computer Organization and Architecture, octava edicion, Editorial Prentice Hall, 2010. Capitulos 10 y 11
- [2] Ciclo de ejecución de instrucciones y registros de control y estado (apunte de la materia), http://orga.blog.unq.edu.ar/wp-content/uploads/sites/5/2015/08/apunte-ciclo-registros-especiales.pdf.
- [3] Especificación completa de Q: http://orga.blog.unq.edu.ar/wp-content/uploads/sites/5/2015/08/Especificacion-Q.pdf