# Instituto Tecnológico de Zitácuaro

Tema 6: Interrupciones

Son eventos que hacen al microcontrolador suspender la ejecución del programa principal y ejecutar un programa secundario conocido como RSI.



Son eventos que hacen al microcontrolador suspender la ejecución del programa principal y ejecutar un programa secundario conocido como RSI.





Programa principal



Hardware

## ¿Qué puede provocar una interrupción?

- La forma de trabajo de algunos periféricos.



## ¿Qué puede provocar una interrupción?

- La forma de trabajo de algunos periféricos.
- Eventos externos monitoreados en los pines correspondientes.



| 1 | 0   | 1  | 1   | 0    | 1  | 0 |
|---|-----|----|-----|------|----|---|
| 1 | 0   | 0  | 0   | di . | 41 | 1 |
| 0 | 0 0 | ** | 111 | H    | ¥, | 0 |
| 1 | 0   | H  | 1   | 0    | 1  | 0 |
| 1 | 0   | 0  | 0   | 0    | 1  | 1 |

# Pines para monitorear interrupciones





Habilita las interrupciones globales.



Cuando se activa pone en uno la bandera I



| Registro | de Estado |       |       |       |       |       |       |
|----------|-----------|-------|-------|-------|-------|-------|-------|
| R/W      | R/W       | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| 1        | T         | н     | S     | V     | N     | Z     | T     |
| bit 7    | bit 6     | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |

### SEI

Habilita las interrupciones globales.





Cuando se ejecuta una interrupción el registro I se pone en cero



| Registro | de Estado |       |       |       |       |       |       |
|----------|-----------|-------|-------|-------|-------|-------|-------|
| R/W      | R/W       | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| 1        | T         | н     | S     | V     | N     | Z     | T     |
| bit 7    | bit 6     | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 |



Habilita las interrupciones globales.







PC

RAM

Dirección de retorno

PILA

### SEI

Habilita las interrupciones globales.



### RETI

Retorno de interrupción.







Table 11-1. Reset and Interrupt Vectors in ATmega328P

| or No. | Program Address | Source       | Interrupt Definition                                                       |
|--------|-----------------|--------------|----------------------------------------------------------------------------|
| 1      | 0x0000          | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |
| 2      | 0x0002          | INTO         | External interrupt request 0                                               |
| 3      | 0x0004          | INT1         | External interrupt request 1                                               |
| 4      | 0x0006          | PCINT0       | Pin change interrupt request 0                                             |
| 5      | 0x0008          | PCINT1       | Pin change interrupt request 1                                             |
| 6      | 0x000A          | PCINT2       | Pin change interrupt request 2                                             |
| 7      | 0x000C          | WDT          | Watchdog time-out interrupt                                                |
| 8      | 0x000E          | TIMER2 COMPA | Timer/Counter2 compare match A                                             |
| 9      | 0x0010          | TIMER2 COMPB | Timer/Counter2 compare match B                                             |
| 10     | 0x0012          | TIMER2 OVF   | Timer/Counter2 overflow                                                    |
| 11     | 0x0014          | TIMER1 CAPT  | Timer/Counter1 capture event                                               |
| 12     | 0x0016          | TIMER1 COMPA | Timer/Counter1 compare match A                                             |
| 13     | 0x0018          | TIMER1 COMPB | Timer/Counter1 compare match B                                             |
| 14     | 0x001A          | TIMER1 OVF   | Timer/Counter1 overflow                                                    |
| 15     | 0x001C          | TIMERO COMPA | Timer/Counter0 compare match A                                             |
| 16     | 0x001E          | TIMERO COMPB | Timer/Counter0 compare match B                                             |
| 17     | 0x0020          | TIMERO OVF   | Timer/Counter0 overflow                                                    |
| 18     | 0x0022          | SPI, STC     | SPI serial transfer complete                                               |
| 19     | 0x0024          | USART, RX    | USART Rx complete                                                          |
| 20     | 0x0026          | USART, UDRE  | USART, data register empty                                                 |
| 21     | 0x0028          | USART, TX    | USART, Tx complete                                                         |
| 22     | 0x002A          | ADC          | ADC conversion complete                                                    |
| 23     | 0x002C          | EE READY     | EEPROM ready                                                               |
| 24     | 0x002E          | ANALOG COMP  | Analog comparator                                                          |
| 25     | 0x0030          | TWI          | 2-wire serial interface                                                    |
| 26     | 0x0032          | SPM READY    | Store program memory ready                                                 |

Table 11-1. Reset and Interrupt Vectors in ATmega328P

