

## ALU Sparc v8

# TRABAJO FINAL CIRCUITOS LÓGICOS PROGRAMABLES (CLP)

| Autor:<br>Ing. Iriarte Fernandez, | Nicolás Ezequiel | (NicolasIriarte950 | @gmail.com) |
|-----------------------------------|------------------|--------------------|-------------|
| Docente:<br>Nicolás Alvarez.      |                  |                    |             |

### ${\rm \acute{I}ndice}$

| Introducción                       | 4 |
|------------------------------------|---|
| Desarrollo, alcance y limitaciones | 4 |
| Simulaciones                       | 6 |



#### Registros de cambios

| ] | Revisión | Detalles de los cambios realizados                    | Fecha                   |
|---|----------|-------------------------------------------------------|-------------------------|
|   | 0        | Creación del documento.                               | 11 de Abril de 2024     |
|   | 1        | Se aplican cambios sugeridos por Salamandri Santiago. | 20 de noviembre de 2023 |

#### Documentos anexos

| Ref.  | Nombre    | Descripción                                   |
|-------|-----------|-----------------------------------------------|
| AD.01 | SPARCV8AM | Especificación de requerimientos de software. |

Cuadro 1. Documentos anexos.

#### Glosario

| Acronimo | Definición                       |
|----------|----------------------------------|
| ALU      | Unidad Aritnética Lógica.        |
| CLP      | Circuitos Lógicos Programables.  |
| ICC      | Integer Condition Code.          |
| SPARC    | Scalable Processor Architecture. |

Cuadro 2. Glosario.



#### Introducción

En el presente documento se detallarán los aspectos relacionados con el desarrollo e implementación del trabajo final de la matería "Circuitos Lógicos Programables (CLP)". El cual consiste en una ALU de la arquitectura Sparc V8 tal como se describe en **AD.01**.

#### Desarrollo, alcance y limitaciones

El desarrollo del trabajo final se realizaró en el lenguaje de descripción de hardware VHDL. Y se implementaó una ALU de 32 bits que soportará las operaciones aritméticas y lógicas básicas. Durante el planeamiento y desarrollo se intentó representar la arquitectura Sparc V8 de forma fiel, sin embargo, para limitar el alcance del trabajo final se decidieron hacer las siguientes simplificaciones:

- El componente no tiene clock asociado, por lo que la actualización de cualquier de sus entradas genera una salida.
- Se implementaron unicamente las siguientes instrucciones, respetando el formato de la trama tal como en el manual de arquitectura (AD.01 Pag. 43). Las instrucciones implementadas son:
  - ADDcc (Opcode: 010000): Adición con actualización de ICC.
  - SUBcc (Opcode: 010100): Resta con actualización de ICC.
  - UMULcc (Opcode: 011010): Multiplicación sin signo con actualización de ICC.
  - SMULcc (Opcode: 011011): Multiplicación con signo con actualización de ICC.
- Para simplificación, el mecanismo de ventanas descrito en el manual de arquitectura (AD.01 Pag. 27) no fue implementado. Y para recuperar los valores de algunos registros requeridos, se pasaron directamente como señales al componente.

A partir de estas simplificaciones, el componente "ALU" que se implementó tiene la siguiente estructura interna:





Figura 1. Diagrama de componentes.

Tal como se observa en la Figura 1, el componente "ALU" tiene tres entradas:

- instruction: Señal de 32 bits que contiene la instrucción a ejecutar. La instrucción se decodifica y se extraen los campos necesarios para la ejecución de la operación. Para mayor información en el formato de la instrucción ver AD.01.
- 2. rs1: Señal de 32 bits que contiene el valor del registro fuente RS1.
- 3. rs2: Señal de 32 bits que contiene el valor del registro fuente RS2.

#### Y dos salidas:

- 1. rd: Señal de 32 bits que contiene resultado de la operación a ejecutar.
- 2. icc: Señal de 4 bits que contiene el valor del Integer Condition Code (ICC) actualizado. Para mayor información en el formato del ICC ver AD.01 Pag. 28.

Como filosofía de diseño, se optó por tenér un sub-componente para cada una de las instrucciones soportadas por la ALU, permitiendo de esta manera generar código VHDL más segmentado y limpio.

Dicho diseño tiene la desventaja de que todas las entradas y salidas de cada sub-componente están conectadas entre sí, y a demás, se debe agregar un selector por cada uno de las salidas esperadas.

El selector se encargará de interpretár la instrucción recibida, extraerá su Opcode y dependiendo de este último, seleccionará que sub-componente redireccionar como salida del mismo.



#### **Simulaciones**

Durante el desarrollo del presente trabajo, se realizaron multiples simulaciones de distintas entradas e instrucciones para verificar el correcto funcionamiento de los componentes implementados. Dichas entradas buscaron verificar distintos aspectos, tales como correcto funcionamiento de los ICC, busqueda de overflows, correcto calculo e interpretación de valores negativos. A continuación se deja un grafico generado a partir de la simulación del test-bench generado:



Figura 2. Diagrama de componentes.