#### Arquitetura e Organização de Computadores 1



ISA: Arquitetura do Conjunto de Instruções
Parte 2

Luciano de Oliveira Neris

luciano@dc.ufscar.br

Adaptado de slides do prof. Marcio Merino Fernandes

Fonte: http://www.techspot.com/article/904-history-of-the-personal-computer-part-5

Departamento de Computação Universidade Federal de São Carlos





#### ISA: Endereçamento

- Uma instruções é composta em sua maioria de um opcode e de alguma informação adicional: de onde vêm os operandos e para onde vão os resultados.
- Especificar onde os operandos estão, ou seja, os seus endereços é denominado de Endereçamento
- Toda ISA deve definir como endereços de memória são especificados em instruções (Load/Store), e interpretados

#### ISA: Endereçamento

- A maioria das ISAs é endereçada byte-a-byte
  - A menor porção de memória que pode ser endereçada é um byte
  - Cada byte tem um endereço, representado por uma sequencia de bits
    - Ex: Se eu tenho 128 bytes de RAM endereçável, cada byte tem um endereço composto por 7 bits;

| Endereço | Byte 0 | Byte 1 | Byte 2 | Byte 3 |
|----------|--------|--------|--------|--------|
| 0        |        |        |        |        |
| 4        | 13     | 23     |        |        |
| 8        |        |        |        |        |
| 12       |        |        |        |        |
| 16       |        |        |        |        |
|          |        |        |        |        |

#### ISA: Endereçamento

- Normalmente, uma ISA permite acesso a:
  - bytes (8 bits)
  - half words (16 bits)
    - C (short integers)
    - Útil quando o tamanho das estrutura de dados é importante (e.g., O/S)
    - Caracteres Unicode
  - words (32 bits)
  - double words (64 bits)

- Na maioria dos computadores, o acesso a objetos maiores que um byte deve ser alinhado.
- Uma palavra de 4 bytes, por exemplo, em uma arquitetura alinhada pode começar no endereço 0, 4, 8, etc., mas não no endereço 1 ou 2.
- Ler 1 endereço arbitrário requer um hardware mais sofisticado e é mais caro



 Definição de Alinhado: Um objeto de tamanho S bytes está alinhado se o seu endereço é um múltiplo de S (i.e., @ mod S = 0)

#### • Exemplo:

- Acessando 1 byte no endereço 000000: alinhado
- Acessando 1 half word no endereço 000001: NÃO alinhado

```
1 \mod 2 = 1
```

- Acessando 1 half word no endereço 000010: alinhado
- Acessando 1 double word no endereço 011000: alinhado
   24 mod 8 = 0



. . .

- Por que Alinhamento?
- Explicação Simples: O hardware fica mais simples
  - O hardware de acesso à memória é construído de modo a permitir o acesso alinhado a objetos de tamanho elevado (ex: double word)
  - Assim, o acesso a objetos mal-alinhados aumentaria o número de acessos à memória, reduzindo o desempenho do sistema.
  - Exemplo:



## ISA: Alinhamento de Registradores

 A CPU possui vários registradores, podendo armazenar bytes, half words, words, or double words:



## ISA: Alinhamento de Registradores

- Quando algum dado ou instrução é carregado da memória p/ um registrador (Load), uma double word é lida e colocada em um registrador de 64-bits
- Assumindo que apenas um tamanho de leitura é possível, o hardware se torna mais simples.
- Além disso, o tempo para transmitir 8 sinais em paralelo (1 byte) e 64 sinais em paralelo (1 doubleword), é o mesmo

#### ISA: Memória para Dados e Instruções

- Outra decisão importante com relação ao acesso à memória é se a faixa de endereços da memória de dados será a mesma da memória de instruções.
- Com a criação das Arquiteturas Harvard os dados passaram a ser armazenados em áreas de memória separadas das instruções.
- Isso ajuda principalmente no Pipeline, porque a CPU pode, no mesmo ciclo, buscar uma instrução e buscar os dados de uma outra instrução.

 Questão importante: como os bytes são representados e referenciados dentro de uma palavra ou como os bits são representados e referenciados dentro de um byte.

• Ex.: valor hexadecimal 12345678

| Endereço | Valor  | Endereço | Valor  |
|----------|--------|----------|--------|
| 184      | 12     | 184      | 78     |
| 185      | 34     | 185      | 56     |
| 186      | 56     | 186      | 34     |
| 187      | 78     | 187      | 12     |
| big-     | endian | little-e | endian |

 Little Endian: O byte cujo endereço é x...x000 é colocado na posição menos significativa, ou seja o "little end"

Ex: IA-32, x86

 Big Endian: O byte cujo endereço é x...x000 é colocado na posição mais significativa, ou seja o "big end"

Ex: Sparc

 Algumas arquitetura permitem as duas opções, configuradas em software (at boot up) ou na motherboard

PowerPC, IA64, MIPS

- Por que a ordenação é importante?
  - Geralmente, isso é transparente ao usuário
  - Mas pode ser um problema quando o mesmo endereço de memória é acessado como doubleword ou word ou byte.
  - Diferenças na ordenação causam problemas na troca de dados entre computadores.

Ex: IP define a ordenação de bytes em redes como Big Endian

Em uma máquina Big Endian

```
#include <stdio.h>
int main() {
   struct {
     int x;
     char y;
   } data;
   data.x = 0x61626364;
   data.y = ' \setminus 0';
   printf("--> '%s'\n",(char*)&data);
```

a b c d 0

Em uma máquina Little Endian

```
#include <stdio.h>
int main() {
   struct {
     int x;
     char y;
   } data;
   data.x = 0x61626364;
  data.y = ' \ 0';
  printf("--> '%s'\n",(char*)&data);
```

d | c | b | a | \0

 O bit de menor ordem é o bit menos significativo do byte (little-endian) ou é o bit mais significativo do byte (big-endian)?

- Os modos de endereçamento são um aspecto da Arquitetura do conjunto de instruções nos projetos das CPUs.
- Os vários modos de endereçamento definidos em uma ISA determinam como as instruções da linguagem de máquina identificam os operandos de cada instrução.

- Modo como os bits do um campo de endereço são interpretados para encontrar o operando:
  - Imediato
  - Direto ou Absoluto
  - Registrador
  - Indireto de registrador
  - Indireto de memória
  - Deslocamento
  - Indexado

#### Endereçamento imediato

- Forma mais simples de endereçamento é o endereçamento imediato, no qual o valor do operando é especificado diretamente na instrução. Pode ser usado para definir e usar constantes ou para atribuir valores iniciais em variáveis.
- Vantagem: não requerer qualquer acesso à memória para obter o operando além do acesso para obter a própria instrução, economizando, portanto, um ciclo de cache ou de memória no ciclo de instrução.
- Desvantagem: tamanho do operando é limitado pelo tamanho do campo de endereço.

| Instrução | 1 1 442 |
|-----------|---------|
| Operando  | Load #3 |

- Endereçamento direto ou absoluto
  - Forma muito simples de endereçamento, no qual o campo de endereço contém o endereço efetivo do operando
  - Vantagem: requer apenas um acesso à memória e nenhum cálculo especial.
  - Desvantagem: fornece um espaço de endereçamento limitado.



Load (1001)

- Endereçamento por Registrador
  - Um ou mais operandos está em registradores (inclusive o operando de destino)

#### Load R3



- Endereçamento indireto por Registrador
  - O campo de endereço contém o registrador que armazena a localização do operando na memória
  - Endereço intermediário: ponteiro

Load (R1)



- Endereçamento indireto de Memória
  - O campo de endereço contém o registrador que armazena a localização do endereço do operando na memória
  - Endereços intermediário: ponteiro para ponteiro



#### Deslocamento

 Esta técnica combina as técnicas de endereçamento direto e do endereçamento indireto por registrador.
 Esta técnica obriga que a instrução tenha dois campos de endereço

Load 100(R1)



#### Indexado

- O Campo do endereço referencia a memória principal e o registrador de referência contém um deslocamento positivo a partir dessa posição de memória
- Utilizado no acesso aos elementos de um vetor (R1=base, R2=índice)

Load (R1+R2)

| Register<br>(Registrador)              | Add R4, R3      | Regs[R4] ← Regs[R4] + Regs[R3]                            |
|----------------------------------------|-----------------|-----------------------------------------------------------|
| Immediate (Imediato/cte)               | Add R4, #3      | Regs[R4] $\leftarrow$ Regs[R4] + 3                        |
| Displacement (Deslocamento)            | Add R4, 100(R1) | Regs[R4] $\leftarrow$ Regs[R4] + Mem[100 + Regs[R1]]      |
| Register Indirect (Indireto/Ponteiro)  | Add R4, (R1)    | Regs[R4] ← Regs[R4] + Mem[Regs[R1]]                       |
| Indexed (Indexado)                     | Add R3, (R1+R2) | Regs[R3] $\leftarrow$ Regs[R3] + Mem[Regs[R1] + Regs[R2]] |
| Direct (Direto)                        | Add R1, (1001)  | $Regs[R1] \leftarrow Regs[R1] + Mem[1001]$                |
| Memory Indirect (Ponteiro p/ Ponteiro) | Add R1, @(R3)   | Regs[R1] ← Regs[R1] + Mem[Mem[Regs[R3]]]                  |

| Autoincrement | Add R1, (R2)+       | Regs[R1] ← Regs[R1] + Mem[Regs[R2]]  Regs[R2] ← Regs[R2] + d  (d: size of an array element) |
|---------------|---------------------|---------------------------------------------------------------------------------------------|
| Autodecrement | Add R1, -(R2)       | $Regs[R2] \leftarrow Regs[R2] - d$ $Regs[R1] \leftarrow Regs[R1] + Mem[Regs[R2]]$           |
| Scaled        | Add R1, 100(R2)[R3] | $Regs[R1] \leftarrow Regs[R1] + Mem[100+Regs[R2] + Regs[R3] * d]$                           |

- Algumas ISAs incluem todos esses modos (ex: VAX), outras apenas alguns (ex: MIPS)
- Quais são as vantagens/desvantagens?
  - Quanto mais modos de endereçamento, menor o instruction count (IC)
  - Quanto mais modos de endereçamento, mais complexo é o hardware
  - Quanto mais modos de endereçamento, maior o número médio clock cycles necessários para executar uma instrução
- Objetivo: Encontrar um bom ponto de equilíbrio entre hardware mais simples e um número suficiente de modos de endereçamento, de modo que escrever código não seja tão difícil

 Lição: Apenas alguns poucos modos são utilizados c/ frequência



#### Arquitetura de X-bits?

- O que significa:
  - Uma arquitetura de 32-bits?
  - Uma arquitetura de 64-bits?
- Infelizmente não existe uma definição clara...
  - Pode ser usado p/ descrever que inteiros e endereços de memória são armazenados (codificados) em X bits
  - Pode ser usado p/ descrever uma CPU (ou ALU) que utiliza registradores de X bits
  - Pode ser usado p/ descrever um computador possuindo um barramentos de dados de X bits
- Em geral, quando se diz "uma arquitetura de X-bits" refere-se a um sistema que manipula grupos de X-bits representando valores inteiros (dados e endereços), registradores e barramentos de dados. Porém, existem diversas variações...

# Arquitetura de X-bits?

Processadores Intel e compatíveis

| Processador                      | Barramento<br>CPU-Memória | Registradores |
|----------------------------------|---------------------------|---------------|
| 8088                             | 8-bit                     | 16-bit        |
| 8086                             | 16-bit                    | 16-bit        |
| 286                              | 16-bit                    | 16-bit        |
| 3865X                            | 16-bit                    | 32-bit        |
| 386DX                            | 32-bit                    | 32-bit        |
| 486/AMD-5×86                     | 32-bit                    | 32-bit        |
| Pentium/AMD-K6                   | 64-bit                    | 32-bit        |
| PentiumPro/Celeron               | 64-bit                    | 32-bit        |
| AMD Duron / Ahtlon/ Athlon<br>XP | 64-bit                    | 32-bit        |
| Pentium 4                        | 64-bit                    | 32-bit        |
| IA64                             | 64-bit                    | 64-bit        |
| AMD Athlon 64                    | 64-bit                    | 64-bit        |

# ISA: Tipos de Instruções

| ſ                  | Aritmética e<br>Lógica    | Integer add, subtract, multiply, divide, and, or,                                |  |  |
|--------------------|---------------------------|----------------------------------------------------------------------------------|--|--|
| universal <b>{</b> | Transferência de<br>Dados | load and stores                                                                  |  |  |
|                    | Control Flow              | Branch, jump, procedure (function, method, etc.) call and return, traps          |  |  |
| variável {         | Sistema                   | Chamadas de primitivas do 5.0., Instruções para gerenciar a memória virtual, etc |  |  |
|                    | Ponto Flutuante           | add, multiply, divide, compare                                                   |  |  |
| opcional           | String                    | string compare, string search                                                    |  |  |
|                    | Graphics                  | pixel and vertex operations, compression/decompression operations                |  |  |

- Transferência de dados: tipo mais fundamental de instrução de máquina
  - Deve especificar os endereços dos operandos fonte e de destino da operação.
  - Cada endereço pode indicar uma posição de memória, Um registrador ou o topo da pilha.
  - Deve indicar o tamanho dos dados a serem transferidos.
  - Como em todas as instruções com operandos, deve especificar o modo de endereçamento de cada operando

- Instruções de sistema
  - São aquelas que apenas podem ser executadas quando o processador está no estado privilegiado ou está executando um programa carregado em uma área especial da memória, que é privilegiada
  - Tipicamente, elas são reservadas para uso pelo sistema operacional

- Instruções de controle de fluxo
  - Geralmente a próxima instrução a ser executada é aquela que segue imediatamente, na memória, a instrução corrente
  - No entanto, uma parte considerável das instruções de qualquer programa tem como função alterar a sequência de execução de instruções
  - Nessas instruções, a CPU atualiza o contador de programa com o endereço de alguma outra instrução armazenada na memória

- Instruções de controle de fluxo
  - Control Flow Instructions: permitem ao program counter (PC) saltar para uma instrução que não seja a próxima na sequencia (o default)
  - Necessárias por:
    - Executar várias vezes um mesmo conjunto de instruções
    - Executar uma determinada sequência de operações se uma determinada condição é satisfeita
    - Divisão de programas em partes

- Instruções de controle de fluxo
  - O PC contém o endereço da instrução sendo executada. Por default, PC =PC + 1 após a execução da instrução corrente. Terminologia:
    - Branch: quando for condicional
    - Jump: quando for incondicional
  - Existem 4 tipos de instruções de controle de fluxo:
    - Conditional branches (desvio condicional)
    - Jumps (desvio/salto)
    - Procedure calls (chamada de procedimento)
    - Procedure returns (retorno de procedimento)

#### Instruções de controle de fluxo: Desvio

- Um de seus operandos é o endereço da próxima instrução a ser executada
- Desvio condicional: o desvio será feito apenas se uma dada condição for satisfeita (o contador de programa é atualizado com o endereço especificado no operando). Caso contrário o PC é incrementado

- Instruções de controle de fluxo: Desvio
  - Desvio condicional:

```
bre r1, r2, L1
XXX
```

УУУ

L1: ZZZ

Branch to L1 if contents of R1 = Contents of R2

- Instruções de controle de fluxo: Desvio
  - Desvio incondicional:

L1:

```
jump L1
XXX
YYY
ZZZ
```

As instruções XXX e YYY não são executadas

- Instruções de controle de fluxo: Chamada de Procedimento
  - Procedimento: um subprograma autocontido, que é incorporado em um programa maior e pode ser invocado (chamado) de qualquer ponto
  - Instrui o processador a executar todo o procedimento e retornar ao ponto de chamada, o que envolve duas instruções básicas:
    - Chamada: desvia a execução da instrução corrente para o início do procedimento;
    - Retorno: provoca o retorno da execução do procedimento para o endereço em que ocorreu a chamada.

- Instruções de controle de fluxo: Chamada de Procedimento
  - Considerando que CALL X, em linguagem máquina, representa uma chamada ao procedimento de endereço X e o endereço de retorno é armazenado em registrador:

### ISA: Instruções Executadas Frequentemente

#### □ Fonte dos dados: **SPEC Benchmark on 80x86:**

| Load                        | 22% |
|-----------------------------|-----|
| Conditional branch (desvio) | 20% |
| Compare                     | 16% |
| Store                       | 12% |
| Add                         | 8%  |
| And                         | 6%  |
| Sub                         | 5%  |
| Move register-register      | 4%  |
| Call                        | 1%  |
| Return                      | 1%  |
| Other                       | 4%  |

**Observação**: 10 instruções simples correspondem a 96% de todas as instruções

Lição 1: Projeto a CPU de modo que elas executem eficientemente ("make the common case fast")

Lição 2: É duvidoso se vale a pena implementar muitas outras instruções sofisticadas.

Esta são as motivações da mudança de paradigma de CISC para RISC (ver slides mais adiante)

### ISA: Instruções de Fluxo de Controle

 Conditional branches são muito mais frequentes que outras instruções de fluxo de controle



© 2003 Elsevier Science (USA). All rights reserved.

\*Útil p/ determinar quais instruções serão implementadas na arquitetura, ou de maneira mais eficiente.

#### **ISA: Conditional Branches**

\*Útil p/ determinar quais instruções serão implementadas na arquitetura, ou de maneira mais eficiente.



### Codificando a ISA

- O formato das instruções define a forma como os campos são distribuídos
- Para cada possível instrução da ISA:
  - Escolha uma sequencia única de bits para representá-la (chamado opcode, ou código da operação)
  - Represente os operandos também como sequencia de bits.
     Cada operando explícito tem de ser referenciado utilizando um dos métodos descritos anteriormente (endereçamento)
  - Construa blocos de hardware para decodificar e executar cadas uma das instruções (ou seja, a CPU).

### Codificando a ISA

- Formato (codificação) de instruções fixo ou variável ?
- Três forças conflitantes:
  - #1: Desejo de se ter o maior número possível de registradores e modos de endereçamento → codificação longa
  - #2:Desejo de reduzir o tamanho do programa executável → codificação curta
  - #3: Desejo de se ter instruções que são fáceis de decodificar, com tamanho sendo múltiplo de bytes, e não arbitrário.
  - Na prática, as soluções mais populare são:
  - Formato variável (forças #1 and #2)
  - Formato fixo (força #3)
  - Formato híbrido (tentativa de encontrar um bom balanceamentó)

### Codificando a ISA – Tamanho das Instruções

Operation and no. of operands specifier 1 Address field 1 Address specifier 5 Address specifier 5 Address specifier 6 Address specifier 6 Address specifier 6 Address specifier 7 Address specifier 7 Address specifier 7 Address specifier 8 Address specifier 8 Address specifier 8 Address specifier 9 Address

(a) Variable (e.g., VAX, Intel 80x86)

| Operation | Address | Address | Address |
|-----------|---------|---------|---------|
|           | field 1 | field 2 | field 3 |

(b) Fixed (e.g., Alpha, ARM, MIPS, PowerPC, SPARC, SuperH)

| Operation | Address<br>specifier | Address<br>field |
|-----------|----------------------|------------------|
|           | opeomer              | noid             |

| Operation | Address     | Address     | Address |
|-----------|-------------|-------------|---------|
|           | specifier 1 | specifier 2 | field   |

| Operation | Address   | Address | Address |
|-----------|-----------|---------|---------|
|           | specifier | field 1 | field 2 |
|           | оросино   | 11010 1 | 11010 = |

(c) Hybrid (e.g., IBM 360/70, MIPS16, Thumb, TI TMS320C54x)

## Codificação de Instruções MIPS

#### MIPS:

- Tamanho de Instrução:
  - Fixo 32 bits
- Codificação:
  - Variável 3 tipos
- Detalhes: Próxima Aula →



- A redução do custo do hardware e a crescente utilização dos sistemas computacionais tornaram o custo do software maior no ciclo de vida de um sistema do que o do hardware.
- Solução: desenvolvimento de linguagens de programação de alto nível cada vez mais poderosas e complexas.
  - Permitem expressar algoritmos de maneira mais concisa, abstraindo detalhes de máquina, e oferecem suporte à programação estruturada e ao projeto orientado a objetos.

- Problema: a grande distância semântica entre as operações disponíveis em linguagens de alto nível e as operações disponibilizadas pelo hardware
  - Ineficiência na execução de programas, tamanho excessivo dos programas e grande complexidade dos compiladores.
- Solução: desenvolvimento de arquiteturas que diminuíssem a distância entre instruções de linguagens de alto nível e instruções de máquina
  - Grandes conjuntos de instruções, dúzias de modos de endereçamento e implementação de diversos comandos de linguagens de alto nível no hardware da máquina.

- Questionamento: muitas das instruções complexas são de fato necessárias nos programas "típicos"?
- Estudos realizados mostram os comandos mais utilizados pelos programas. Eles se concentram em alguns poucos comandos, em geral bastante simples

| Carga      | Huck, 1983 –<br>Pascal | Knuth, 1971<br>FORTRAN | Patterson e<br>Sequin, 1982 - | Patterson e<br>Sequin, 1982 - | Tanenbaum,<br>1978 – |
|------------|------------------------|------------------------|-------------------------------|-------------------------------|----------------------|
|            | Científico             |                        | Pascal                        | c                             | Sistema SAL          |
| Assignment | 74                     | 67                     | 45                            | 38                            | 42                   |
| Loop       | 4                      | 3                      | 5                             | 3                             | 4                    |
| Call       | 1                      | 3                      | 15                            | 12                            | 12                   |
| IF         | 20                     | 11                     | 29                            | 43                            | 36                   |
| GOTO       | 2                      | 9                      | -                             | 3                             | -                    |
| Outras     | -                      | 7                      | 6                             | 1                             | 6                    |

Esses estudos sobre o comportamento da execução de programas em linguagens de alto nível orientaram o projeto de um novo tipo de arquitetura para processadores: o computador com um conjunto reduzido de instruções (Reduced Instruction set computer - RISC)

- CISC: Complex Instruction Set Computer
  - □ Cada instrução é "complexa" → faz várias operações.
    - Ex: lê um dado da memória, faz uma operação aritmética, armazena o resultado na memória, tudo isso c/ uma única instrução.
  - A ideia é aproximar o hardware das instruções de linguagens de alto nível.
  - Estratégia interessante na era "pré-compiladores".

#### RISC: Reduced Instruction Set Computer

- Surgiu após os sistemas CISC, motivado por vários fatos:
  - A maioria dos programas utiliza apenas uma pequena fração das instruções disponíveis na ISA;
  - A construção de hardware para executar instruções complexas (e pouco utilizadas) resultava em hardware lento também para executar as instruções simples (e frequentes).
  - Instruções complexas são mais difíceis de decodificar
  - Instruções complexas necessitam de vários ciclos de clock para executar
  - Com os avanços em VLSI, implementar registradores se tornou mais barato, viabilizando o projeto mais eficientes.
  - Compiladores funcionam melhor quando as instruções de máquinas são mais simples.
  - Popularização no uso da técnica de pipelining para a construção de CPUs.

#### Filosofia chave diferenciando RISC de CISC:

- Não há microprograma para interpretar as instruções. Existe um conjunto reduzido de instruções simples RISC parecidas com as microinstruções da arquitetura CISC.
- Em RISC os operandos são registradores idênticos (em número razoável)
- Use operações load e store para fazer a comunicação memória
   -> registradores, usando modos de endereçamento simples.
- O código resultante é uma série mais longa de instruções simples.
- Obs: Muitos preferem o termo "arquitetura load-store" para se referir a RISC

121

- O termo "CISC" surgiu após as arquiteturas RISC serem desenvolvidas, apenas p/ diferenciar de RISC
- Note que RISC não é uma boa opção quando o tamanho do código dos programas executáveis deve ser o menor possível
  - Não é problema para desktops e servidores
  - Problema sério p/ sistemas embarcados

From Computer Desktop Encyclopedia

@ 1998 The Computer Language Co. Inc.





#### Máquinas CISC usam codificação variável

| Operation and   | Address     | Address | <br>Address   | Address |
|-----------------|-------------|---------|---------------|---------|
| no. of operands | specifier 1 | field 1 | <br>specifier | field   |

(a) Variable (e.g., VAX, Intel 80x86)

#### Máquinas RISC usam codificação fixa:

| Operation | Address | Address | Address |
|-----------|---------|---------|---------|
|           | field 1 | field 2 | field 3 |

(b) Fixed (e.g., Alpha, ARM, MIPS, PowerPC, SPARC, SuperH)

|                               | CISC           |               |                | RISC        |               |  |
|-------------------------------|----------------|---------------|----------------|-------------|---------------|--|
| Modelo                        | IBM<br>370/168 | VAX<br>11/780 | Intel<br>80486 | Sparc       | MIPS<br>R4000 |  |
| Ano desenv.                   | 1973           | 1978          | 1989           | 1987        | 1991          |  |
| Num.<br>instruções            | 208            | 203           | 235            | 69          | 94            |  |
| Tam. instrução (bytes)        | 2 a 6          | 2 a 57        | 1 a 11         | 4           | 4             |  |
| Modos de<br>endereçam.        | 4              | 22            | 11             | 1           | 1             |  |
| Num. de reg.<br>prop. geral   | 16             | 16            | 8              | 40 a<br>520 | 32            |  |
| Tam. mem.<br>Controle (kbits) | 420            | 480           | 246            | -           | -             |  |
| Tam. cache<br>(kbytes)        | 64             | 64            | 8              | 32          | 128           |  |