#### Presentación *Práctica 1*

#### Arquitectura de Computadores

3º de grado en Ingeniería Informática y 3º de doble grado en Ing. Informática y Matemáticas

## Diseño jerárquico



Módulos que se proveen y módulos a desarrollar

#### MIPS uniciclo



## Material Entregado

directorio rtl/: contiene el código del procesador

| processor.vhd    | procesador, a completar        |
|------------------|--------------------------------|
| alu.vhd          | ALU, completa                  |
| reg_bank.vhd     | Banco de registros, completo   |
| control_unit.vhd | Unidad de control, a completar |
| alu_control.vhd  | Control de la ALU, a completar |

 directorio sim/: contiene lo necesario para simular el procesador

| processor_tb.vhd | El banco de pruebas (Testbench)                    |
|------------------|----------------------------------------------------|
| memory.vhd       | Modelo simple de memoria síncrona                  |
| programa.s       | Código fuente de un programa ensamblador de prueba |
| programa.lst     | Listado con la codificación del programa           |
| instrucciones    | Fichero de datos para la memoria de instrucciones  |
| datos            | Fichero de datos para la memoria de datos          |
| runsim.do        | Script de simulación para ModelSim                 |
| wave.do          | Script de configuración de ondas paras ModelSim    |

#### Unidad de control

- Genera las señales de control desde el código de operación de la instrucción
  - Entra el código de operación (OpCode)
  - Salen las señales de control: MemToReg, MemWrite, Branch/Jump, AluCtrl, RegDst, RegWrite, AluOP

 A desarrollar por el alumno. Utilizar la declaración de entidad provista

## ALU (Arithmetic Logic Unit)

- Debe ser capaz de ejecutar el conjunto de instrucciones que se implementarán
- Las señales de control las general el bloque conbinacional "ALU CONTROL"
- Aunque ya está desarrollado el modulo hay que verificar que se puedan ejecutar todas las instrucciones pedidas. Caso contrario habrá que agregarlas

Ya desarrollado (alu.vhd)

## Banco de registros

- 32 registros
- Lectura asíncrona
- Escritura síncrona
  - Flanco de bajada
  - El resto de registros del procesador en flanco de subida
- Registro 0
  - Siempre vale 0
  - Escrituras sin efecto

Ya desarrollado (reg\_bank.vhd)

### Simulación: generar instrucciones y datos



#### Simulación



#### Simulación



## Consejos de desarrollo

- Codificación
  - No crear nuevos componentes. Multiplexores y registros se pueden describir con procesos o asignaciones concurrentes
- EDITOR: Xilinx ISE
  - Check syntax (Detección de errores de VHDL)
  - Synthetize (Detección de errores "HW" (latches, ...))
- Simulador: Mentor ModelSIM
  - Integrado en Xilinx ISE
  - File -> Save -> wave.do
  - File -> Load -> wave.do
    - Permite guardar el formato de vuestra simulación
      - » Agrupaciones, formatos de representación, colores, ...

## Consejos antes de empezar

- Leer el guion completo de la práctica
- 2. Mirar en el libro de la teoría el sistema a implementar
- 3. Preguntar al profesor lo que no quede claro



# Presentación *Práctica 1*2<sup>do</sup> ejercicio

Arquitectura de Computadores

Microprocesador segmentado

#### Segmentación. Reutilizar recursos



# Segmentación 5 etapas del MIPS

- Etapa IF (*Instruction Fetch*): Captura de instrucción.
- Etapa ID (Instruction Decode): Decodificación de instrucción.
- Etapa EX (*Execute*): Ejecución de instrucción (ALU) o cálculo de dirección para lw y sw.
- Etapa MEM (*Memory*): Lectura o escritura en memoria.
- Etapa WB (Write Back): Escritura en banco de registros

# Segmentación en MIPS



# Segmentación en MIPS



Vista simplificada de la segmentación en 5 etapas

### Separando etapas: crear registros

```
PC_counter: process(clk,reset)
                                              iProceso
                                              síncrono!
begin
    if reset = '1' then
        pcmas4 ID <= (others=>'0');
                                           Inicialización
       intruccion ID <= (others=>'0');
    elsif rising_edge(clk) then
        pcmas4_ID <= pcmas4_IF;
                                           Propagación de valores
        instrucción_ID <= instrucción_IF;
    end if;
end process;
```

# Separando etapas: crear registros con habilitación

```
PC_counter: process(clk,reset)
begin
   if reset = '1' then
      pcmas4 ID \le (others = >'0');
      intruccion ID <= (others=>'0');
   elsif rising_edge(clk) and enable IF ID='1' hen
      pcmas4_ID <= pcmas4_IF;
      instrucción ID <= instrucción IF;
   end if;
end process;
```

enable IF ID <= '1';

En P1 nunca se para el pipeline, pero será necesario en P2

# MIPS Segmentado (Pipelined)



#### Recomendaciones



- Documentar el código y usar nombres de señales descriptivos. Mejor seguir nomenclatura del libro
- 2. Hacer checkeos sintácticos y síntesis antes de simular. Si lo que habéis descripto no puede transformarse en HW difícilmente funcionará
- 3. Simular y entender que se está simulando
- 4. Este diseño es la base para la práctica 2. Asegurarse que realmente funciona.
- Preguntar al profesor lo que no quede claro (para eso está allí)