

#### Lecture 6 – Introduction to the ATmega328 and Ardunio

**CSE P567** 

## Outline

#### Lecture 6

- ATmega architecture and instruction set
- I/O pins
- Arduino C++ language
- Lecture 7
  - Controlling Time
    - Interrupts and Timers
- Lecture 8
  - Guest lecture Radio communication
- Lecture 9
  - Designing PID Controllers



## AVR Architecture

- Clocks and Power
- Beyond scope of this course





# AVR Architecture

- Harvard architecture
- Flash program memory
  32K
- SRAM data memory
  2K
- EEPROM
  - For long-term data
  - On I/O data bus



## Memory

#### Flash (32K) (15-bit addresses)

- Program memory read only
- Non-volatile
- Allocate data to Flash using PROGMEM keyword
  - see documentation

## SRAM (2K)

- Temporary values, stack, etc.
- Volatile
- Limited space!

## EEPROM (IK)

- Long-term data
- see documentation on EEPROM library

## AVR CPU

 Instruction Fetch and Decode







### AVR Register File

▶ 32 8-bit GP registers

#### Part of SRAM memory space

General Purpose Working Registers

#### Figure 6-2. AVR CPU General Purpose Working Registers

| 7 | 0  | Addr |
|---|----|------|
| R | 0  | 0x00 |
| R | 1  | 0x01 |
| R | 2  | 0x02 |
|   |    |      |
| R | 3  | 0x0D |
| R | 4  | 0x0E |
| R | 5  | 0x0F |
| R | 6  | 0x10 |
| R | 7  | 0x11 |
|   |    |      |
| R | 26 | 0x1A |
| R | 27 | 0x1B |
| R | 28 | 0x1C |
| R | 29 | 0x1D |
| R | 30 | 0x1E |
| R | 31 | 0x1F |
|   |    |      |

X-register Low Byte X-register High Byte Y-register Low Byte Y-register High Byte Z-register Low Byte Z-register High Byte

## Special Addressing Registers

X,Y and Z registers

- I6-bit registers made using registers 26 31
- Support indirect addressing

15 XH XL 0 X-register 0 7 0 7 R27 (0x1B) R26 (0x1A) 15 YH YL 0 0 0 Y-register 7 R29 (0x1D) R28 (0x1C) 15 ΖH ZL 0 Z-register 0 0 7 R31 (0x1F) R30 (0x1E)

Figure 6-3. The X-, Y-, and Z-registers

## AVR Memory

- Program memory Flash
- Data memory SRAM

#### Data Memory

| 32 Registers             | 0x0000 - 0x001F            |
|--------------------------|----------------------------|
| 64 I/O Registers         | 0x0020 - 0x005F            |
| 160 Ext I/O Reg.         | 0x0060 - 0x00FF            |
|                          | 0x0100                     |
| Internal SRAM            |                            |
| (512/1024/1024/2048 x 8) |                            |
|                          | 0x04FF/0x04FF/0x0FF/0x08FF |



 Direct register addressing



#### Direct I/O addressing



D

#### Direct data memory addressing



Direct data memory with displacement addressing



#### Indirect data memory addressing



Indirect data memory addressing with pre-decrement



Indirect data memory addressing with post-increment



Program memory addressing (constant data)



### SRAM Read/Write Timing

Figure 7-4. On-chip Data SRAM Access Cycles



### Stack Pointer Register

#### Special register in I/O space [3E, 3D]

- Enough bits to address data space
- Initialized to RAMEND (address of highest memory address)
- Instructions that use the stack pointer

| Instruction            | Stack pointer    | Description                                                                                     |
|------------------------|------------------|-------------------------------------------------------------------------------------------------|
| PUSH                   | Decremented by 1 | Data is pushed onto the stack                                                                   |
| CALL<br>ICALL<br>RCALL | Decremented by 2 | Return address is pushed onto the stack with a subroutine call or interrupt                     |
| POP                    | Incremented by 1 | Data is popped from the stack                                                                   |
| RET<br>RETI            | Incremented by 2 | Return address is popped from the stack with return from<br>subroutine or return from interrupt |

## Program Status Register (PSR)



Status bits set by instructions/Checked by Branch/Skip instructions