| or No. | Program Addre | ss Source    | Interrupt Definition                                                       |
|--------|---------------|--------------|----------------------------------------------------------------------------|
| 1      | 0x0000        | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |
| 2      | 0x0002        | INTO         | External interrupt request 0                                               |
| 3      | 0x0004        | INT1         | External interrupt request 1                                               |
| 4      | 0x0006        | PCINT0       | Pin change interrupt request 0                                             |
| 5      | 0x0008        | PCINT1       | Pin change interrupt request 1                                             |
| 6      | 0x000A        | PCINT2       | Pin change interrupt request 2                                             |
| 7      | 0x000C        | WDT          | Watchdog time-out interrupt                                                |
| 8      | 0x000E        | TIMER2 COMPA | Timer/Counter2 compare match A                                             |
| 9      | 0x0010        | TIMER2 COMPB | Timer/Counter2 compare match B                                             |
| 10     | 0x0012        | TIMER2 OVF   | Timer/Counter2 overflow                                                    |
| 11     | 0x0014        | TIMER1 CAPT  | Timer/Counter1 capture event                                               |
| 12     | 0x0016        | TIMER1 COMPA | Timer/Counter1 compare match A                                             |
| 13     | 0x0018        | TIMER1 COMPB | Timer/Counter1 compare match B                                             |
| 14     | 0x001A        | TIMER1 OVF   | Timer/Counter1 overflow                                                    |
| 15     | 0x001C        | TIMERO COMPA | Timer/Counter0 compare match A                                             |
| 16     | 0x001E        | TIMERO COMPB | Timer/Counter0 compare match B                                             |
| 17     | 0x0020        | TIMERO OVF   | Timer/Counter0 overflow                                                    |
| 18     | 0x0022        | SPI, STC     | SPI serial transfer complete                                               |
| 19     | 0x0024        | USART, RX    | USART Rx complete                                                          |
| 20     | 0x0026        | USART, UDRE  | USART, data register empty                                                 |
| 21     | 0x0028        | USART, TX    | USART, Tx complete                                                         |
| 22     | 0x002A        | ADC          | ADC conversion complete                                                    |
| 23     | 0x002C        | EE READY     | EEPROM ready                                                               |
| 24     | 0x002E        | ANALOG COMP  | Analog comparator                                                          |
| 25     | 0x0030        | TWI          | 2-wire serial interface                                                    |
| 26     | 0x0032        | SPM READY    | Store program memory ready                                                 |

Direcciones para Timer

Table 11-1. Reset and Interrupt Vectors in ATmega328P

| or No. | Program Addres | s Source     | Interrupt Definition                                                       |
|--------|----------------|--------------|----------------------------------------------------------------------------|
| 1      | 0x0000         | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |
| 2      | 0x0002         | INT0         | External interrupt request 0                                               |
| 3      | 0x0004         | INT1         | External interrupt request 1                                               |
| 4      | 0x0006         | PCINT0       | Pin change interrupt request 0                                             |
| 5      | 0x0008         | PCINT1       | Pin change interrupt request 1                                             |
| 6      | 0x000A         | PCINT2       | Pin change interrupt request 2                                             |
| 7      | 0x000C         | WDT          | Watchdog time-out interrupt                                                |
| 8      | 0x000E         | TIMER2 COMPA | Timer/Counter2 compare match A                                             |
| 9      | 0x0010         | TIMER2 COMPB | Timer/Counter2 compare match B                                             |
| 10     | 0x0012         | TIMER2 OVF   | Timer/Counter2 overflow                                                    |
| 11     | 0x0014         | TIMER1 CAPT  | Timer/Counter1 capture event                                               |
| 12     | 0x0016         | TIMER1 COMPA | Timer/Counter1 compare match A                                             |
| 13     | 0x0018         | TIMER1 COMPB | Timer/Counter1 compare match B                                             |
| 14     | 0x001A         | TIMER1 OVF   | Timer/Counter1 overflow                                                    |
| 15     | 0x001C         | TIMERO COMPA | Timer/Counter0 compare match A                                             |
| 16     | 0x001E         | TIMERO COMPB | Timer/Counter0 compare match B                                             |
| 7      | 0x0020         | TIMERO OVF   | Timer/Counter0 overflow                                                    |
| 18     | 0x0022         | SPI, STC     | SPI serial transfer complete                                               |
| 9      | 0x0024         | USART, RX    | USART Rx complete                                                          |
| 0      | 0x0026         | USART, UDRE  | USART, data register empty                                                 |
| 1      | 0x0028         | USART, TX    | USART, Tx complete                                                         |
| 22     | 0x002A         | ADC          | ADC conversion complete                                                    |
| 23     | 0x002C         | EE READY     | EEPROM ready                                                               |
| 24     | 0x002E         | ANALOG COMP  | Analog comparator                                                          |
| 25     | 0x0030         | TWI          | 2-wire serial interface                                                    |
| 66     | 0x0032         | SPM READY    | Store program memory ready                                                 |

Módulo USART

Table 11-1. Reset and Interrupt Vectors in ATmega328P

| tor No. | Program Address | Source       | Interrupt Definition                                                       |
|---------|-----------------|--------------|----------------------------------------------------------------------------|
| 1       | 0x0000          | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |
| 2       | 0x0002          | INTO         | External interrupt request 0                                               |
| 3       | 0x0004          | INT1         | External interrupt request 1                                               |
| 4       | 0x0006          | PCINT0       | Pin change interrupt request 0                                             |
| 5       | 0x0008          | PCINT1       | Pin change interrupt request 1                                             |
| 6       | 0x000A          | PCINT2       | Pin change interrupt request 2                                             |
| 7       | 0x000C          | WDT          | Watchdog time-out interrupt                                                |
| 8       | 0x000E          | TIMER2 COMPA | Timer/Counter2 compare match A                                             |
| 9       | 0x0010          | TIMER2 COMPB | Timer/Counter2 compare match B                                             |
| 10      | 0x0012          | TIMER2 OVF   | Timer/Counter2 overflow                                                    |
| 11      | 0x0014          | TIMER1 CAPT  | Timer/Counter1 capture event                                               |
| 12      | 0x0016          | TIMER1 COMPA | Timer/Counter1 compare match A                                             |
| 13      | 0x0018          | TIMER1 COMPB | Timer/Counter1 compare match B                                             |
| 14      | 0x001A          | TIMER1 OVF   | Timer/Counter1 overflow                                                    |
| 15      | 0x001C          | TIMERO COMPA | Timer/Counter0 compare match A                                             |
| 16      | 0x001E          | TIMERO COMPB | Timer/Counter0 compare match B                                             |
| 17      | 0x0020          | TIMERO OVF   | Timer/Counter0 overflow                                                    |
| 18      | 0x0022          | SPI, STC     | SPI serial transfer complete                                               |
| 19      | 0x0024          | USART, RX    | USART Rx complete                                                          |
| 20      | 0x0026          | USART, UDRE  | USART, data register empty                                                 |
| 21      | 0x0028          | USART, TX    | USART, Tx complete                                                         |
| 22      | 0x002A          | ADC          | ADC conversion complete                                                    |
| 23      | 0x002C          | EE READY     | EEPROM ready                                                               |
| 24      | 0x002E          | ANALOG COMP  | Analog comparator                                                          |
| 25      | 0x0030          | TWI          | 2-wire serial interface                                                    |
| 26      | 0x0032          | SPM READY    | Store program memory ready                                                 |

Convertidor de Analógico a Digital

Table 11-1. Reset and Interrupt Vectors in ATmega328P

# Interrupciones Externas

| ctor No. | Program Addre | ss Source    | Interrupt Definition                                                       |
|----------|---------------|--------------|----------------------------------------------------------------------------|
| 1        | 0x0000        | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |
| 2        | 0x0002        | INTO         | External interrupt request 0                                               |
| 3        | 0x0004        | INT1         | External interrupt request 1                                               |
| 4        | 0x0006        | PCINT0       | Pin change interrupt request 0                                             |
| 5        | 0x0008        | PCINT1       | Pin change interrupt request 1                                             |
| 6        | 0x000A        | PCINT2       | Pin change interrupt request 2                                             |
| 7        | 0x000C        | WDT          | Watchdog time-out interrupt                                                |
| 8        | 0x000E        | TIMER2 COMPA | Timer/Counter2 compare match A                                             |
| 9        | 0x0010        | TIMER2 COMPB | Timer/Counter2 compare match B                                             |
| 10       | 0x0012        | TIMER2 OVF   | Timer/Counter2 overflow                                                    |
| 11       | 0x0014        | TIMER1 CAPT  | Timer/Counter1 capture event                                               |
| 12       | 0x0016        | TIMER1 COMPA | Timer/Counter1 compare match A                                             |
| 13       | 0x0018        | TIMER1 COMPB | Timer/Counter1 compare match B                                             |
| 14       | 0x001A        | TIMER1 OVF   | Timer/Counter1 overflow                                                    |
| 15       | 0x001C        | TIMERO COMPA | Timer/Counter0 compare match A                                             |
| 16       | 0x001E        | TIMERO COMPB | Timer/Counter0 compare match B                                             |
| 17       | 0x0020        | TIMERO OVF   | Timer/Counter0 overflow                                                    |
| 18       | 0x0022        | SPI, STC     | SPI serial transfer complete                                               |
| 19       | 0x0024        | USART, RX    | USART Rx complete                                                          |
| 20       | 0x0026        | USART, UDRE  | USART, data register empty                                                 |
| 21       | 0x0028        | USART, TX    | USART, Tx complete                                                         |
| 22       | 0x002A        | ADC          | ADC conversion complete                                                    |
| 23       | 0x002C        | EE READY     | EEPROM ready                                                               |
| 24       | 0x002E        | ANALOG COMP  | Analog comparator                                                          |
| 25       | 0x0030        | TWI          | 2-wire serial interface                                                    |
| 26       | 0x0032        | SPM READY    | Store program memory ready                                                 |

