

# PODER EXECUTIVO MINISTÉRIO DA EDUCAÇÃO UNIVERSIDADE FEDERAL DE RORAIMA DEPARTAMENTO DE CIÊNCIA DA COMPUTAÇÃO



### Processador Sonic – 8 bits

**Componentes: Jorge Siqueira** 

William Thiago

Prof. Orientador: Prof. Dr. Herbert Oliveira Rocha





# O nome do processador



+Velocidade
-Tempo....





### Detalhes do processador - Sonic

Programado em: Quartus 2 v. Prime Version 15.1.0

Build 185 10/21/2015 SJ Lite Edition

Linguagem: VHDL

Arquitetura: 8 bits

Datapath: Baseado no mips

N° de Registradores: 4

Operações Suportadas: R, I e J

Operações: Realizadas usando inteiros.











## Detalhes do processador - Sonic Formato das instruções

| Operações do tipo R |                |        |  |  |  |
|---------------------|----------------|--------|--|--|--|
| 0p                  | Op Reg 1 Reg 2 |        |  |  |  |
| 4 bits              | 2 bits         | 2 bits |  |  |  |
| 7-4                 | 3-2            | 1-0    |  |  |  |

| Operações do tipo I |        |        |  |  |
|---------------------|--------|--------|--|--|
| ٥p                  | Reg 1  | Reg 2  |  |  |
| 4 bits              | 2 bits | 2 bits |  |  |
| 7-4                 |        | 1-0    |  |  |

| Operações do tipo J |          |  |
|---------------------|----------|--|
| <b>0</b> p          | Endereço |  |
| 4 bits              | 4 bits   |  |
| 7-4                 | 3-0      |  |





# Detalhes do processador - Sonic

# Códigos da Unidade de controle para cada operação

| Opcode | Nome         | Formato | Breve Descrição      | Exemplo             |
|--------|--------------|---------|----------------------|---------------------|
| 0000   | add          | R       | Soma                 | add \$s0, \$s1      |
| 0001   | addi         | 1       | Soma Imediata        | addi \$s0 3         |
| 0010   | sub          | R       | Subtração            | sub Ss0, \$s1       |
| 0011   | subi         | 1       | Subtração Imediata   | subi \$s0 3         |
| 0100   | lw           | 1       | Load Word            | lw \$s0 memória(00) |
| 0101   | sw           | 1       | Store Word           | sw \$s0 memória(00) |
| 0110   | move         | R       | Mover                | move \$s0 \$s1      |
| 0111   | li           | 1       | Load Imediato        | li \$s0 1           |
| 1000   | beq          | J       | Desvio Condicional   | beq endereço        |
| 1001   | bne          | J       | Desvio Condicional   | bne endereço        |
| 1010   | If beq e bne | R       | Condição para Desvio | if \$s0 \$s1        |
| 1011   | mul          | R       | Multiplicação        | mul \$s0 \$s1       |
| 1111   | j            | J       | Desvio Incondicional | J endereço(0000)    |





# Detalhes do processador - Sonic

# ◊ projeto

#### Flow Summary

Flow Status Successful - Tue Dec 03 06:47:17 2019

Quartus Prime Version 15.1.0 Build 185 10/21/2015 SJ Lite Edition

 Revision Name
 sonic

 Top-level Entity Name
 sonic

 Family
 Cyclone V

Device 5CGXFC7C7F23C8

 Timing Models
 Final

 Logic utilization (in ALMs)
 N/A

 Total registers
 20

 Total pins
 41

 Total virtual pins
 0

 Total block memory bits
 64

 Total DSP Blocks
 0

 Total HSSI RX PCSs
 0

 Total HSSI PMA RX Deserializers
 0

Total HSSI PMA TX Serializers 0
Total PLLs 0
Total DLLs 0

Total HSSI TX PCSs



### Processador Sonic - 8 bits



# Detalhes do processador - Sonic O RTL Viewer







# Detalhes do processador - Sonic O Data Path







# Detalhes do processador - Son Teste L - Addi





Resultado:

|            | Name                | Value at<br>0 ps | 0 ps<br>0 ps | 10.0 ns | 20.0 ns | 30.0 ns |
|------------|---------------------|------------------|--------------|---------|---------|---------|
| in         | clock_sonic         | B 0              |              |         |         |         |
| <b>*</b>   | > out_op_code_sonic | B 0001           |              |         |         |         |
| <b>*</b>   | > out_out_pc        | B 00000000       |              |         | 00000   | 000     |
| <b>**</b>  | > out_reg1          | B 00             |              |         | 00      | )       |
| <b>***</b> | > out_reg2          | B 10             |              |         | 10      | )       |
| *          | > out_rom_value     | B 00010010       |              |         | 00010   | 010     |
| *          | > out_ula_sonic     | B 00000010       |              |         | 00000   | 1010    |







## Detalhes do processador - Sonic

## Bibliografia

Dados sobre o VHDL. Curso de FPGA. disponível em:

https://www.youtube.com/watch?v=F0-

CgRe6hAc&list=PLZ8dBTV2 5HS79fVexGTtCMDUp7kjnumS

Componentes e tutoriais sobre o Quartus, disponíveis em:

https://www.fpga4student.com/