- ► I Global interrupt enable
- ▶ T Flag bit
- ► H Half carry (BCD arithmetic)
- S Sign
- ► V Overflow
- ► N Negative
- Z Zero
- ► C Carry

## Simple 2-Stage Pipeline

#### Branch/Skip??

Figure 6-4. The Parallel Instruction Fetches and Instruction Executions



## Single-Cycle ALU Instructions

- Most instructions execute in one cycle
- Makes program timing calculations (relatively) easy
  - No cache misses
  - I clock/instruction

Figure 6-5. Single Cycle ALU Operation



JMP, CALL – Direct Program Memory Addressing



IJMP, ICALL – Indirect program memory addressing



RJMP, RCALL – Relative program memory addressing



### Arithmetic Instructions

| ADD                   | Rd, Rr | Add without Carry                        | Rd        | ← | Rd + Rr         | Z,C,N,V,S,H | 1 |
|-----------------------|--------|------------------------------------------|-----------|---|-----------------|-------------|---|
| ADC                   | Rd, Rr | Add with Carry                           | Rd        | 4 | Rd + Rr + C     | Z,C,N,V,S,H | 1 |
| ADIW <sup>(1)</sup>   | Rd, K  | Add Immediate to Word                    | Rd        | ÷ | Rd + 1:Rd + K   | Z,C,N,V,S   | 2 |
| SUB                   | Rd, Rr | Subtract without Carry                   | Rd        | ← | Rd - Rr         | Z,C,N,V,S,H | 1 |
| SUBI                  | Rd, K  | Subtract Immediate                       | Rd        | 4 | 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 <sup>(1)</sup>   | Rd, K  | Subtract Immediate from Word             | Rd + 1:Rd | 4 | Rd + 1:Rd - K   | Z,C,N,V,S   | 2 |
| INC                   | Rd     | Increment                                | Rd        | ← | Rd + 1          | Z,N,V,S     | 1 |
| DEC                   | Rd     | Decrement                                | Rd        | ← | Rd - 1          | Z,N,V,S     | 1 |
| MUL <sup>(1)</sup>    | Rd,Rr  | Multiply Unsigned                        | R1:R0     | ÷ | Rd x Rr (UU)    | Z,C         | 2 |
| MULS <sup>(1)</sup>   | Rd,Rr  | Multiply Signed                          | R1:R0     | 4 | Rd x Rr (SS)    | Z,C         | 2 |
| MULSU <sup>(1)</sup>  | Rd,Rr  | Multiply Signed with Unsigned            | R1:R0     | ← | Rd x Rr (SU)    | Z,C         | 2 |
| FMUL <sup>(1)</sup>   | Rd,Rr  | Fractional Multiply Unsigned             | R1:R0     | 4 | Rd x Rr<<1 (UU) | Z,C         | 2 |
| FMULS <sup>(1)</sup>  | Rd,Rr  | Fractional Multiply Signed               | R1:R0     | ← | Rd x Rr<<1 (SS) | Z,C         | 2 |
| FMULSU <sup>(1)</sup> | Rd,Rr  | Fractional Multiply Signed with Unsigned | R1:R0     | ← | Rd x Rr<<1 (SU) | Z,C         | 2 |

## Logical Instructions

| 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 |
| COM  | Rd     | One's 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 |
| 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 |

## Jump and Call Instructions

| RJMP                  | k | Relative Jump                 | PC                    | ←      | PC + k + 1 | None | 2                       |
|-----------------------|---|-------------------------------|-----------------------|--------|------------|------|-------------------------|
| IJMP <sup>(1)</sup>   |   | Indirect Jump to (Z)          | PC(15:0)<br>PC(21:16) | ↓<br>↓ | Z,<br>0    | None | 2                       |
| EIJMP <sup>(1)</sup>  |   | Extended Indirect Jump to (Z) | PC(15:0)<br>PC(21:16) | †<br>† | Z,<br>EIND | None | 2                       |
| JMP <sup>(1)</sup>    | k | Jump                          | PC                    | ←      | k          | None | 3                       |
| RCALL                 | k | Relative Call Subroutine      | PC                    | ←      | PC + k + 1 | None | 3 / 4 <sup>(3)(5)</sup> |
| ICALL <sup>(1)</sup>  |   | Indirect Call to (Z)          | PC(15:0)<br>PC(21:16) | ↓<br>↓ | Z,<br>0    | None | 3 / 4 <sup>(3)</sup>    |
| EICALL <sup>(1)</sup> |   | Extended Indirect Call to (Z) | PC(15:0)<br>PC(21:16) | ↓<br>↓ | Z,<br>EIND | None | 4 <sup>(3)</sup>        |
| CALL <sup>(1)</sup>   | k | call Subroutine               | PC                    | +      | k          | None | 4 / 5 <sup>(3)</sup>    |
| RET                   |   | Subroutine Return             | PC                    | ←      | STACK      | None | 4 / 5 <sup>(3)</sup>    |
| RETI                  |   | Interrupt Return              | PC                    | ←      | STACK      | 1    | 4 / 5 <sup>(3)</sup>    |

## Skip and Branch Instructions

| CPSE | Rd,Rr | Compare, Skip if Equal              | if (Rd = Rr) PC          | 4 | 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 (I/O(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   |

## Skip and Branch (cont)

| BRMI | k | Branch if Minus                    | if (N = 1) then PC           | 4 | 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 $\oplus$ V= 0) then PC | ← | PC + k + 1 | None | 1/2 |
| BRLT | k | Branch if Less Than, Signed        | if (N $\oplus$ 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 |
| BRIE | k | Branch if Interrupt Enabled        | if (I = 1) then PC           | ← | PC + k + 1 | None | 1/2 |
| BRID | k | Branch if Interrupt Disabled       | if (I = 0) then PC           | ← | PC + k + 1 | None | 1/2 |

## Move, Load

| LDI                | Rd, K   | Load Immediate                   | Rd                     | ←      | К             | None | 1                                  |
|--------------------|---------|----------------------------------|------------------------|--------|---------------|------|------------------------------------|
| LDS <sup>(1)</sup> | Rd, k   | Load Direct from data space      | Rd                     | ←      | (k)           | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| LD <sup>(2)</sup>  | Rd, X   | Load Indirect                    | Rd                     | ←      | (X)           | None | 1 <sup>(5)</sup> 2 <sup>(3)</sup>  |
| LD <sup>(2)</sup>  | Rd, X+  | Load Indirect and Post-Increment | Rd<br>X                | ↓<br>↓ | (X)<br>X + 1  | None | 2 <sup>(3)</sup>                   |
| LD <sup>(2)</sup>  | Rd, -X  | Load Indirect and Pre-Decrement  | X ← X - 1,<br>Rd ← (X) | ↓<br>↓ | X - 1<br>(X)  | None | 2 <sup>(3)</sup> /3 <sup>(5)</sup> |
| LD <sup>(2)</sup>  | Rd, Y   | Load Indirect                    | Rd ← (Y)               | ←      | (Y)           | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| LD <sup>(2)</sup>  | Rd, Y+  | Load Indirect and Post-Increment | Rd<br>Y                | ↓<br>↓ | (Y)<br>Y + 1  | None | 2 <sup>(3)</sup>                   |
| LD <sup>(2)</sup>  | Rd, -Y  | Load Indirect and Pre-Decrement  | Y<br>Rd                | ↓<br>↓ | Y - 1<br>(Y)  | None | 2 <sup>(3)</sup> /3 <sup>(5)</sup> |
| LDD <sup>(1)</sup> | Rd, Y+q | Load Indirect with Displacement  | Rd                     | ←      | (Y + q)       | None | 2 <sup>(3)</sup>                   |
| LD <sup>(2)</sup>  | Rd, Z   | Load Indirect                    | Rd                     | ←      | (Z)           | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| LD <sup>(2)</sup>  | Rd, Z+  | Load Indirect and Post-Increment | Rd<br>Z                | ↓<br>↓ | (Z),<br>Z+1   | None | 2 <sup>(3)</sup>                   |
| LD <sup>(2)</sup>  | Rd, -Z  | Load Indirect and Pre-Decrement  | Z<br>Rd                | ↓<br>↓ | Z - 1,<br>(Z) | None | 2 <sup>(3)</sup> /3 <sup>(5)</sup> |
| LDD <sup>(1)</sup> | Rd, Z+q | Load Indirect with Displacement  | Rd                     | ←      | (Z + q)       | None | 2 <sup>(3)</sup>                   |

#### Store

| STS <sup>(1)</sup> | k, Rr   | Store Direct to Data Space        | (k)      | ←      | Rd           | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
|--------------------|---------|-----------------------------------|----------|--------|--------------|------|------------------------------------|
| ST <sup>(2)</sup>  | X, Rr   | Store Indirect                    | (X)      | ←      | Rr           | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| ST <sup>(2)</sup>  | X+, Rr  | Store Indirect and Post-Increment | (X)<br>X | ↓<br>↓ | Rr,<br>X + 1 | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| ST <sup>(2)</sup>  | -X, Rr  | Store Indirect and Pre-Decrement  | X<br>(X) | ↓<br>↓ | X - 1,<br>Rr | None | 2 <sup>(3)</sup>                   |
| ST <sup>(2)</sup>  | Y, Rr   | Store Indirect                    | (Y)      | ÷      | Rr           | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| ST <sup>(2)</sup>  | Y+, Rr  | Store Indirect and Post-Increment | က္       | ↓<br>↓ | Rr,<br>Y + 1 | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| ST <sup>(2)</sup>  | -Y, Rr  | Store Indirect and Pre-Decrement  | Y<br>(Y) | ↓<br>↓ | Y - 1,<br>Rr | None | 2 <sup>(3)</sup>                   |
| STD <sup>(1)</sup> | Y+q, Rr | Store Indirect with Displacement  | (Y + q)  | ←      | Rr           | None | 2 <sup>(3)</sup>                   |
| ST <sup>(2)</sup>  | Z, Rr   | Store Indirect                    | (Z)      | ←      | Rr           | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| ST <sup>(2)</sup>  | Z+, Rr  | Store Indirect and Post-Increment | (Z)<br>Z | ↓<br>↓ | Rr<br>Z + 1  | None | 1 <sup>(5)</sup> /2 <sup>(3)</sup> |
| ST <sup>(2)</sup>  | -Z, Rr  | Store Indirect and Pre-Decrement  | Z        | ←      | Z-1          | None | 2 <sup>(3)</sup>                   |
| STD <sup>(1)</sup> | Z+q,Rr  | Store Indirect with Displacement  | (Z + q)  | ←      | Rr           | None | 2 <sup>(3)</sup>                   |

## Load/Store Program Memory

| LPM <sup>(1)(2)</sup> |        | Load Program Memory                                | R0             | ←      | (Z)                 | None | 3 |
|-----------------------|--------|----------------------------------------------------|----------------|--------|---------------------|------|---|
| LPM <sup>(1)(2)</sup> | Rd, Z  | Load Program Memory                                | Rd             | 4      | (Z)                 | None | 3 |
| LPM <sup>(1)(2)</sup> | Rd, Z+ | Load Program Memory and Post-<br>Increment         | Rd<br>Z        | ↓<br>↓ | (Z),<br>Z + 1       | None | 3 |
| ELPM <sup>(1)</sup>   |        | Extended Load Program Memory                       | R0             | ÷      | (RAMPZ:Z)           | None | 3 |
| ELPM <sup>(1)</sup>   | Rd, Z  | Extended Load Program Memory                       | Rd             | ←      | (RAMPZ:Z)           | None | 3 |
| ELPM <sup>(1)</sup>   | Rd, Z+ | Extended Load Program Memory and<br>Post-Increment | Rd<br>Z        | ↓<br>↓ | (RAMPZ:Z),<br>Z + 1 | None | 3 |
| SPM <sup>(1)</sup>    |        | Store Program Memory                               | (RAMPZ:Z)      | ←      | R1:R0               | None | - |
| SPM <sup>(1)</sup>    | Z+     | Store Program Memory and Post-<br>Increment by 2   | (RAMPZ:Z)<br>Z | ←<br>↓ | R1:R0,<br>Z + 2     | None | - |

## Move, I/O, Push/Pop

| MOV                 | Rd, Rr | Copy Register           | Rd      | ← | Rr      | None | 1 |
|---------------------|--------|-------------------------|---------|---|---------|------|---|
| MOVW <sup>(1)</sup> | Rd, Rr | Copy Register Pair      | Rd+1:Rd | ← | Rr+1:Rr | None | 1 |
| IN                  | Rd, A  | In From I/O Location    | Rd      | ← | I/O(A)  | None | 1 |
| OUT                 | A, Rr  | Out To I/O Location     | I/O(A)  | ← | Rr      | None | 1 |
| PUSH <sup>(1)</sup> | Rr     | Push Register on Stack  | STACK   | ← | Rr      | None | 2 |
| POP <sup>(1)</sup>  | Rd     | Pop Register from Stack | Rd      | ← | STACK   | None | 2 |

## Shift and Bit Instructions

| LSL  | Rd    | Logical Shift Left           | Rd(n+1)<br>Rd(0)<br>C | $\downarrow \downarrow \downarrow$ | Rd(n),<br>0,<br>Rd(7)   | Z,C,N,V,H | 1                   |
|------|-------|------------------------------|-----------------------|------------------------------------|-------------------------|-----------|---------------------|
| LSR  | Rd    | Logical Shift Right          | Rd(n)<br>Rd(7)<br>C   | $\downarrow \downarrow \downarrow$ | Rd(n+1),<br>0,<br>Rd(0) | Z,C,N,V   | 1                   |
| ROL  | Rd    | Rotate Left Through Carry    | Rd(0)<br>Rd(n+1)<br>C | ↓<br>↓<br>↓                        | C,<br>Rd(n),<br>Rd(7)   | Z,C,N,V,H | 1                   |
| ROR  | Rd    | Rotate Right Through Carry   | Rd(7)<br>Rd(n)<br>C   | ↓<br>↓<br>↓                        | C,<br>Rd(n+1),<br>Rd(0) | Z,C,N,V   | 1                   |
| ASR  | Rd    | Arithmetic Shift Right       | Rd(n)                 | ←                                  | Rd(n+1), n=06           | Z,C,N,V   | 1                   |
| SWAP | Rd    | Swap Nibbles                 | Rd(30)                | $\leftrightarrow$                  | Rd(74)                  | None      | 1                   |
| BSET | s     | Flag Set                     | SREG(s)               | ←                                  | 1                       | SREG(s)   | 1                   |
| BCLR | s     | Flag Clear                   | SREG(s)               | ←                                  | 0                       | SREG(s)   | 1                   |
| SBI  | A, b  | Set Bit in I/O Register      | I/O(A, b)             | ←                                  | 1                       | None      | 1 <sup>(5)</sup> 2  |
| CBI  | A, b  | Clear Bit in I/O Register    | I/O(A, b)             | ←                                  | 0                       | None      | 1 <sup>(5)</sup> /2 |
| BST  | Rr, b | Bit Store from Register to T | Т                     | ←                                  | Rr(b)                   | Т         | 1                   |
| BLD  | Rd, b | Bit load from T to Register  | Rd(b)                 | ←                                  | Т                       | None      | 1                   |
| SEC  |       | Set Carry                    | С                     | ←                                  | 1                       | С         | 1                   |
| CLC  |       | Clear Carry                  | С                     | ←                                  | 0                       | С         | 1                   |
| SEN  |       | Set Negative Flag            | Ν                     | ←                                  | 1                       | N         | 1                   |
| CLN  |       | Clear Negative Flag          | Ν                     | ←                                  | 0                       | Ν         | 1                   |
| SEZ  |       | Set Zero Flag                | Z                     | ←                                  | 1                       | Z         | 1                   |
| CLZ  |       | Clear Zero Flag              | Z                     | ←                                  | 0                       | Z         | 1                   |

## Bit Instructions (cont)

| SEI                      |  | Global Interrupt Enable         | l 4                             | - 1  | I    | 1 |  |  |  |  |
|--------------------------|--|---------------------------------|---------------------------------|------|------|---|--|--|--|--|
| CLI                      |  | Global Interrupt Disable        | l 4                             | - 0  | I    | 1 |  |  |  |  |
| SES                      |  | Set Signed Test Flag            | S 🗧                             | - 1  | S    | 1 |  |  |  |  |
| CLS                      |  | Clear Signed Test Flag          | S ∢                             | - 0  | S    | 1 |  |  |  |  |
| SEV                      |  | Set Two's Complement Overflow   | V <del>(</del>                  | - 1  | v    | 1 |  |  |  |  |
| CLV                      |  | Clear Two's Complement Overflow | V <del>(</del>                  | - 0  | V    | 1 |  |  |  |  |
| SET                      |  | Set T in SREG                   | T ∢                             | - 1  | Т    | 1 |  |  |  |  |
| CLT                      |  | Clear T in SREG                 | T +                             | - 0  | т    | 1 |  |  |  |  |
| SEH                      |  | Set Half Carry Flag in SREG     | H 🗧                             | - 1  | Н    | 1 |  |  |  |  |
| CLH                      |  | Clear Half Carry Flag in SREG   | H ∢                             | - 0  | Н    | 1 |  |  |  |  |
| MCU Control Instructions |  |                                 |                                 |      |      |   |  |  |  |  |
| BREAK <sup>(1)</sup>     |  | Break                           | (See specific descr.            | None | 1    |   |  |  |  |  |
| NOP                      |  | No Operation                    |                                 |      | None | 1 |  |  |  |  |
| SLEEP                    |  | Sleep                           | (see specific descr. for Sleep) |      | None | 1 |  |  |  |  |
| WDR                      |  | Watchdog Reset                  | (see specific desc              | None | 1    |   |  |  |  |  |

## AVR Architecture

- Three timers
- Very flexible
  - Choose clock rate
  - Choose "roll-over" value
  - Generate interrupts
  - Generate PWM signals
    - (represent 8-bit value with using a clock signal)
- More in next lecture...



## Arduino Timing Functions

- delay(ms)
  - wait for ms milliseconds before continuing
- delayMicroseconds(us)
  - wait for us microseconds before continuing
- unsigned long millis()
  - return number of milliseconds since program started
- unsigned long micros()
  - return number of microseconds since program started
  - resolution of 4 microseconds

# AVR Architecture

- Interface to pins
- Each pin directly programmable
  - Program direction
  - Program value
  - Program pull-ups
- Some pins are special
  - Analog vs. Digital
  - Clocks
  - Reset



## I/O Ports

- 3 8-bit Ports (B, C, D)
- Each port controlled by 3 8-bit registers
  - Each bit controls one I/O pin
  - DDRx Direction register
    - Defines whether a pin is an input (0) or and output (1)
  - PINx Pin input value
    - Reading this "register" returns value of pin
  - PORTx Pin output value
    - Writing this register sets value of pin

## Pin Circuitry



Note: 1. WRx, WPx, WDx, RRx, RPx, and RDx are common to all pins within the same port. clk<sub>I/O</sub>, SLEEP, and PUD are common to all ports.

### Pin Input



Note: 1. WRx, WPx, WDx, RRx, RPx, and RDx are common to all pins within the same port. clk<sub>I/O</sub>, SLEEP, and PUD are common to all ports.

## Synchronization Timing

Note: Takes a clock cycle for data output to be reflected on the input

Figure 13-3. Synchronization when Reading an Externally Applied Pin value



## Pin Output



Note: 1. WRx, WPx, WDx, RRx, RPx, and RDx are common to all pins within the same port. clk<sub>I/O</sub>, SLEEP, and PUD are common to all ports.

#### Pin Input – PORT controls pullup



Note: 1. WRx, WPx, WDx, RRx, RPx, and RDx are common to all pins within the same port. clk<sub>I/O</sub>, SLEEP, and PUD are common to all ports.

# I/O Ports

#### Pullups

- If a pin is an input (DDRxi = 0):
  - PORTxi = 0 pin is floating
  - PORTxi = I connects a pullup to the pin
    - □ Keeps pin from floating if noone driving
    - $\Box$  Allows wired-OR bus
- Individual bits can be set cleared using bit-ops
- A bit can be toggled by writing I to PINxi
  - SBI instruction e.g.

## I/O Protection





## Arduino Digital and Analog I/O Pins

#### Digital pins:

- ▶ Pins 0 7: PORT D [0:7]
- Pins 8 13: PORT B [0:5]
- Pins 14 19: PORT C [0:5] (Arduino analog pins 0 5)
- b digital pins 0 and 1 are RX and TX for serial communication
- b digital pin 13 connected to the base board LED

#### Digital Pin I/O Functions

- pinMode(pin, mode)
  - Sets pin to INPUT or OUTPUT mode
  - Writes I bit in the DDRx register
- digitalWrite(pin, value)
  - Sets pin value to LOW or HIGH (0 or I)
  - Writes I bit in the PORTx register
- int value = digitalRead(pin)
  - Reads back pin value (0 or 1)
  - Read I bit in the PINx register

## Arduino Analog I/O

- Analog input pins: 0 5
- Analog output pins: 3, 5, 6, 9, 10, 11 (digital pins)
- Analog input functions
  - int val = analogRead(pin)
  - ► Converts 0 5v. voltage to a 10-bit number (0 1023)
  - Don't use pinMode
  - analogReference(type)
    - Used to change how voltage is converted (advanced)

#### Analog output

- analogWrite(pin, value)
  - value is 0 255
- Generates a PWM output on digital pin (3, 5, 6, 9, 10, 11)
- @490Hz frequency

## AVR Architecture

- Analog inputs
- Convert voltage to a
   10-bit digital value
- Can provide reference voltages



## PWM – Pulse Width Modulation

#### Use one wire to represent a multi-bit value

- A clock with a variable duty cycle
- Duty cycle used to represent value
- We can turn it into a analog voltage using an integrating filter



## Port Special Functions

- Lots of special uses for pins
  - Clock connections
  - Timer connections
    - e.g. comparator output for PWM
  - Interrupts
  - Analog references
  - Serial bus I/Os
    - **USART**
    - ► PCI

# Reading and Writing Pins Directly

- Only one pin can be changed using the Arduino I/O functions
  - Setting multiple pins takes time and instructions
- To change multiple pins simultaneously, directly read/write the pin registers
  - DDR{A/B/C}
  - PORT{A/B/C}
  - PIN{A/B/C}
- ▶ e.g. to set all digital pins 0 7 to a value:
  - > PORTD = B01100101;

## AVR Architecture

- Special I/O support
  - Serial protocols
- Uses special pins
- Uses timers
- Beyond scope of this course



## Arduino C Programs

- Arduino calls these "sketches"
  - Basically C with libraries
- Program structure
  - Header: declarations, includes, etc.
  - setup()
  - loop()
- Setup is like Verilog initial
  - executes once when program starts
- Ioop() is like Verilog always
  - continuously re-executed when the end is reached



```
Blink Program
```

```
int ledPin = 13; // LED connected to digital pin 13
// The setup() method runs once, when the sketch starts
void setup()
             {
  // initialize the digital pin as an output:
 pinMode(ledPin, OUTPUT);
}
// the loop() method runs over and over again,
// as long as the Arduino has power
void loop()
{
 digitalWrite(ledPin, HIGH); // set the LED on
 delay(1000);
                               // wait for a second
 digitalWrite(ledPin, LOW); // set the LED off
 delay(1000);
                               // wait for a second
}
```

### The Arduino C++ Main Program

```
int main(void)
{
    init();
    setup();
    for (;;)
        loop();
    return 0;
}
```

## Arduino Serial I/O

#### Communication with PC via USB serial line

- Use the Serial Monitor in the IDE
- Or set up a C or Java (or you-name-it) interface

#### Example Serial library calls

- Serial.begin(baud-rate)
  - > 9600 default
- Serial.println(string)
- int foo = Serial.read()
  - Read one byte (input data is buffered)
- See documentation for more

#### Example Program

```
int ledPin = 13; // select the pin for the LED
int val = 0; 	// variable to store the data from the serial port
void setup() {
 pinMode(ledPin,OUTPUT); // declare the LED's pin as output
  Serial.begin(9600); // connect to the serial port
}
void loop () {
  val = Serial.read(); // read the serial port
  // if the stored value is a single digit, blink the LED that number
  if (val > '0' && val <= '9' ) {
    val = val - '0'; // convert from character to number
    for(int i=0; i<val; i++) {</pre>
      Serial.println("blink!");
     digitalWrite(ledPin,HIGH);
     delay(150);
     digitalWrite(ledPin, LOW);
     delay(150);
    //Serial.println();
  }
}
```