Table 11-1. Reset and Interrupt Vectors in ATmega328P

| tor No. | Program Addre | ss Source    | Interrupt Definition                                                       |
|---------|---------------|--------------|----------------------------------------------------------------------------|
| 1       | 0x0000        | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |
| 2       | 0x0002        | INT0         | External interrupt request 0                                               |
| 3       | 0x0004        | INT1         | External interrupt request 1                                               |
| 4       | 0x0006        | PCINT0       | Pin change interrupt request 0                                             |
| 5       | 0x0008        | PCINT1       | Pin change interrupt request 1                                             |
| 6       | 0x000A        | PCINT2       | Pin change interrupt request 2                                             |
| 7       | 0x000C        | WDT          | Watchdog time-out interrupt                                                |
| 8       | 0x000E        | TIMER2 COMPA | Timer/Counter2 compare match A                                             |
| 9       | 0x0010        | TIMER2 COMPB | Timer/Counter2 compare match B                                             |
| 10      | 0x0012        | TIMER2 OVF   | Timer/Counter2 overflow                                                    |
| 11      | 0x0014        | TIMER1 CAPT  | Timer/Counter1 capture event                                               |
| 12      | 0x0016        | TIMER1 COMPA | Timer/Counter1 compare match A                                             |
| 13      | 0x0018        | TIMER1 COMPB | Timer/Counter1 compare match B                                             |
| 14      | 0x001A        | TIMER1 OVF   | Timer/Counter1 overflow                                                    |
| 15      | 0x001C        | TIMERO COMPA | Timer/Counter0 compare match A                                             |
| 16      | 0x001E        | TIMERO COMPB | Timer/Counter0 compare match B                                             |
| 17      | 0x0020        | TIMERO OVF   | Timer/Counter0 overflow                                                    |
| 18      | 0x0022        | SPI, STC     | SPI serial transfer complete                                               |
| 19      | 0x0024        | USART, RX    | USART Rx complete                                                          |
| 20      | 0x0026        | USART, UDRE  | USART, data register empty                                                 |
| 21      | 0x0028        | USART, TX    | USART, Tx complete                                                         |
| 22      | 0x002A        | ADC          | ADC conversion complete                                                    |
| 23      | 0x002C        | EE READY     | EEPROM ready                                                               |
| 24      | 0x002E        | ANALOG COMP  | Analog comparator                                                          |
| 25      | 0x0030        | TWI          | 2-wire serial interface                                                    |
| 26      | 0x0032        | SPM READY    | Store program memory ready                                                 |





### Table 11-1. Reset and Interrupt Vectors in ATmega328P



|         | Vector No. | Program Address | Source       | Interrupt Definition                                                       |
|---------|------------|-----------------|--------------|----------------------------------------------------------------------------|
|         | 1          | 0x0000          | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |
| (0)     | 2          | 0x0002          | INTO         | External interrupt request 0                                               |
| ; ((n)) | 3          | 0x0004          | INT1         | External interrupt request 1                                               |
| \im     | 4          | 0x0006          | PCINT0       | Pin change interrupt request 0                                             |
| 6       | 5          | 0x0008          | PCINT1       | Pin change interrupt request 1                                             |
| ,       | 6          | 0x000A          | PCINT2       | Pin change interrupt request 2                                             |
| ) (     | 7          | 0x000C          | WDT          | Watchdog time-out interrupt                                                |
|         | 8          | 0x000E          | TIMER2 COMPA | Timer/Counter2 compare match A                                             |
|         | 9          | 0x0010          | TIMER2 COMPB | Timer/Counter2 compare match B                                             |
|         | 10         | 0x0012          | TIMER2 OVF   | Timer/Counter2 overflow                                                    |
|         | 11         | 0x0014          | TIMER1 CAPT  | Timer/Counter1 capture event                                               |
|         | 12         | 0x0016          | TIMER1 COMPA | Timer/Counter1 compare match A                                             |
|         | 13         | 0x0018          | TIMER1 COMPB | Timer/Counter1 compare match B                                             |
|         | 14         | 0x001A          | TIMER1 OVF   | Timer/Counter1 overflow                                                    |
|         | 15         | 0x001C          | TIMERO COMPA | Timer/Counter0 compare match A                                             |
|         | 16         | 0x001E          | TIMERO COMPB | Timer/Counter0 compare match B                                             |
|         | 17         | 0x0020          | TIMERO OVF   | Timer/Counter0 overflow                                                    |
|         | 18         | 0x0022          | SPI, STC     | SPI serial transfer complete                                               |
|         | 19         | 0x0024          | USART, RX    | USART Rx complete                                                          |
|         | 20         | 0x0026          | USART, UDRE  | USART, data register empty                                                 |
|         | 21         | 0x0028          | USART, TX    | USART, Tx complete                                                         |
|         | 22         | 0x002A          | ADC          | ADC conversion complete                                                    |
| 000000  | 23         | 0x002C          | EE READY     | EEPROM ready                                                               |
| 200000  | 24         | 0x002E          | ANALOG COMP  | Analog comparator                                                          |
| 0       | 25         | 0x0030          | TWI          | 2-wire serial interface                                                    |
|         | 26         | 0x0032          | SPM READY    | Store program memory ready                                                 |

### Flash



|   | 10 | ) |
|---|----|---|
| 7 | 1  | m |
|   | 4  |   |

| ector No. | <b>Program Address</b> | Source       | Interrupt Definition                                                       |                                         |       |
|-----------|------------------------|--------------|----------------------------------------------------------------------------|-----------------------------------------|-------|
| 1         | 0x0000                 | RESET        | External pin, power-on reset, brown-out reset and watchdog<br>system reset |                                         |       |
| 2         | 0x0002                 | INTO         | External interrupt request 0                                               |                                         |       |
| 3         | 0x0004                 | INT1         | External interrupt request 1                                               | Flash                                   |       |
| 4         | 0x0006                 | PCINT0       | Pin change interrupt request 0                                             |                                         | 1     |
| 5         | 0x0008                 | PCINT1       | Pin change interrupt request 1                                             | RJMP                                    | 0X0   |
| 6         | 0x000A                 | PCINT2       | Pin change interrupt request 2                                             | 2                                       | 0X0   |
| 7         | 0x000C                 | WDT          | Watchdog time-out interrupt                                                |                                         |       |
| 8         | 0x000E                 | TIMER2 COMPA | Timer/Counter2 compare match A                                             | RSI_INT0                                | 0X0   |
| 9         | 0x0010                 | TIMER2 COMPB | Timer/Counter2 compare match B                                             |                                         | 0X0   |
| 10        | 0x0012                 | TIMER2 OVF   | Timer/Counter2 overflow                                                    |                                         |       |
| 11        | 0x0014                 | TIMER1 CAPT  | Timer/Counter1 capture event                                               |                                         | 0X0   |
| 12        | 0x0016                 | TIMER1 COMPA | Timer/Counter1 compare match A                                             |                                         | 0X0   |
| 13        | 0x0018                 | TIMER1 COMPB | Timer/Counter1 compare match B                                             | *************************************** | 000   |
| 14        | 0x001A                 | TIMER1 OVF   | Timer/Counter1 overflow                                                    |                                         | 0X0   |
| 15        | 0x001C                 | TIMERO COMPA | Timer/Counter0 compare match A                                             |                                         | 1,,,, |
| 16        | 0x001E                 | TIMERO COMPB | Timer/Counter0 compare match B                                             |                                         | 0X0   |
| 17        | 0x0020                 | TIMERO OVF   | Timer/Counter0 overflow                                                    |                                         | 0X0   |
| 18        | 0x0022                 | SPI, STC     | SPI serial transfer complete                                               |                                         | 0X0   |
| 19        | 0x0024                 | USART, RX    | USART Rx complete                                                          |                                         | 1000  |
| 20        | 0x0026                 | USART, UDRE  | USART, data register empty                                                 |                                         | 0X0   |
| 21        | 0x0028                 | USART, TX    | USART, Tx complete                                                         |                                         | 1     |
| 22        | 0x002A                 | ADC          | ADC conversion complete                                                    |                                         | 1:    |
| 23        | 0x002C                 | EE READY     | EEPROM ready                                                               |                                         |       |
| 24        | 0x002E                 | ANALOG COMP  | Analog comparator                                                          |                                         |       |
| 25        | 0x0030                 | TWI          | 2-wire serial interface                                                    |                                         |       |
| 26        | 0x0032                 | SPM READY    | Store program memory ready                                                 |                                         |       |

# Registros para configurar interrupciones externas

200000000



| Registro | Dirección |
|----------|-----------|
| EIFR     | 0X1C      |
| EIMSK    | 0X1D      |
| EICRA    | 0X69      |







IN/OUT

0x0000 - 0x001F

Load/Store

32 registers 0x0000 - 0x001F

64 I/O registers 0x0020 - 0x005F

160 Ext I/O registers 0x0060 - 0x00FF

0x0100

Internal SRAM (2048x8)

0x08FF

Se debe tomar en cuenta que hay memoria de periféricos de Entrada y Salida con su dirección de memoria

| Registro | Dirección |
|----------|-----------|
| EIFR     | 0X1C      |
| EIMSK    | 0X1D      |
| EICRA    | 0X69      |



