Para todos los ejercicios se pide que respeten los nombres de las entidades, entradas y salidas. Representación de datos <u>siempre</u> en *std\_logic* o *std\_logic\_vector*. Internamente, se les da la libertad para que utilicen el diseño que consideren más adecuado siempre y cuando la salida sea la esperada.

<u>Ejercicio 1</u>) Diseñe un componente llamado controller utilizando los componentes aludec y maindec del práctico 1 según el diagrama.



Implemente en VHDL, diseñe un testbench adecuado, simule con GHDL y GTKWave.

<u>Ejercicio 2</u>) Diseñe un componente llamado *datapath*. Respete los nombres de las señales y las conexiones según los diagramas adjuntos.



Deberá reutilizar los componentes adder, flopr, mux2, imem, signext, sl2, alu, regfile, y dmem del práctico anterior.



Implemente en VHDL, diseñe un testbench adecuado, simule con GHDL y GTKWave.

<u>Ejercicio 3</u>) Diseñe un módulo llamado *mips* utilizando los componentes *controller* y *datapath* según el diagrama.



Implemente en VHDL, diseñe un testbench adecuado, simule con GHDL y GTKWave.

Una vez terminada la implementación de la entidad de más alto nivel, "mips", ha completado el desarrollo de un microprocesador MIPS de un solo ciclo. Es hora de probar su funcionamiento; utilice el simulador MARS de MIPS, desarrolle y compile pequeños programas en *assembly* para luego cargarlos en la memoria de su MIPS (utilizando *imem.vhd* y *dmem.vhd* provistos (o "a ser provistos") por la cátedra).

#### Ejemplo:

Inicializar los registros \$t0 a \$t7 y luego colocar su valor en memoria RAM (en las direcciones 0x00 a 0x07).

| Instrucción de    | Código para                                                                                                                                                                                                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MIPS              | imem                                                                                                                                                                                                                                                                                    |
| addi \$t0, \$0, 0 | 20080000                                                                                                                                                                                                                                                                                |
| addi \$t1, \$0, 1 | 20090001                                                                                                                                                                                                                                                                                |
| addi \$t2, \$0, 2 | 200a0002                                                                                                                                                                                                                                                                                |
| addi \$t3, \$0, 3 | 200b0003                                                                                                                                                                                                                                                                                |
| addi \$t4, \$0, 4 | 200c0004                                                                                                                                                                                                                                                                                |
| addi \$t5, \$0, 5 | 200d0005                                                                                                                                                                                                                                                                                |
| addi \$t6, \$0, 6 | 200e0006                                                                                                                                                                                                                                                                                |
| addi \$t7, \$0, 7 | 200f0007                                                                                                                                                                                                                                                                                |
| sw \$t0, 0(\$0)   | ac080000                                                                                                                                                                                                                                                                                |
| sw \$t1, 4(\$0)   | ac090004                                                                                                                                                                                                                                                                                |
| sw \$t2, 8(\$0)   | ac0a0008                                                                                                                                                                                                                                                                                |
| sw \$t3, 12(\$0)  | ac0b000c                                                                                                                                                                                                                                                                                |
| sw \$t4, 16(\$0)  | ac0c0010                                                                                                                                                                                                                                                                                |
| sw \$t5, 20(\$0)  | ac0d0014                                                                                                                                                                                                                                                                                |
| sw \$t6, 24(\$0)  | ac0e0018                                                                                                                                                                                                                                                                                |
| sw \$t7, 28(\$0)  | ac0f001c                                                                                                                                                                                                                                                                                |
|                   | MIPS  addi \$t0, \$0, 0  addi \$t1, \$0, 1  addi \$t2, \$0, 2  addi \$t3, \$0, 3  addi \$t4, \$0, 4  addi \$t5, \$0, 5  addi \$t6, \$0, 6  addi \$t7, \$0, 7  sw \$t0, 0(\$0)  sw \$t1, 4(\$0)  sw \$t2, 8(\$0)  sw \$t3, 12(\$0)  sw \$t4, 16(\$0)  sw \$t5, 20(\$0)  sw \$t6, 24(\$0) |

En su *testbench* debe colocar la señal reset -> 1 por dos ciclos; correr el programa anterior por 17 ciclos, y luego colocar la señal *dump* -> 1 por tres ciclos, para obtener el archivo con el *dump* de la memoria. Verificar en el archivo de salida que el contenido de las siete primeras posiciones de la memoria contiene su índice (es decir, el contenido de la posición 0 es 0; el contenido de la posición 1 es 1, y así sucesivamente hasta la posición 7).

<u>Hint 1</u>: Es bueno agregar un bucle infinito del estilo "exit" para evitar que el programa vuelva a comenzar y la memoria se pise con valores erroneos.

<u>Hint 2</u>: Tenga en cuenta los tiempos de simulación, un "stop-time" o un "wait for" en su *testbench* "pequeños" podrían acortar la simulación, de manera que el programa finalice la ejecución de instrucciones antes de escribir el resultado en memoria.

<u>Hint 3 de MARS:</u> Chequear que la memoria de datos comience en 0: Settings -> Memory Configuration -> Compact Data at Address 0.

Hint 4 de MARS: Una vez que compilo el programa en MIPS, debe realizar un dump del

código

y luego seleccionar el tipo de salida: "Hexadecimal Text":



Para los siguientes ejercicios, debe utilizar las instrucciones MIPS assembly (que soporte su implementación de MIPS: addi, j, beq, etc.), simular en MARS, hacer un dump de las instrucciones, correr su implementación de MIPS con ese programa (imem deberá leer ese archivo, para que luego dmem genere un archivo de salida), corroborar que el archivo dump de la memoria RAM contenga el valor esperado. Recuerde comentar su código.

<u>Ejercicio 4)</u> Con la menor cantidad de registros e instrucciones de MIPS, inicialice con el valor de su índice las primeras N posiciones de memoria (comenzando en la dirección 0).

<u>Ejercicio 5</u>) Realice la sumatoria de las primeras N posiciones de memoria, y guarde el resultado en la posición N+1;

<u>Ejercicio 6</u>) Realice la multiplicación de dos registros: \$t0 y \$t1. Guarde el resultado en \$t3. Suponga que el resultado "cabe" en el registro. Guarde el resultado en la posición 0 de la memoria. Inicialice los valores de los registros debidamente.