

## RISC\_Pipeline - Especificaciones del Diseño

### Resumen

**RISC\_Pipeline** contiene la implementación de un procesador RISC Pipeline que cumple con las especificaciones proporcionadas por la guía **RTL Exercise Training** de Allegro.

### Diagrama



### Modulos

- **top\_module.sv:** Módulo principal. En este módulo se instancian y conectan el resto de los módulos.
- **control\_unit\_mod.sv:** Unidad de control. Este módulo genera las señales de control necesarias para el funcionamiento del procesador, decodificando las instrucciones y activando las señales y excepciones correspondientes.
- **data\_memory\_mod.sv:** Memoria de datos.
- **register\_file\_mod.sv:** Memoria de registros. Contiene los 32 registros del procesador.
- **instruction\_memory\_mod.sv:** Memoria de instrucciones. Almacena el conjunto de instrucciones que serán ejecutadas por el procesador.
- **program\_counter\_mod.sv:** Contador de programa. Registro de la dirección de la siguiente instrucción a ejecutar.
- **extender\_mod.sv:** Extensor de señal. Extiende a 32 bits el parametro Immediate o su concatenacion con el parametro Rc.
- **alu\_mod.sv:** Unidad Aritmético-Lógica. Realiza operaciones aritméticas y lógicas sobre los datos proporcionados por los registros o la memoria.
- **hazard\_unit\_mod.sv:** Unidad de control de Hazards. Genera las señales de control necesarias para el funcionamiento del procesador ante la aparición de Hazards.

## Entradas

- **clk**: Señal de reloj.
- **rst\_n**: Señal de reinicio activa en bajo. Cuando está en bajo (**0**) resetea el módulo al estado "A".

## Salidas

- **exception\_flags\_o**: Señales de bandera de excepción de 3 bits: Instrucción inválida, dirección de memoria inválida y dirección de program counter inválida.
- **alu\_result\_o**: Resultado de 32 bits de la operación realizada por la ALU.
- **reg\_file\_r\_data1\_o**: Datos de 34 bits leídos del primer registro de la memoria de registros.
- **reg\_file\_r\_data2\_o**: Datos de 34 bits leídos del segundo registro de la memoria de registros.
- **data\_mem\_r\_data\_o**: Datos de 32 bits leídos de la memoria de datos.
- **pc\_o**: Contador de programa de **N** bits.
- **inst\_read\_data\_o**: Datos de 32 bits leídos de la memoria de instrucciones.
- **alu\_C\_flag\_o**: Señal de bandera de carry de la ALU. Indica si hubo un acarreo en la última operación aritmética.
- **alu\_V\_flag\_o**: Señal de bandera de overflow de la ALU. Indica si hubo un desbordamiento en la última operación aritmética.

## Comportamiento ante Hazards

- **T=1x or [T=00 and (OPC=x00 or OPCODE=01x)]**: Al llegar a la etapa execute, se verifica en un registro interno de la hazard unit si recientemente se ha solicitado escribir alguno de los registros solicitados. De haberlos usado, se realiza bypassing desde la etapa de memory o writeback hacia la etapa de execute.
- **T=00 and OPCODE=000**: En la etapa decode se realiza un Stall con 3 clocks de duración. En el segundo y tercer clock se realizan flushes para introducir instrucciones NOP (Bubbles).
- **T=01 and (OPC= 000 or 101 or 110 or 111)**: En la etapa decode se realiza un Stall con 2 clocks de duración. En el segundo clock se realiza un flush para introducir una instrucción NOP (Bubbles).
- **T=01 and (OPC= 001 or 010 or 011 or 100)**: En la etapa decode se verifica si la condición de la instrucción se cumple, aquí también puede ocurrir bypassing. Si no cumple, continua la ejecución normal del programa. Si cumple, al segundo clock se realizan flushes en decode y execute y continua la ejecución del programa.



## Estructura del proyecto

El proyecto se encuentra dividido en 5 carpetas:

- Modules: Aquí se encuentran los módulos que conforman procesador.
- testbenches: Contiene los testbenches correspondientes cada uno de los módulos.
- Assembler: Aquí puede encontrarse el compilador de assembler desarrollado en python, junto con el programa utilizado y un txt con su explicación.
- Memory files: Contiene los datos a precargar en las memorias para el target testbench.
- Documentación: Aquí se almacenan todos los archivos relevantes para la documentación.



```
|   |   extender_mod.sv  
|   |   instruction_memory_mod.sv  
|   |   program_counter_mod.sv  
|   |   top_module.sv  
|   |   hazard_unit_mod.sv  
|   |   Documentation  
|   |   RISC PIPELINE_Specs_Hipperdinger.pdf  
|   |   Pipeline_diagram.png  
|   |   hazard_handling.png  
|   |   hazard_handling2.png
```

## Simulación online

<https://www.edaplayground.com/x/Spyt>