IN/OUT

0x0000 - 0x001F

También hay memoria de periféricos extendida

200000000

Load/Store

32 registers

64 I/O registers

0x0020 - 0x005F 0060 - 0x00FF

160 Ext I/O registers

Internal SRAM (2048x8)

0x08FF

0x0100

| OS DE CONFIGURACION MAPEADOS EN RA | м |
|------------------------------------|---|
|------------------------------------|---|

|          | I/O M | emory    |      | Extended I/O Memory |      |          |      |
|----------|-------|----------|------|---------------------|------|----------|------|
| REGISTRO | DIR   | REGISTRO | DIR  | REGISTRO            | DIR  | REGISTRO | DIR  |
| PINB     | 0x03  | OCR0A    | 0x27 | WDTCSR              | 0x60 | ICR1L    | 0x86 |
| DDRB     | 0x04  | OCR0B    | 0x28 | CLKPR               | 0x61 | ICR1H    | 0x87 |
| PORTB    | 0x05  | GPIOR1   | 0x2a | PRR                 | 0x64 | OCR1AL   | 0x88 |
| PINC     | 0x06  | GPIOR2   | 0x2b | OSCCAL              | 0x66 | OCR1AH   | 0x89 |
| DDRC     | 0x07  | SPCR     | 0x2c | PCICR               | 0x68 | OCR1BL   | 0x8a |
| PORTC    | 0x08  | SPSR     | 0x2d | EICRA               | 0x69 | OCR1BH   | 0x8b |
| PIND     | 0x09  | SPDR     | 0x2e | PCMSK0              | 0x6b | TCCR2A   | 0xb0 |
| DDRD     | 0x0a  | ACSR     | 0x30 | PCMSK1              | 0x6c | TCCR2B   | 0xb1 |
| PORTD    | 0x0b  | SMCR     | 0x33 | PCMSK2              | 0x6d | TCNT2    | 0xb2 |
| TIFR0    | 0x15  | MCUSR    | 0x34 | TIMSK0              | 0x6e | OCR2A    | 0xb3 |
| TIFR1    | 0x16  | MCUCR    | 0x35 | TIMSK1              | 0x6f | OCR2B    | 0xb4 |
| TIFR2    | 0x17  | SPMCSR   | 0x37 | TIMSK2              | 0x70 | ASSR     | 0xb6 |
| PCIFR    | 0x1b  | SPL      | 0x3d | ADCL                | 0x78 | TWBR     | 0xb8 |
| EIFR     | 0x1c  | SPH      | 0x3e | ADCH                | 0x79 | TWSR     | 0xb9 |
| EIMSK    | 0x1d  | SREG     | 0x3f | ADCSRA              | 0x7a | TWAR     | 0xba |
| GPIOR0   | 0x1e  |          |      | ADCSRB              | 0x7b | TWDR     | 0xbb |
| EECR     | 0x1f  |          |      | ADMUX               | 0x7c | TWCR     | 0xbc |
| EEDR     | 0x20  |          |      | DIDR0               | 0x7e | TWAMR    | 0xbd |
| EEARL    | 0x21  |          |      | DIDR1               | 0x7f | UCSR0A   | 0xc0 |
| EEARH    | 0x22  |          |      | TCCR1A              | 0x80 | UCSR0B   | 0xc1 |
| GTCCR    | 0x23  |          |      | TCCR1B              | 0x81 | UCSR0C   | 0xc2 |
| TCCR0A   | 0x24  |          |      | TCCR1C              | 0x82 | UBRR0L   | 0xc4 |
| TCCR0B   | 0x25  |          |      | TCNT1L              | 0x84 | UBRR0H   | 0xc5 |
| TCNT0    | 0x26  |          |      | TCNT1H              | 0x85 | UDR0     | 0xc6 |



### TABLA DE REGISTROS DE CONFIGURACION MAPEADOS EN RAM

IN •

OUT

