

**Documento de Arquitetura**MUSA

Fazemos Qualquer Negócio Inc.

Compilação 3.1



# Histórico de Revisões



| Data       | Descrição                                                                   | Autor(es)              |
|------------|-----------------------------------------------------------------------------|------------------------|
| 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"e modificação do nome do projeto.     | 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 Fetch                            | santana22              |
| 10/12/2014 | Atualização da tabela de microinstruções                                    | mirelarios             |
| 10/12/2014 | Modificando as informações contidas nos diagramas de classe de cada estágio | santana22              |
| 11/12/2014 | Refatoração da introdução e codificação                                     | manuellemacedo         |
| 11/12/2014 | Alteração no datapath do Intruction Fetch                                   | mirelarios             |
| 14/12/2014 | Atualização dos diagramas de classe                                         | santana22              |
| 15/12/2014 | Adição dos datapaths dos estágios 2 e 3                                     | mirelarios             |



# **SUMÁRIO**

| 1 | Intr | dução 5                           |
|---|------|-----------------------------------|
|   | 1    | Propósito do Documento            |
|   | 2    | Stakeholders                      |
|   | 3    | Visão Geral do Documento          |
|   | 4    | Acrônimos e Abreviações           |
| 2 | Visã | o Geral da Arquitetura            |
|   | 1    | Codificação das instruções        |
|   | 2    | Descrição dos Componentes         |
| 3 | Des  | rição da Arquitetura 11           |
|   | 1    | Leitura da Instrução              |
|   |      | 1.1 Diagrama de Classe            |
|   |      | 1.2 Definições de entrada e saída |
|   |      | 1.3 Datapath Interno              |
|   | 2    | Decodificação da Instrução        |
|   |      | 2.1 Diagrama de Classe            |
|   |      | 2.2 Definições de entrada e saída |
|   |      | 2.3 Tabela de microinstruções     |
|   |      | 2.4 Datapath Interno              |
|   | 3    | Estágio de execução               |
|   |      | 3.1 Diagrama de Classe            |
|   |      | 3.2 Definições de entrada e saída |
|   |      | 3.3 Datapath Interno              |
|   | 4    | Acesso à memória e write back     |
|   |      | 4.1 Diagrama de Classe            |
|   |      | 4.2 Definições de entrada e saída |
|   |      | 4.3 Datapath Interno              |
|   |      |                                   |



| 5 | Datapath Externo |       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 2 | 1 |
|---|------------------|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| J | Datapath Externo | <br>• | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • |   |   |

# 1 Introdução

#### 1. Propósito do Documento

Este documento descreve a arquitetura do projeto MUSA. Como parte integrante deste documento estão os diagramas de classe, as definições de entrada e saída como também, as especificações dos circuitos internos de cada componente. Dessa forma, o principal objetivo deste documento é definir as especificações do projeto MUSA.

#### 2. Stakeholders

| Nome                                                  | Papel/Responsabilidades |
|-------------------------------------------------------|-------------------------|
| Manuelle                                              | Gerência                |
| Manuelle, Vinicius, Weverson, Patrick                 | Análise                 |
| Patrick, Lucas, Mirela, Vinícius,<br>Gabriel e Tarles | Projeto                 |
| Manuelle e Anderson                                   | Verificação Funcional   |

#### 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 nas entradas e saídas do sistema e na arquitetura geral do mesmo;
- Capítulo 3 Este capítulo descreve a arquitetura interna do IP a partir do detalhamento dos seus componentes, da definição das portas de entrada e saída e das especificações do caminho de dados (*datapath*).



# 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                                       |
|                      | NOT       | NOT lógico                                      |
|                      | NOP       | Não realiza operação                            |
|                      | ADDI      | Soma dois valores, um destes imediato.          |
| I-type               | SUBI      | Subtrai dois valores, um destes imediato.       |
| Г-туре               | 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            |
|                      | СМР       | Compara dois valores                            |
|                      | BRFL      | Desvia para um destino se $RF == CST$           |
|                      | JR        | Desvia para um destino                          |
|                      | JPC       | Desvia para um destino relativo ao PC           |
| Jump                 | CALL      | Chamada de sub-rotina                           |
| Jump                 |           | continua na próxima página                      |



| continuação da página anterior |           |                       |  |  |  |  |  |  |
|--------------------------------|-----------|-----------------------|--|--|--|--|--|--|
| Formato da Instrução           | Instrução | Descrição             |  |  |  |  |  |  |
|                                | RET       | Retorno de sub-rotina |  |  |  |  |  |  |
|                                | HALT      | Parada do sistema     |  |  |  |  |  |  |

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   | 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 |
|---|--------|-------|-------|-----------|
| 1 | 31:26  | 25:21 | 20:16 | 15:0      |

| САМРО     | 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        |
| 0x1D   | СМР         |

O formato *Jump* serve para as instruções de desvio condicional e 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 + pcWrite: input bit + push: input bit + pop: input bit + pclnput: input bit[32] + pcOutput: output bit[32] + pcStack: 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                                              |
|---------|---------|---------|--------------------------------------------------------|
| clock   | 1       | entrada | Clock do sistema                                       |
| reset   | 1       | entrada | Sinal de reinício do estágio                           |
| pcInput | 32      | entrada | Endereço da instrução a ser buscada                    |
| pcWrite | 1       | entrada | Sinal que habilita a modificação do valor de PC        |
| push    | 1       | entrada | Sinal que habilita a escrita na Pilha de<br>Instruções |
| pop     | 1       | entrada | Sinal que habilita a leitura da Pilha de<br>Instruções |



| Nome        | Tamanho | ho Direção Descrição                              |                                                            |  |  |  |  |  |  |  |
|-------------|---------|---------------------------------------------------|------------------------------------------------------------|--|--|--|--|--|--|--|
| pcStack     | 32      | saida                                             | Valor do PC armazenado no topo da Pi-<br>lha de Instruções |  |  |  |  |  |  |  |
| pcOutput    | 32      | saída Endereço da instrução que está se executada |                                                            |  |  |  |  |  |  |  |
| instruction | 32      | saída                                             | Instrução encontrada                                       |  |  |  |  |  |  |  |

## 1.3. Datapath Interno



Instruction Fetch



# 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[5]        |
| + writeData : input bit        |
| + writeRegister : input bit[5] |
| + word : input bit[16]         |
| + branch : output bit          |
| + memRead : output bit         |
| + memToReg : output bit        |
| + aluOp : output bit[2]        |
| + memWrite : output bit        |
| + aluSrc : output bit          |
| + regWrite : output bit        |
| + jump : output bit            |
| - 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                                           |  |  |  |  |  |  |  |
|---------------|---------|---------|-----------------------------------------------------|--|--|--|--|--|--|--|
| clock         | 1       | entrada | Clock do sistema                                    |  |  |  |  |  |  |  |
| reset         | 1       | entrada | Sinal de reinício do estágio                        |  |  |  |  |  |  |  |
| instruction   | 32      | entrada | Instrução a ser executada.                          |  |  |  |  |  |  |  |
| writeData     | 1       | entrada | Sinal de controle para escrita no registra-<br>dor. |  |  |  |  |  |  |  |
| writeRegister | 5       | entrada | Endereço do registrador de destino do writeData.    |  |  |  |  |  |  |  |



| Nome     | Tamanho | Direção | Descrição                                                                                          |  |  |  |  |  |  |
|----------|---------|---------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| word     | 16      | entrada | Os primeiros 16 bits da 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 campo 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, MUL e DIV |
| 2      | ADDI                            |
| 3      | ANDI                            |
| 4      | SUBI                            |
| 5      | ORI                             |
| 6      | SW                              |
| 7      | LW                              |
| 8      | JR                              |



| Código | Instrução |
|--------|-----------|
| 9      | JPC       |
| 10     | BRFL      |
| 11     | CALL      |
| 12     | RET       |
| 13     | HALT      |
| 14     | NOP       |
| 15     | СМР       |

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



#### 2.4. Datapath Interno





# 3. Estágio de execução

#### 3.1. Diagrama de Classe

# **Execute Operation** + clock : input bit + reset : input bit + data\_a : input bit[32] + data\_b : input bit[32] + pc\_in : input bit[32] + pc\_1: input bit [32] + immediate: input bit [32] + immediate\_div\_4: input bit [32] + stack: input bit [32] + data\_a\_select: input bit [2] + data\_b\_select: input bit [2] + pc\_select: input bit [2] + alu\_control: input bit [2] + func: input bit [6] + result: output bit [32] + flag: output bit [3] + next\_pc: output bit [32] + «comb» calc\_next\_pc() + «comb» cal\_al\_operation()

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

| Nome      | Tamanho | Direção | Descrição                    |
|-----------|---------|---------|------------------------------|
| clock     | 1       | Entrada | Clock do sistema             |
| reset     | 1       | Entrada | Sinal de reinício do estágio |
| data_a    | 32      | Entrada | Dado do primeiro operando    |
| data_b    | 32      | Entrada | Dado do segundo operando     |
| pc_in     | 32      | Entrada | Valor do PC atual            |
| pc_1      | 32      | Entrada | Valor de PC + 1              |
| immediate | 32      | Entrada | Constante numérica           |



| Nome            | Tamanho | Direção | Descrição                                                                  |
|-----------------|---------|---------|----------------------------------------------------------------------------|
| immediate_div_4 | 32      | Entrada | Contante numérica                                                          |
| stack           | 32      | Entrada | Valor do PC proveniente da Pilha de Instruções                             |
| data_a_select   | 2       | Entrada | Sinal para selecionar o conteúdo do pri-<br>meiro operando                 |
| data_b_select   | 2       | Entrada | Sinal para selecionar o conteúdo do se-<br>gundo operando operando         |
| pc_select       | 2       | Entrada | Sinal para selecionar o endereço da pró-<br>xima instrução a ser executada |
| alu_control     | 2       | Entrada | Sinal informa qual o tipo da operação que será realizada                   |
| func            | 6       | Saída   | Variante especifica da operação                                            |
| result          | 32      | Saída   | Resultado da operação                                                      |
| flag            | 3       | Saída   | Informações sobre o resultado da operação                                  |
| next_pc         | 32      | Saída   | Endereço da próxima instrução a ser executada                              |



## 3.3. Datapath Interno





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

#### 4.1. Diagrama de Classe

#### **Acess Memory**

- + clock : input bit
- + reset : input bit
- + address : input bit[11]
- + memRead : input bit
- + memWrite : input bit
- writeData : input bit[32]
- writeBack : output bit[32]
- +«comb» accessMem()

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

| Nome      | Tamanho | Direção | Descrição                                                               |
|-----------|---------|---------|-------------------------------------------------------------------------|
| address   | 11      | entrada | Endereço da memória de dados 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 es-<br>crita                       |
| writeData | 32      | entrada | Dado a ser escrito na memória.                                          |
| writeBack | 32      | saída   | Dado proveniente da ALU que será es-<br>crito no bloco de registradores |

#### 4.3. Datapath Interno

# 5. Datapath Externo

