

**Documento de Arquitetura**MUSA

Fazemos Qualquer Negócio Inc.

Compilação 2.1

# Histórico de Revisões

| Date                                              | Descrição                                                                                                   | Autor(s)               |
|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------|
| 25/06/2014                                        | Concepção do documento                                                                                      | joaocarlos             |
| 15/10/2014                                        | Adição da subseção de acesso à memória                                                                      | weversongomes          |
| 16/10/2014                                        | Adição da seção "Leitura da Instrução"com dados preliminares e modificação do nome do projeto no documento. | santana22 e gabri14el. |
| 19/10/2014                                        | Modificações na seção "Leitura da Instrução"                                                                | santana22              |
| 20/10/2014                                        | Correções na subseção de acesso à memória                                                                   | weversongomes          |
| 25/10/2014                                        | Adição das descrições da codificação                                                                        | manuellemacedo         |
| 29/10/2014                                        | Unificação das subseções de acesso à memória com a de write back                                            | weversongomes          |
| 29/10/2014                                        | Adição das descrições dos componentes                                                                       | manuellemacedo         |
| 30/10/2014 Adição do Datapath (Instruction Fetch) |                                                                                                             | santana22 e gabri14el  |
| 30/10/2014                                        | Alterações na subseção de acesso à memória com definições de número de bits                                 | weversongomes          |
| 03/11/2014                                        | Correções na subseção "Leitura da Instrução"                                                                | weversongomes          |
| 05/11/2014                                        | Modificação dos datapaths internos                                                                          | tarleswalker           |
| 05/11/2014                                        | Alteração nos opcodes                                                                                       | manuellemacedo         |
| 27/11/2014                                        | Refatoração da introdução e codificação                                                                     | manuellemacedo         |
| 06/12/2014                                        | Atualização das informações do Instruction<br>Fetch                                                         | santana22              |



# **SUMÁRIO**

| I | intro | oduçao   |                               | 4      |
|---|-------|----------|-------------------------------|--------|
|   | 1     | Propós   | sito do Documento             | <br>4  |
|   | 2     | Stakeh   | nolders                       | <br>4  |
|   | 3     | Visão (  | Geral do Documento            | <br>4  |
|   | 4     | Acrôni   | imos e Abreviações            | <br>5  |
| 2 | Visã  | o Geral  | ıl da Arquitetura             | 6      |
|   | 1     | Codific  | cação das instruções          | <br>6  |
|   | 2     | Descri   | ção dos Componentes           | <br>9  |
| 3 | Desc  | crição d | da Arquitetura                | 10     |
|   | 1     | Leitura  | a da Instrução                | <br>10 |
|   |       | 1.1      | Diagrama de Classe            | <br>10 |
|   |       | 1.2      | Definições de entrada e saída | <br>10 |
|   |       | 1.3      | Datapath Interno              | <br>10 |
|   | 2     | Decodi   | lificação da Instrução        | <br>11 |
|   |       | 2.1      | Diagrama de Classe            | <br>11 |
|   |       | 2.2      | Definições de entrada e saída | <br>11 |
|   |       | 2.3      | Tabela de microinstruções     | <br>12 |
|   |       | 2.4      | Datapath Interno              | <br>13 |
|   | 3     | Estágio  | o de execução                 | <br>14 |
|   |       | 3.1      | Diagrama de Classe            | <br>14 |
|   |       | 3.2      | Definições de entrada e saída | <br>14 |
|   |       | 3.3      | Datapath Interno              | <br>15 |
|   | 4     | Acesso   | o à memória e write back      | <br>16 |
|   |       |          |                               |        |



|   | 4.1   | Diagrama de Classe            | 16 |
|---|-------|-------------------------------|----|
|   | 4.2   | Definições de entrada e saída | 17 |
|   | 4.3   | Datapath Interno              | 17 |
| 5 | Datan | ath Externo                   | 18 |

# 1 Introdução

# 1. Propósito do Documento

Este documento descreve a arquitetura do projeto MUSA, incluindo especificações do circuitos internos de cada componente. Ele também apresenta diagramas de classe, definições de entrada e saída.O principal objetivo deste documento é definir as especificações do projeto MUSA e prover uma visão geral completa do mesmo.

#### 2. Stakeholders

| Nome                                                                                     | Papel/Responsabilidades |
|------------------------------------------------------------------------------------------|-------------------------|
| Manuelle                                                                                 | Gerência                |
| Manuelle, Patrick, Lucas, Mirela,<br>Vinícius, Gabriel, Weverson, An-<br>derson e Tarles | Análise                 |
| Manuelle, Patrick, Lucas, Mirela,<br>Vinícius, Gabriel, Weverson, An-<br>derson e Tarles | Desenvolvimento         |
| Patrick, Lucas, Mirela, Vinícius,<br>Gabriel, Weverson, Anderson e<br>Tarles             | Testes                  |
| Patrick, Lucas, Mirela, Vinícius,<br>Gabriel, Weverson, Anderson e<br>Tarles             | Implementação           |

#### 3. Visão Geral do Documento

O presente documento é apresentado como segue:

- Capítulo 2 Este capítulo apresenta uma visão geral da arquitetura, com foco em entradas e saídas do sistema e arquitetura geral do mesmo;
- Capítulo 3 Este capítulo descreve a arquitetura interna do IP a partir do detalhamento dos seus componentes, definição de portas de entrada e saída e especificação de caminho de dados.



# 4. Acrônimos e Abreviações

| Sigla  | Descrição       |
|--------|-----------------|
| PC     | Program Counter |
| OPCODE | Operation Code  |
| RF     | Register Flag   |
| CST    | Constant        |

# 2 | Visão Geral da Arquitetura

# 1. Codificação das instruções

Todas as instruções contém 32 bits. Exitem três formatos de instruções: R (R-type), I (I-type) e Jump. Neste documento os OPCODES são representados em seus respectivos códigos hexadecimais.

| Formato da instrução | Instrução | Descrição                                       |
|----------------------|-----------|-------------------------------------------------|
|                      | ADD       | Soma dois valores                               |
|                      | SUB       | Subtrai dois valores                            |
|                      | MUL       | Multiplica dois valores                         |
| R-type               | DIV       | Divide dois valores                             |
| Ктурс                | AND       | AND lógico                                      |
|                      | OR        | OR lógico                                       |
|                      | СМР       | Compara dois valores                            |
|                      | NOT       | NOT lógico                                      |
|                      | ADDI      | Soma dois valores,um destes imediato.           |
| I-type               | SUBI      | Subtrai dois valores, um destes imediato.       |
| i-туре               | ANDI      | AND lógico de dois valores, um destes imediato. |
|                      | ORI       | OR lógico de dois valores, um destes imediato.  |
|                      | LW        | Leitura de um dado da memória de dados          |
|                      | SW        | Armazena um dado na memória de dados            |
|                      | JR        | Desvia para um destino                          |
|                      | JPC       | Desvia para um destino relativo ao PC           |
| Jump                 | BRFL      | Desvia para um destino se RF==CST               |
| Jump                 | CALL      | Chamada de subrotina                            |
|                      | RET       | Retorno de Subrotina                            |
|                      |           | continua na próxima página                      |



| continuação da página anterior |      |                   |  |
|--------------------------------|------|-------------------|--|
| Formato da Instrução Instrução |      | Descrição         |  |
|                                | HALT | Parada do sistema |  |
|                                | NOP  | Refresh no módulo |  |

O formato R está relacionado as instruções lógicas e aritméticas.

| OPCODE | RS    | RT    | RD    | DON'T CARE | FUNCT |
|--------|-------|-------|-------|------------|-------|
| 31:26  | 25:21 | 20:16 | 15:11 | 10:6       | 5:0   |

| САМРО      | DESCRIÇÃO                                   |
|------------|---------------------------------------------|
| OPCODE     | Código da operação básica da instrução.     |
| RS         | Registrador do primeiro operando de origem. |
| RT         | Registrador do segundo operando de origem.  |
| RD         | Registrador de destino.                     |
| DON'T CARE | Não importa.                                |
| FUNCT      | Variante específica da operação.            |

| OPCODE | INSTRUCTION | FUNCTION |
|--------|-------------|----------|
| 0x00   | ADD         | 0x20     |
| 0x00   | SUB         | 0x22     |
| 0x1C   | MUL         | 0x02     |
| 0x05   | DIV         | 0x01     |
| 0x00   | AND         | 0x24     |
| 0x00   | OR          | 0x25     |
| 0x00   | СМР         | 0x2A     |
| 0x00   | NOT         | 0x27     |
| 0x00   | NOP         | 0x00     |

Um segundo tipo de formato de instrução é chamado de formato I, utilizado pelas instruções imediatas e de transferência de dados.



| OPCODE | RS    | RT    | IMMEDIATE |
|--------|-------|-------|-----------|
| 31:26  | 25:21 | 20:16 | 15:0      |

| CAMPO     | DESCRIÇÃO                                   |
|-----------|---------------------------------------------|
| OPCODE    | Código da operação básica da instrução.     |
| RS        | Registrador do primeiro operando de origem. |
| RT        | Registrador de destino.                     |
| IMMEDIATE | Constante numérica.                         |

| OPCODE | INSTRUCTION |
|--------|-------------|
| 0x08   | ADDI        |
| 0x09   | SUBI        |
| 0x0C   | ANDI        |
| 0x0D   | ORI         |
| 0x23   | LW          |
| 0x2B   | SW          |
| 0x04   | BRFL        |

 $\boldsymbol{O}$  formato Jump servem para as instruções de desvio incondicional.

| OPCODE | IMMEDIATE |
|--------|-----------|
| 31:26  | 25:0      |

| САМРО     | DESCRIÇÃO                               |  |  |  |  |
|-----------|-----------------------------------------|--|--|--|--|
| OPCODE    | Código da operação básica da instrução. |  |  |  |  |
| IMMEDIATE | Constante numérica.                     |  |  |  |  |



| OPCODE | INSTRUCTION |
|--------|-------------|
| 0x11   | JR          |
| 0x02   | JPC         |
| 0x03   | CALL        |
| 0x01   | RET         |
| 0x3F   | HALT        |

# 2. Descrição dos Componentes

A unidade de processamento a ser desenvolvida é composta a partir dos seguintes componentes:

- Instruction Fetch Módulo responsavel pela busca da instrução na memória de instrução.
- Instruction Decode e Register Read Módulo responsável pela decodificação das instruções e leitura do banco de registradores.
- Execute Operation or Calculate Address Módulo responsável pela execução as operações de caractér lógico/aritmético ou cálculos endereços.
- Memory Access e Write Back Módulo responsável pelo acesso a memória de dados e escrita no banco de registradores.

# 3 | Descrição da Arquitetura

# 1. Leitura da Instrução

# 1.1. Diagrama de Classe

# Instruction Fetch + clock : input bit + reset : input bit + pcInput : input bit[32] + pcWrite : input bit + pcOutput : output bit[32] + instruction : output bit[32] - «comb» search\_Instruction()

- «comb» next\_PC()

# 1.2. Definições de entrada e saída

| Nome        | Tamanho | Direção | Descrição                                       |
|-------------|---------|---------|-------------------------------------------------|
| pcInput     | 32      | entrada | Valor do PC atual                               |
| pcWrite     | 1       | entrada | Sinal que habilita a modificação do valor de PC |
| pcOutput    | 32      | saída   | Valor do PC atual                               |
| instruction | 32      | saída   | Instrução a ser executada                       |

# 1.3. Datapath Interno





# 2. Decodificação da Instrução

## 2.1. Diagrama de Classe

# **Instruction Decode** + clock : input bit + reset : input bit + instruction : input bit[32] + regDst : input bit + writeData : input bit + writeRegister : input bit + word : input bit[16] + regDst : output bit + branch : output bit + memRead : output bit + memToReg : output bit + aluOp : output bit + memWrite : output bit + aluSrc : output bit + regWrite : output bit + jump : output bit + readData1 : output bit[32] + readData2 : output bit [32] + outputWord : output bit [32] + registers : reg bit[32] - «comb» opcode\_decoder() - «comb» search\_register() - «comb» set\_write\_register() - «sequ» sign\_extend() - «sequ» zero\_extend()

## 2.2. Definições de entrada e saída



| Nome          | Tamanho | Direção | Descrição                                                                                           |  |  |  |  |
|---------------|---------|---------|-----------------------------------------------------------------------------------------------------|--|--|--|--|
| instruction   | 32      | entrada | Instrução a ser executada.                                                                          |  |  |  |  |
| writeData     | 1       | entrada | Sinal de controle para escrita no registra dor.                                                     |  |  |  |  |
| writeRegister | 1       | entrada | Endereço do registrador de destino do writeData.                                                    |  |  |  |  |
| word          | 16      | entrada | é uma instrução.                                                                                    |  |  |  |  |
| branch        | 1       | saída   | Sinal que informa ao circuito se a instrução é de branch.                                           |  |  |  |  |
| memRead       | 1       | saída   | Sinal de controle para realizar leitura da memória.                                                 |  |  |  |  |
| memToReg      | 1       | saída   | Sinal de controle que define se o dado deve vir da ULA ou da memória                                |  |  |  |  |
| aluOp         | 2       | saída   | Sinal de controle que define se o código funct da instrução deve ser levado em consideração ou não. |  |  |  |  |
| memWrite      | 1       | saída   | Sinal de controle para realizar escrita na memória.                                                 |  |  |  |  |
| aluSrc        | 1       | saída   | Sinal de controle que define qual entrada<br>a ULA deve utilizar para realizar a opera-<br>ção.     |  |  |  |  |
| regWrite      | 1       | saída   | Sinal de controle para realizar escrita no registrador.                                             |  |  |  |  |
| jump          | 1       | saída   | Sinal que informa ao circuito se a operação é de jump.                                              |  |  |  |  |

# 2.3. Tabela de microinstruções

| Código | Instrução                       |  |  |  |  |  |
|--------|---------------------------------|--|--|--|--|--|
| 1      | Lógicas, Aritméticas, NOP e CMP |  |  |  |  |  |
| 2      | MUL                             |  |  |  |  |  |
| 3      | DIV                             |  |  |  |  |  |
| 4      | ADDI                            |  |  |  |  |  |



| Código | Instrução |
|--------|-----------|
| 5      | ANDI      |
| 6      | SUBI      |
| 7      | ORI       |
| 8      | SW        |
| 9      | LW        |
| 10     | JR        |
| 11     | JPC       |
| 12     | BRFL      |
| 13     | CALL      |
| 14     | RET       |
| 15     | HALT      |

| Código   | 1   | 2   | 3   | 4   | 5   | 6   | 7   | 8   | 9   | 10  | 11  | 12  | 13  | 14  | 15  |
|----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| regDst   | 1   | 1   | 1   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| memRead  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 0   | 0   | 0   | 0   | 0   | 0   |
| memToReg | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| aluOp    | 010 | 010 | 010 | 000 | 011 | 001 | 100 | 000 | 000 | 000 | 000 | 101 | 000 | 000 | 000 |
| memWrite | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| regWrite | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 0   | 1   | 0   | 0   | 0   | 0   | 0   | 0   |
| data_a_s | 10  | 10  | 10  | 10  | 10  | 10  | 10  | 10  | 10  | 00  | 00  | 10  | 00  | 00  | 00  |
| data_b_s | 01  | 01  | 01  | 00  | 00  | 00  | 00  | 00  | 00  | 00  | 10  | 00  | 00  | 00  | 00  |
| pcSrc    | 010 | 010 | 010 | 010 | 010 | 010 | 010 | 010 | 010 | 001 | 100 | 001 | 001 | 000 | 110 |
| pop      | Х   | Х   | Х   | Х   | Х   | Х   | X   | Х   | Х   | Х   | X   | Х   | Х   | 1   | Х   |
| push     | X   | X   | X   | X   | X   | X   | X   | X   | X   | X   | X   | X   | 1   | X   | X   |

# 2.4. Datapath Interno





Datapath do estágio 2.

# 3. Estágio de execução

# 3.1. Diagrama de Classe

# 3.2. Definições de entrada e saída

| Nome           | Tamanho | Direção | Descrição                                                      |
|----------------|---------|---------|----------------------------------------------------------------|
| data_a         | 32      | Entrada | Dado do primeiro operando.                                     |
| data_b         | 32      | Entrada | Dado do segundo operando.                                      |
| pc_in          | 14      | Entrada | Valor do PC atual.                                             |
| rt_data_mem    | 5       | Entrada | Dado vindo da memoria.                                         |
| opcode         | 5       | Entrada | Código da operação.                                            |
| control_signal | TBD     | Entrada | Sinal de comando da unidade de controle.                       |
| alu_result     | 32      | Saída   | Representação do resultado da operação.                        |
| pc_out         | 32      | Saída   | Valor do PC atual.                                             |
| write_reg_mem  | 5       | Saída   | Sinal proveniente da UC que habilita a escrita no registrador. |
| memory_address | 32      | Saída   | Endereço da memória.                                           |



| Nome                | Tamanho | Direção | Descrição                                                  |
|---------------------|---------|---------|------------------------------------------------------------|
| memory_write_enable | TBD     | Saída   | Sinal proveniente da UC que habilita a escrita na memória. |

# 3.3. Datapath Interno



#### **Execute Operation**

- + clock : input bit
- + reset : input bit
- + data\_a : input bit[32]
- + data\_b : input bit[32]
- + pc\_in : input bit[14]
- + orig\_pc: input bit [2]
- + op\_alu : input bit[5]
- + origin\_aalu : input bit[1]
- $+ \ origin\_balu: input \ bit[2]$
- + instruction : output bit[32]
- + offset\_inst : input [32]
- +«comb» calc\_next\_pc()
- + «comb» cal\_al\_operation()



Datapath interno do estágio de execução (EX).

#### 4. Acesso à memória e write back

## 4.1. Diagrama de Classe

# Acess Memory + clock: input bit + reset: input bit + zero: input bit + address: input bit + writeData: input bit[13] + memRead: input bit + memWrite: input bit - writeBack: output bit[14] - writeToRegister: output bit[14]



# 4.2. Definições de entrada e saída

| Nome            | Tamanho | Direção | Descrição                                                               |
|-----------------|---------|---------|-------------------------------------------------------------------------|
| zero            | 1       | entrada | Executa branch quando é zero.                                           |
| address         | 13      | entrada | Endereço no qual o dado deve ser escrito.                               |
| memRead         | 1       | entrada | Sinal proveniente da UC que habilita leitura.                           |
| memWrite        | 1       | entrada | Sinal proveniente da UC que habilita escrita.                           |
| writeData       | 1       | entrada | Dado a ser escrito na memória.                                          |
| writeBack       | 14      | saída   | Dado proveniente da ALU que será es-<br>crito no bloco de registradores |
| writeToRegister | 14      | saída   | Dado do segundo operando.                                               |

# 4.3. Datapath Interno



Datapath dos estágios 4 e 5.

# 5. Datapath Externo