| I/O Memory |      |          |      | Ext      | ended | I/O Memory |      |
|------------|------|----------|------|----------|-------|------------|------|
| REGISTRO   | DIR  | REGISTRO | DIR  | REGISTRO | DIR   | REGISTRO   | DIR  |
| PINB       | 0x03 | OCR0A    | 0x27 | WDTCSR   | 0x60  | ICR1L      | 0x86 |
| DDRB       | 0x04 | OCR0B    | 0x28 | CLKPR    | 0x61  | ICR1H      | 0x87 |
| PORTB      | 0x05 | GPIOR1   | 0x2a | PRR      | 0x64  | OCR1AL     | 0x88 |
| PINC       | 0x06 | GPIOR2   | 0x2b | OSCCAL   | 0x66  | OCR1AH     | 0x89 |
| DDRC       | 0x07 | SPCR     | 0x2c | PCICR    | 0x68  | OCR1BL     | 0x8a |
| PORTC      | 0x08 | SPSR     | 0x2d | EICRA    | 0x69  | OCR1BH     | 0x8b |
| PIND       | 0x09 | SPDR     | 0x2e | PCMSK0   | 0x6b  | TCCR2A     | 0xb0 |
| DDRD       | 0x0a | ACSR     | 0x30 | PCMSK1   | 0x6c  | TCCR2B     | 0xb1 |
| PORTD      | 0x0b | SMCR     | 0x33 | PCMSK2   | 0x6d  | TCNT2      | 0xb2 |
| TIFR0      | 0x15 | MCUSR    | 0x34 | TIMSK0   | 0x6e  | OCR2A      | 0xb3 |
| TIFR1      | 0x16 | MCUCR    | 0x35 | TIMSK1   | 0x6f  | OCR2B      | 0xb4 |
| TIFR2      | 0x17 | SPMCSR   | 0x37 | TIMSK2   | 0x70  | ASSR       | 0xb6 |
| PCIFR      | 0x1b | SPL      | 0x3d | ADCL     | 0x78  | TWBR       | 0xb8 |
| EIFR       | 0x1c | SPH      | 0x3e | ADCH     | 0x79  | TWSR       | 0xb9 |
| EIMSK      | 0x1d | SREG     | 0x3f | ADCSRA   | 0x7a  | TWAR       | 0xba |
| GPIOR0     | 0x1e |          |      | ADCSRB   | 0x7b  | TWDR       | 0xbb |
| EECR       | 0x1f |          |      | ADMUX    | 0x7c  | TWCR       | 0xbc |
| EEDR       | 0x20 |          |      | DIDR0    | 0x7e  | TWAMR      | 0xbd |
| EEARL      | 0x21 |          |      | DIDR1    | 0x7f  | UCSR0A     | 0xc0 |
| EEARH      | 0x22 |          |      | TCCR1A   | 0x80  | UCSR0B     | 0xc1 |
| GTCCR      | 0x23 |          |      | TCCR1B   | 0x81  | UCSR0C     | 0xc2 |
| TCCR0A     | 0x24 |          |      | TCCR1C   | 0x82  | UBRR0L     | 0xc4 |
| TCCR0B     | 0x25 |          |      | TCNT1L   | 0x84  | UBRR0H     | 0xc5 |
| TCNT0      | 0x26 |          |      | TCNT1H   | 0x85  | UDR0       | 0xc6 |



### TABLA DE REGISTROS DE CONFIGURACION MAPEADOS EN RAM

|          | I/O M |
|----------|-------|
| REGISTRO | DIR   |
| PINB     | 0x03  |
| DDRB     | 0x04  |
| PORTB    | 0x05  |
| PINC     | 0x06  |
| DDRC     | 0x07  |
| PORTC    | 0x08  |
| PIND     | 0x09  |
| DDRD     | 0x0a  |
| PORTD    | 0x0b  |
| TIFR0    | 0x15  |
| TIFR1    | 0x16  |
| TIFR2    | 0x17  |
| PCIFR    | 0x1b  |
| EIFR     | 0x1c  |
| EIMSK    | 0x1d  |
| GPIOR0   | 0x1e  |
| EECR     | 0x1f  |
| EEDR     | 0x20  |
| EEARL    | 0x21  |
| EEARH    | 0x22  |
| GTCCR    | 0x23  |
| TCCR0A   | 0x24  |
| TCCR0B   | 0x25  |
| TCNT0    | 0x26  |

IN 🤏

OUT

200000000

| mory     |      |  |  |  |
|----------|------|--|--|--|
| REGISTRO | DIR  |  |  |  |
| OCR0A    | 0x27 |  |  |  |
| OCR0B    | 0x28 |  |  |  |
| GPIOR1   | 0x2a |  |  |  |
| GPIOR2   | 0x2b |  |  |  |
| SPCR     | 0x2c |  |  |  |
| SPSR     | 0x2d |  |  |  |
| SPDR     | 0x2e |  |  |  |
| ACSR     | 0x30 |  |  |  |
| SMCR     | 0x33 |  |  |  |
| MCUSR    | 0x34 |  |  |  |
| MCUCR    | 0x35 |  |  |  |
| SPMCSR   | 0x37 |  |  |  |
| SPL      | 0x3d |  |  |  |
| SPH      | 0x3e |  |  |  |
| SREG     | 0x3f |  |  |  |

| 1 | Exte     | ended | I/O Memory |      |
|---|----------|-------|------------|------|
| I | REGISTRO | DIR   | REGISTRO   | DIR  |
| 1 | WDTCSR   | 0x60  | ICR1L      | 0x86 |
| 1 | CLKPR    | 0x61  | ICR1H      | 0x87 |
| I | PRR      | 0x64  | OCR1AL     | 0x88 |
| 1 | OSCCAL   | 0x66  | OCR1AH     | 0x89 |
| ı | PCICR    | 0x68  | OCR1BL     | 0x8a |
| 1 | EICRA    | 0x69  | OCR1BH     | 0x8b |
| ı | PCMSK0   | 0x6b  | TCCR2A     | 0xb0 |
| 1 | PCMSK1   | 0x6c  | TCCR2B     | 0xb1 |
| 1 | PCMSK2   | 0x6d  | TCNT2      | 0xb2 |
| 1 | TIMSK0   | 0x6e  | OCR2A      | 0xb3 |
| 1 | TIMSK1   | 0x6f  | OCR2B      | 0xb4 |
| 1 | TIMSK2   | 0x70  | ASSR       | 0xb6 |
| I | ADCL     | 0x78  | TWBR       | 0xb8 |
| 1 | ADCH     | 0x79  | TWSR       | 0xb9 |
| I | ADCSRA   | 0x7a  | TWAR       | 0xba |
| 1 | ADCSRB   | 0x7b  | TWDR       | 0xbb |
| ı | ADMUX    | 0x7c  | TWCR       | 0xbc |
| ı | DIDR0    | 0x7e  | TWAMR      | 0xbd |
| ı | DIDR1    | 0x7f  | UCSR0A     | 0xc0 |
| ı | TCCR1A   | 0x80  | UCSR0B     | 0xc1 |
| ı | TCCR1B   | 0x81  | UCSR0C     | 0xc2 |
| ı | TCCR1C   | 0x82  | UBRR0L     | 0xc4 |
| I | TCNT1L   | 0x84  | UBRR0H     | 0xc5 |
| L | TCNT1H   | 0x85  | UDR0       | 0xc6 |















La interrupción se ejecuta cuando hay un nivel bajo es decir cero



| EICRA - Exte | rnal Interr | upt Control F | Register A |   |       |       |       |       |
|--------------|-------------|---------------|------------|---|-------|-------|-------|-------|
| Bit          | 7           | 6             | 5          | 4 | 3     | 2     | 1     | 0     |
|              | -           | -             |            | - | ISC11 | ISC10 | ISC01 | ISC00 |
| ReadWrite    | R           | R             | R          | R | RW    | RW    | RW    | R/W   |



| Table 12-2. Interrupt 0 Sense Control |       |                                                            |  |  |  |
|---------------------------------------|-------|------------------------------------------------------------|--|--|--|
| ISC01                                 | ISC00 | Description                                                |  |  |  |
| . 0                                   | 0     | The low level of INTO generates an interrupt request.      |  |  |  |
| 0                                     | 1     | Any logical change on INT0 generates an interrupt request. |  |  |  |
| 1                                     | 0     | The falling edge of INT0 generates an interrupt request.   |  |  |  |
| 1                                     | 1     | The rising edge of INT0 generates an interrupt request.    |  |  |  |





| Table 12-2. Interrupt 0 Sense Control |       |                                                            |  |  |  |
|---------------------------------------|-------|------------------------------------------------------------|--|--|--|
| ISC01                                 | ISC00 | Description                                                |  |  |  |
| - 0                                   | 0     | The low level of INTO generates an interrupt request.      |  |  |  |
| 0                                     | 1     | Any logical change on INT0 generates an interrupt request. |  |  |  |
| 1                                     | 0     | The falling edge of INTO generates an interrupt request.   |  |  |  |
| 1                                     | 1     | The rising edge of INTO generates an interrupt request.    |  |  |  |





| Table 12-2 | Table 12-2. Interrupt 0 Sense Control |                                                            |  |  |  |  |
|------------|---------------------------------------|------------------------------------------------------------|--|--|--|--|
| ISC01      | ISC00                                 | Description                                                |  |  |  |  |
| . 0        | 0                                     | The low level of INTO generates an interrupt request.      |  |  |  |  |
| 0          | 1                                     | Any logical change on INT0 generates an interrupt request. |  |  |  |  |
| 1          | 0                                     | The falling edge of INTO generates an interrupt request.   |  |  |  |  |
| 1          | 1                                     | The rising edge of INTO generates an interrupt request.    |  |  |  |  |



1 1

| Table 12-1. Interrupt 1 Sense Control |       |                                                            |
|---------------------------------------|-------|------------------------------------------------------------|
| ISC11                                 | ISC10 | Description                                                |
| 0                                     | 0     | The low level of INT1 generates an interrupt request.      |
| 0                                     | 1     | Any logical change on INT1 generates an interrupt request. |
| 1                                     | 0     | The falling edge of INT1 generates an interrupt request.   |
| 1                                     | 1     | The rising edge of INT1 generates an interrupt request.    |









Se pone en 1 cuando hay una interrupción en INTFO







