## MC404

# ORGANIZAÇÃO BÁSICA DE COMPUTADORES E LINGUAGEM DE MONTAGEM

2009

Prof. Paulo Cesar Centoducatte

<u>ducatte@ic.unicamp.br</u>

www.ic.unicamp.br/~ducatte

## MC404

## ORGANIZAÇÃO BÁSICA DE COMPUTADORES E LINGUAGEM DE MONTAGEM

"Organização de Memória e Modos de Endereçamento"

## Organização de Memória e Modos de Endereçamento Sumário

- · Organização de Memória do Atmega88
  - Memória de Programa Flash
  - Memória de Dados
    - · SRAM
    - · EEPROM
- Modos de Endereçamento





Figure 4-2. AVR CPU General Purpose Working Registers

General Purpose Working Registers

| 7  | 0 | Addr. |                      |
|----|---|-------|----------------------|
| Ri | 0 | 0x00  |                      |
| R  | 1 | 0x01  |                      |
| R  | 2 | 0x02  |                      |
|    |   | Ī     |                      |
| R1 | 3 | 0x0D  |                      |
| R1 | 4 | 0x0E  |                      |
| R1 | 5 | 0x0F  |                      |
| R1 | 6 | 0x10  |                      |
| R1 | 7 | 0x11  |                      |
|    |   |       |                      |
| R2 | 8 | 0x1A  | X-register Low Byte  |
| R2 | 7 | 0x1B  | X-register High Byte |
| R2 | 8 | 0x1C  | Y-register Low Byte  |
| R2 | 9 | 0x1D  | Y-register High Byte |
| R3 | 0 | 0x1E  | Z-register Low Byte  |
| R3 | 1 | 0x1F  | Z-register High Byte |
|    |   | _     |                      |



## AVR ATmega48/88/168 Memories

### In-System Reprogrammable Flash Program Memory

Program Memory Map, ATmega88 and ATmega168 Program Memory 0.0000 Application Flash Section Boot Flash Section 0x0FFF/0x1FFF

## SRAM Data Memory

## Data Memory

32 Registers

64 I/O Registers

160 Ext I/O Reg.

Internal SRAM (512/1024/1024 x 8) 0x0000 - 0x001F

0x0020 - 0x005F

0x0060 - 0x00FF

0x0100

0x02FF/0x04FF/0x04FF

## **EEPROM Data Memory**

| The EEPROM Address | Register - | - EEARH and | EEARL |
|--------------------|------------|-------------|-------|
|--------------------|------------|-------------|-------|

| Bt           | 15     | 14    | 13    | 12    | 11    | 10    | 9     | 8     | _     |
|--------------|--------|-------|-------|-------|-------|-------|-------|-------|-------|
|              | -      | -     | -     | -     | -     | -     | -     | EEAR8 | EEARH |
|              | EE AR7 | EEAR6 | EEAR5 | EEAR4 | EEAR3 | EEAR2 | EEAR1 | EEAR0 | EEARL |
|              | 7      | 8     | 5     | 4     | 3     | 2     | 1     | 0     | _     |
| Read/Write   | R      | R     | R     | R     | R     | R     | R     | R/W   |       |
|              | RW     | R/W   |       |
| Inital Value | 0      | 0     | 0     | 0     | 0     | 0     | 0     | X     |       |
|              | X      | X     | X     | X     | X     | X     | X     | X     |       |





#### The EEPROM Control Register - EECR

Bit EEPM1 E EPM0 EERIE EEMPE EEPE EERE EECH R/W R/W R/W R/W R/W R/W Read/Write 0 0 X X 0 0 × 0 Inităl Value

| Table 5-1. | EEPROM | Mode: | Bits |
|------------|--------|-------|------|
|------------|--------|-------|------|

| EEPM1 | EEPM0 | Programming<br>Time | Operation                                           |
|-------|-------|---------------------|-----------------------------------------------------|
| 0     | 0     | 3.4 ms              | Erase and Write in one operation (Atomic Operation) |
| 0     | 1     | 1.8 ms              | Erase Only                                          |
| 1     | 0     | 1.8 ms              | Write Only                                          |
| 1     | 1     | _                   | Reserved for future use                             |

## Direct Single Register Addressing



## Direct Register Addressing, Two Registers



## VO Direct Addressing



## Direct Data Addressing



## Data Indirect with Displacement



## Data Indirect Addressing



## Data Indirect Addressing with Pre-decrement







FLASHEND

## Program Memory Addressing with Post-increment PROGRAM MEMORY 0x0000 15 1 0 Z-REGISTER LSB FLASHEND

LPM Z+ and ELPM Z+



# Indirect Program Memory Addressing PROGRAM MEMORY 0x0000 15 Z-REGISTER PC IJMP and ICALL FLASHEND



## **RJMP and RCALL**

## **Conditional Branch Summary**

| Test     | Boolean       | Mnemonic            | Complementary | Boolean       | Mnemonic  | Comment  |
|----------|---------------|---------------------|---------------|---------------|-----------|----------|
| Rd > Rr  | Z•(N ⊕ V) = 0 | BRLT <sup>(1)</sup> | Rd ≤ Rr       | Z+(N ⊕ V) = 1 | BRGE*     | Signed   |
| Rd≥Rr    | (N ⊕ V) = 0   | BRGE                | Rd < Rr       | (N ⊕ V) = 1   | BRLT      | Signed   |
| Rd = Rr  | Z = 1         | BREQ                | Rd ≠ Rr       | Z = 0         | BRNE      | Signed   |
| Rd≤Rr    | Z+(N ⊕ V) = 1 | BRGE <sup>(1)</sup> | Rd > Rr       | Z•(N ⊕ V) = 0 | BRLT*     | Signed   |
| Rd < Rr  | (N ⊕ V) = 1   | BRLT                | Rd ≥ Rr       | (N ⊕ V) = 0   | BRGE      | Signed   |
| Rd > Rr  | C + Z = 0     | BRLO <sup>(1)</sup> | Rd ≤ Rr       | C + Z = 1     | BRSH*     | Unsigned |
| Rd≥Rr    | C = 0         | BRSH/BRCC           | Rd < Rr       | C = 1         | BRLO/BRCS | Unsigned |
| Rd = Rr  | Z = 1         | BREQ                | Rd ≠ Rr       | Z = 0         | BRNE      | Unsigned |
| Rd≤Rr    | C + Z = 1     | BRSH <sup>(1)</sup> | Rd > Rr       | C + Z = 0     | BRLO*     | Unsigned |
| Rd < Rr  | C = 1         | BRLO/BRCS           | Rd ≥ Rr       | C = 0         | BRSH/BRCC | Unsigned |
| Carry    | C = 1         | BRCS                | No carry      | C = 0         | BRCC      | Simple   |
| Negative | N = 1         | BRMI                | Positive      | N = 0         | BRPL      | Simple   |
| Overflow | V = 1         | BRVS                | No overflow   | V = 0         | BRVC      | Simple   |
| Zero     | Z = 1         | BREQ                | Not zero      | Z = 0         | BRNE      | Simple   |

Note: 1. Interchange Rd and Rr in the operation before the test, i.e., CP Rd,Rr → CP Rr,Rd

#### Instruction Set Summary

| Mnemonics | Operands | Description                                 | Operation                 | Flags       | #Clock<br>Note |
|-----------|----------|---------------------------------------------|---------------------------|-------------|----------------|
|           |          | Arithmetic and                              | Logic Instructions        | •           |                |
| ADD       | Rd, Rr   | Add without Carry                           | Rd ← Rd + Rr              | Z,C,N,V,S,H | 1              |
| ADC       | Rd, Rr   | Add with Carry                              | Rd ← Rd + Rr + C          | Z,C,N,V,S,H | 1              |
| ADIW      | Rd, K    | Add Immediate to Word                       | Rd+1:Rd ← Rd+1:Rd + K     | Z,C,N,V,S   | 2 (1)          |
| SUB       | Rd, Rr   | Subtract without Carry                      | Rd ← Rd - Rr              | Z,C,N,V,S,H | 1              |
| SUBI      | Rd, K    | Subtract immediate                          | Rd ← Rd - K               | Z,C,N,V,S,H | 1              |
| SBC       | Rd, Rr   | Subtract with Carry                         | Rd ← Rd - Rr - C          | Z,C,N,V,S,H | 1              |
| SBCI      | Rd, K    | Subtract Immediate with Carry               | Rd ← Rd - K - C           | Z,C,N,V,S,H | 1              |
| SBIW      | Rd, K    | Subtract Immediate from Word                | Rd+1:Rd ← Rd+1:Rd - K     | Z,C,N,V,S   | 2 (1)          |
| AND       | Rd, Rr   | Logical AND                                 | Rd ← Rd • Rr              | Z,N,V,S     | 1              |
| ANDI      | Rd, K    | Logical AND with immediate                  | Rd ← Rd • K               | Z,N,V,S     | 1              |
| OR.       | Rd, Rr   | Logical OR                                  | Rd ← Rd v Rr              | Z,N,V,S     | 1              |
| ORI       | Rd, K    | Logical OR with Immediate                   | Rd ← Rd v K               | Z,N,V,S     | 1              |
| EOR       | Rd, Rr   | Exclusive OR                                | Rd ← Rd ⊕ Rr              | Z,N,V,S     | 1              |
| СОМ       | Rd       | Ones Complement                             | Rd ← \$FF - Rd            | Z,C,N,V,S   | 1              |
| NEG       | Rd       | Two's Complement                            | Rd ← \$00 - Rd            | Z,C,N,V,S,H | 1              |
| SBR       | Rd,K     | Set Bit(s) in Register                      | Rd ← Rd v K               | Z,N,V,S     | 1              |
| CBR       | Rd,K     | Clear Bit(s) in Register                    | Rd ← Rd • (\$FFh - K)     | Z,N,V,S     | 1              |
| INC       | Rd       | Increment                                   | Rd ← Rd + 1               | Z,N,V,S     | 1              |
| DEC       | Rd       | Decrement                                   | Rd ← Rd - 1               | Z,N,V,S     | 1              |
| TST       | Rd       | Test for Zero or Minus                      | Rd ← Rd • Rd              | Z,N,V,S     | 1              |
| CLR       | Rd       | Clear Register                              | Rd ← Rd ⊕ Rd              | Z,N,V,S     | 1              |
| SER       | Rd       | Set Register                                | Rd ← \$FF                 | None        | 1              |
| MUL       | Rd,Rr    | Multiply Unsigned                           | R1:R0 ← Rd × Rr (UU)      | z,c         | 2 (1)          |
| MULS      | Rd,Rr    | Multiply Signed                             | R1:R0 ← Rd × Rr (SS)      | z,c         | 2 (1)          |
| MULSU     | Rd,Rr    | Multiply Signed with Unsigned               | R1:R0 ← Rd × Rr (SU)      | z,c         | 2 (1)          |
| FMUL      | Rd,Rr    | Fractional Multiply Unsigned                | R1:R0 ← (Rd × Rr)<<1 (UU) | z,c         | 2 (1)          |
| FMULS     | Rd,Rr    | Fractional Multiply Signed                  | R1:R0 ← (Rd × Rr)<<1 (SS) | z,c         | 2 (1)          |
| FMULSU    | Rd,Rr    | Fractional Multiply Signed with<br>Unsigned | R1:R0 ← (Rd × Rr)<<1 (SU) | z,c         | 2 (1)          |

| Branch Instructions |       |                                     |                                    |             |              |  |  |
|---------------------|-------|-------------------------------------|------------------------------------|-------------|--------------|--|--|
| RJMP                | k     | Relative Jump                       | PC ← PC + k + 1                    | None        | 2            |  |  |
| UMP                 |       | Indirect Jump to (Z)                | PC(15:0) ← Z. PC(21:16) ← 0        | None        | 2 (1)        |  |  |
| EUMP                |       | Extended Indirect Jump to (Z)       | PC(15:0) ← Z, PC(21:16) ← EIND     | None        | 2 (1)        |  |  |
| JMP                 | k     | Jump                                | PC ← k                             | None        | 3 (1)        |  |  |
| RCALL               | k     | Relative Call Subroutine            | PC ← PC + k + 1                    | None        | 3 / 4 (4)    |  |  |
| ICALL               |       | Indirect Call to (Z)                | PC(15:0) ← Z, PC(21:16) ← 0        | None        | 3 / 4 (1)(4) |  |  |
| EICALL              |       | Extended Indirect Call to (Z)       | PC(15:0) ← Z, PC(21:16) ← EIND     | None        | 4 (1)(4)     |  |  |
| CALL                | k     | Call Subroutine                     | PC ← k                             | None        | 4 / 5 (1)(4) |  |  |
| RET                 |       | Subroutine Return                   | PC ← STACK                         | None        | 4 / 5 (4)    |  |  |
| RETI                |       | Interrupt Return                    | PC ← STACK                         | 1           | 4 / 5 (4)    |  |  |
| CPSE                | Rd,Rr | Compare, Skip if Equal              | If (Rd = Rr) PC ← PC + 2 or 3      | None        | 1/2/3        |  |  |
| CP                  | Rd,Rr | Compare                             | Rd - Rr                            | Z,C,N,V,S,H | 1            |  |  |
| CPC                 | Rd,Rr | Compare with Carry                  | Rd - Rr - C                        | Z,C,N,V,S,H | 1            |  |  |
| CPI                 | Rd,K  | Compare with Immediate              | Rd - K                             | Z,C,N,V,S,H | 1            |  |  |
| SBRC                | Rr, b | Skip if Bit in Register Cleared     | If (Rr(b)=0) PC ← PC + 2 or 3      | None        | 1/2/3        |  |  |
| SBRS                | Rr, b | Skip if Bit in Register Set         | If (Rr(b)=1) PC ← PC + 2 or 3      | None        | 1/2/3        |  |  |
| SBIC                | A, b  | Skip if Bit in I/O Register Cleared | If(I/O(A,b)=0) PC ← PC + 2 or 3    | None        | 1/2/3        |  |  |
| SBIS                | A, b  | Skip if Bit in I/O Register Set     | If(VO(A,b)=1) PC ← PC + 2 or 3     | None        | 1/2/3        |  |  |
| BRBS                | s, k  | Branch if Status Flag Set           | If (SREG(s) = 1) then PC ←PC+k + 1 | None        | 1/2          |  |  |
| BRBC                | s, k  | Branch if Status Flag Cleared       | If (SREG(s) = 0) then PC ←PC+k + 1 | None        | 1/2          |  |  |
| BREQ                | k     | Branch if Equal                     | If (Z = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRNE                | k     | Branch if Not Equal                 | If (Z = 0) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRCS                | k     | Branch If Carry Set                 | If (C = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRCC                | k     | Branch if Carry Cleared             | If (C = 0) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRSH                | k     | Branch If Same or Higher            | If (C = 0) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRLO                | k     | Branch if Lower                     | If (C = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRMI                | k     | Branch if Minus                     | If (N = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRPL                | k     | Branch if Plus                      | If (N = 0) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRGE                | k     | Branch if Greater or Equal, Signed  | If (N ⊕ V= 0) then PC ← PC + k + 1 | None        | 1/2          |  |  |
| BRLT                | k     | Branch if Less Than, Signed         | If (N ⊕ V= 1) then PC ← PC + k + 1 | None        | 1/2          |  |  |
| BRHS                | k     | Branch if Half Carry Flag Set       | If (H = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRHC                | k     | Branch if Half Carry Flag Cleared   | If (H = 0) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRTS                | k     | Branch if T Flag Set                | If (T = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRTC                | k     | Branch if T Flag Cleared            | If (T = 0) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRVS                | k     | Branch if Overflow Flag is Set      | If (V = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |
| BRVC                | k     | Branch if Overflow Flag is Cleared  | If (V = 0) then PC ← PC + k + 1    | None        | 1/2          |  |  |
|                     | k     | Branch if Interrupt Enabled         | If (I = 1) then PC ← PC + k + 1    | None        | 1/2          |  |  |

## ADC - Add with Carry

#### Description:

Adds two registers and the contents of the C Flag and places the result in the destination register Rd.

Operation:

(i) Rd ← Rd + Rr + C

Syntax: Operands:

Program Counter:

(i) ADC Rd,Rr 0≤d≤31,0≤r≤31

PC ← PC + 1

16-bit Opcode:

| 0001 | llrd | dddd | 2222 |
|------|------|------|------|



## ADD - Add without Carry

#### Description:

Adds two registers without the C Flag and places the result in the destination register Rd.

#### Operation:

(i) Rd ← Rd + Rr

Syntax: Operands:

Program Counter:

(i) ADD Rd,Rr 0≤d≤31, 0≤r≤31

PC ← PC + 1

#### 16-bit Opcode:

| 0000 | llrd | dddd | EEEE |
|------|------|------|------|



#### ADIW - Add Immediate to Word

#### Description:

Adds an immediate value (0 - 63) to a register pair and places the result in the register pair. This instruction operates on the upper four register pairs, and is well suited for operations on the pointer registers.

This instruction is not available in all devices. Refer to the device specific instruction set summary.

#### Operation:

 $Rd+1:Rd \leftarrow Rd+1:Rd + K$ 

Operands: Syntax:

Program Counter:

ADIW Rd+1:Rd,K d ∈ {24,26,28,30}, 0 ≤ K ≤ 63 PC ← PC + 1 (i)

#### 16-bit Opcode:

| 1001 | 0110 | KKdd | XXXX |
|------|------|------|------|



#### ASR - Arithmetic Shift Right

#### Description:

Shifts all bits in Rd one place to the right. Bit 7 is held constant. Bit 0 is loaded into the C Flag of the SREG. This operation effectively divides a signed value by two without changing its sign. The Carry Flag can be used to round the result.

#### Operation:

(i)



Syntax:

Operands:

Program Counter:

) ASR Rd

 $0 \le d \le 31$ 

PC ← PC + 1

#### 16-bit Opcode:

| 1001 | 010d | dddd | 0101 |
|------|------|------|------|
|      |      |      |      |



#### LSR - Logical Shift Right

#### Description:

Shifts all bits in Rd one place to the right. Bit 7 is cleared. Bit 0 is loaded into the C Flag of the SREG. This operation effectively divides an unsigned value by two. The C Flag can be used to round the result.

#### Operation:



Syntax: LSR Rd Operands: Program Counter:

16-bit Opcode:

(i)



#### Status Register (SREG) and Boolean Formula:



 $0 \le d \le 31$ 

PC ← PC + 1

## LSL - Logical Shift Left

#### Description:

Shifts all bits in Rd one place to the left. Bit 0 is cleared. Bit 7 is loaded into the C Flag of the SREG. This operation effectively multiplies signed and unsigned values by two.

#### Operation:

(i)



Syntax: Operands: LSLRd 0≤d≤31 Program Counter:

PC ← PC + 1

16-bit Opcode: (see ADD Rd, Rd)

| 0000 | 1144     | dddd       | 6666        |
|------|----------|------------|-------------|
| 0000 | 1.1.0404 | 4,00,00,00 | CATALOGICA. |

#### ROL - Rotate Left trough Carry

#### Description:

Shifts all bits in Rd one place to the left. The C Flag is shifted into bit 0 of Rd. Bit 7 is shifted into the C Flag. This operation, combined with LSL, effectively multiplies multi-byte signed and unsigned values by two.

#### Operation:



 Syntax:
 Operands:

 ROL Rd
 0 ≤ d ≤ 31

Program Counter: PC ← PC + 1

16-bit Opcode: (see ADC Rd, Rd)

| 0001 | 11dd | dddd | dddd |
|------|------|------|------|



#### ROR - Rotate Right through Carry

#### Description:

Shifts all bits in Rd one place to the right. The C Flag is shifted into bit 7 of Rd. Bit 0 is shifted into the C Flag. This operation, combined with ASR, effectively divides multi-byte signed values by two. Combined with LSR it effectively divides multi-byte unsigned values by two. The Carry Flag can be used to round the result.

#### Operation:



Syntax: Operands: (i) RORRd 0≤d≤31 Program Counter:

PC ← PC + 1

#### 16-bit Opcode:



