

Câmpus Venâncio Aires

## Arquitetura e Organização de Computadores

Professor: Fernando Luís Herrmann

E-mail: fernandoherrmann@ifsul.edu.br



Tecnólogo em Análise e Desenvolvimento de Sistemas 2022

### Material de aula:

https://github.com/herrmannfl/tads-aoc-2022





### Arquiteturas Didáticas

| Arquitetura | Endereços            | Dados   | Instruções                                        | Registradores                                        |
|-------------|----------------------|---------|---------------------------------------------------|------------------------------------------------------|
| NEANDER     | 8 bits<br>256 bytes  | 8 bits  | 11 instruções<br>(opcode: 4bits)                  | AC, PC, IR, Flags (N,Z)<br>REM, RDM                  |
| AHMES       | 8 bits<br>256 bytes  | 8 bits  | 24 instruções Neander<br>extendido                | PC, IR, Flags (N, Z, C,, V)<br>REM, RDM              |
| RAMSES      | 8 bits               | 8 bits  | Modos de endereçamento<br>4 modos x 16 instruções | PC, IR, RA, RB, RX,<br>Flags (N,Z, C, V)<br>REM, RDM |
| CESAR       | 16 bits<br>64 KBytes | 16 bits | Inúmeras                                          | R0 a R6 (uso geral)<br>R7 (PC)                       |

# Simulador Ramses







# Características gerais

- Largura de dados e de endereços de 8 bits
- Dados representados em complemento de dois
- 4 modos de endereçamento: direto, indireto, imediato e indexado
- 2 registradores de uso geral de 8 bits
- 1 registrador de índice de 8 bits
- 1 apontador de programa de 8 bits
- 1 registrador de estado com 3 códigos de condição: negativo, zero e carry

### **Arquitetura Ramses**



### Conjunto de Instruções RAMSES

| Código | Instrução | Operação                                                                                |            |             | Г,      | VOW.       | anla                           |            |                       |       |  |  |
|--------|-----------|-----------------------------------------------------------------------------------------|------------|-------------|---------|------------|--------------------------------|------------|-----------------------|-------|--|--|
| 0000   | NOP       | Nenhuma operação                                                                        |            |             |         |            | Exemplo: 0010 0100             |            |                       |       |  |  |
| 0001   | STR r,end | Armazena registrador "r" no endereço "end" da memória                                   |            |             |         |            |                                |            |                       |       |  |  |
| 0010   | LDR r,end | Carrega o registrador "r" com o conteúdo do endereço "end" da memória                   |            |             |         |            |                                |            |                       |       |  |  |
| 0011   | ADD r,end | Soma o conteúdo do endereço "end" da memória ao registrador "r"                         |            |             |         |            | *                              |            |                       |       |  |  |
| 0100   | OR r,end  | Efetua operação lógica "OU" do conteúdo do endereço "end" da memória ao registrador "r" |            |             |         |            | 0010 - LDR<br>01 - Registrador |            |                       |       |  |  |
| 0101   | AND r,end | Efetua operação lógica "E" do conteúdo do endereço "end" da memória ao registrador "r"  |            |             |         |            |                                |            |                       |       |  |  |
| 0110   | NOT r     | Inverte todos os bits do registrador "r"                                                |            |             |         |            |                                |            | aaoi                  |       |  |  |
| 0111   | SUB r,end | Subtrai o conteúdo do endereço "end" da memória ao registrador "r"                      |            |             | 00      | ) -        | - Mo                           | do         |                       |       |  |  |
| 1000   | JMP end   | Desvio incondicional para o endereço "end" da memória                                   | Códigos    | das inst    | trucões |            |                                |            |                       | ×     |  |  |
| 1001   | JN end    | Desvio condicional, se "N=1", para o endereço "end" da memória                          |            |             |         | MD         | 00                             |            | Modo:                 |       |  |  |
| 1010   | JZ end    | Desvio condicional, se "Z=1", para o endereço "end" da memória                          | NOP<br>STR | 0<br>- 10 r |         | MP<br>N    | 80<br>90                       | end<br>end | 0: Dir:               | n     |  |  |
| 1011   | JC end    | Desvio condicional, se "C=1", para o endereço "end" da memória                          | LDR        |             |         | Z          |                                | end        | 1: Ind:               |       |  |  |
| 1100   | JSR end   | Desvio para subrotina no endereço "end" da memória                                      | ADD        |             |         | C          | B0                             | end        | 2: Imd:<br>3: Idx:    |       |  |  |
| 1101   | NEG r     | Troca o sinal do registrador "r"                                                        | OR         |             |         | SR         | C0                             | end        | J. 10A.               | 11,63 |  |  |
| 1110   | SHR r     | Desloca o registrador "r" um bit para a direita                                         | AND        | 50 r        | end N   | 4EG        | D0                             | r          | _Registr <sub>i</sub> |       |  |  |
| 1111   | HLT       | Para o ciclo de busca-decodificação-execução                                            | NOT        | 60 r        | 9       | HR         | E0                             | r          |                       | 2: X  |  |  |
|        | 1         |                                                                                         | SUB        | - 70 m      | end   H | <b>ILT</b> | F0                             |            | 1: B                  | 3: ?  |  |  |



### Modos de Endereçamento

```
OpCode Oper R ME
                 Mnemônico
                                Modo Enedereçamento
 20 = 0010 0000 LDR A, Valor
                              - Modo Direto
22 = 0010 0010 LDR A, #00
                              - Modo Imediato A
 24 = 0010 0100
                 LDR B, Valor
                               - Modo Direto
26 = 0010 0110 LDR B, #00
                              - Modo Imediato B
 2A = 0010 1010
                 LDR X,#00
                              - Modo Imediato X
 20 = 0010 0000 LDR A, Valor
                              - Modo Direto
 51 = 0010 0001
                 LDR A,Ptr,I

   Modo Indireto A

 22 = 0010 0010
                 LDR A,#00
                              - Modo Imediato A
 23 = 0010 0011
                 LDR A, Vet, X
                              - Modo Indexado A com X
```

Questão 1. Implemente um código Assembly que seja capaz de efetuar uma subtração. As posições de memória 128 e 129 devem conter, respectivamente, o minuendo e o subtraendo. O resultado deverá ser armazenado na posição 130.

#### **NEANDER**



### RAMSES



### **RAMSES**

Questão 2. Implemente um código que seja capaz de calcular o endereço da rede a qual um IPv4 pertence dados o IPv4 e a Máscara. A memória de dados deve ser organizada da seguinte forma:

Palavras 128, 129, 130 e 131 – Bytes do IPv4 Palavras 132, 133, 134, 135 – Bytes da Máscara Palavras 136, 137, 138, 139 – IP da rede calculado

#### Código Fonte:

ORG 0 inicio: LDR X, #0 LDR A. IPv4.X loop: AND A, Mascara, X A, Result, X STR X, Temp SUB X. #4 JZ fim LDR X, Temp JMP loop fim: HLT ORG 128 DAB 10,10,10,1

IPv4: Mascara:DAB 255,0,0,0 Result: DAB 0,0,0,0

DB 0Temp: