

### (6609) Laboratorio de Microcomputadoras

# Proyecto: ( tp4 interrupción externa)

|          |                       | Ing. Guillermo Campiglio |                          |  |     |        |     |  |  |  |
|----------|-----------------------|--------------------------|--------------------------|--|-----|--------|-----|--|--|--|
|          | 1ro/2020<br>Miércoles |                          |                          |  |     |        |     |  |  |  |
| T        |                       |                          |                          |  |     |        |     |  |  |  |
|          | fe de Trabajos        |                          | Pedro Martos             |  |     |        |     |  |  |  |
|          | Do                    | cente guía:              |                          |  |     |        |     |  |  |  |
|          | Autores               |                          | Seguimiento del proyecto |  |     |        |     |  |  |  |
| Nombre   | Apellido              | Padrón                   |                          |  |     |        |     |  |  |  |
| Cristian | Simonelli             | 87879                    |                          |  |     |        |     |  |  |  |
|          |                       |                          |                          |  |     |        |     |  |  |  |
|          |                       |                          |                          |  |     |        |     |  |  |  |
|          |                       |                          |                          |  |     |        |     |  |  |  |
|          | Fecha de api          |                          | COLOQUI                  |  | Fir | na J.T | .P. |  |  |  |

Firma Profesor

| Objetivo:                                        | 2 |
|--------------------------------------------------|---|
| Desarrollo.                                      | 2 |
| Registros para el uso de interrupciones externas | 2 |
| Registro de control de interrupciones externas:  | 2 |
| Máscara de interrupción externa.                 | 2 |
| SEI.                                             | 2 |
| Listado de componentes:                          | 3 |
| Diagrama en bloques:                             | 4 |
| Circuito esquemático:                            | 5 |
| Diagrama de flujos:                              | 6 |
| Código:                                          | 7 |
| Resultado:                                       | 8 |
| Conclusiones:                                    | 8 |

### **Objetivo:**

El objetivo del trabajo práctico es capturar una interrupción externa y a partir de la misma prender o apagar leds.

#### Desarrollo.

Se utiliza la interrupción INTO del Atmega328p, por flanco.

INTO Se encuentra en PD2. (pin 9 de arduino Uno).

Cuando se detecta el flanco se llama a la ISR correspondiente, en este caso INT0addr.

En la rutina de interrupción de llama a la función delay del tp para titilar el led.

## Registros para el uso de interrupciones externas

#### Registro de control de interrupciones externas:

En este registro se elige la forma de activación de la interrupción.

En este caso se utiliza interrupción por flanco, pero podría ser por cambio de valor.

The external interrupt control register A contains control bits for interrupt sense control.

| Bit           | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |       |
|---------------|---|---|---|---|-------|-------|-------|-------|-------|
| (0x69)        | - | - | - | - | ISC11 | ISC10 | ISC01 | ISC00 | EICRA |
| Read/Write    | R | R | R | R | R/W   | R/W   | R/W   | R/W   | •     |
| Initial Value | 0 | 0 | 0 | 0 | 0     | 0     | 0     | 0     |       |

Table 12-2. Interrupt 0 Sense Control

| ISC01 | ISC00 | Description                                                |  |
|-------|-------|------------------------------------------------------------|--|
| 0     | 0     | The low level of INT0 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 INT0 generates an interrupt request.    |  |

#### Máscara de interrupción externa.

| Bit           | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    | _     |
|---------------|---|---|---|---|---|---|------|------|-------|
| 0x1D (0x3D)   | _ | - | - | - | - | - | INT1 | INT0 | EIMSK |
| Read/Write    | R | R | R | R | R | R | R/W  | R/W  | •     |
| Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    |       |

Se pone el 1 el bit correspondiente a la interrupción que se va a utilizar. En este caso bit 0.

#### SEI.

Habilita interrupciones globales, setea el bit de interrupciones en el status reg. Ambas, La global interrupt flag y el correspondiente bit en EIMSK tiene que estar activados para que se produzca la interrupción.

#### 108.1. Description

Sets the Global Interrupt Flag (I) in SREG (Status Register). The instruction following SEI will be executed before any pending interrupts.

Operation:

(i) I ← 1

Syntax: Operands: Program Counter:

(i) SEI None  $PC \leftarrow PC + 1$ 

16-bit Opcode:

1001 0100 0111 1000

# Listado de componentes:

Placa arduino UNO Atmega 328p \$659 aprox 10 usd.

2 led (pack de 10) \$70.

2 resistencias 220 ohm 1/8w 1% \$50.

1 switch \$10.

# Diagrama en bloques:



# Circuito esquemático (con resistencia de pull up):



# Diagrama de flujos:



### Código:

```
.include "m328pdef.inc"
.def dummyreg = r21
.cseg
.org 0x0000
           jmp
                  configuracion
.org INTOaddr
                  isr_int0
          jmp
.org INT_VECTORS_SIZE
configuracion:
                       dummyreg,low(RAMEND)
              ldi
                       spl,dummyreg
               out
               ldi
                       dummyreg,high(RAMEND)
               out
                       sph,dummyreg
               ldi
                       dummyreg, 0xfb
               out
                       DDRD, dummyreg
                       dummyreg, 0xff ; Port b OUTPUT
               ldi
                       DDRB, dummyreg
               out
                       dummyreg,(1 << ISC01 | 1 << ISC00) ;0x02 ; IE0 rising edge</pre>
               ldi
               sts
                       EICRA,dummyreg
               ldi
                       dummyreg,(1 << INTO) ;0x01 ; turn IEO on
                       EIMSK, dummyreg
               out
               cbi
                       PORTB, 1
               sbi
                       PORTB, 0
               sei
main:
               jmp main
isr_int0:
```

```
push
                        r20
                        PORTB, 0
                cbi
                ldi
                        r20, 10
                call
                         switch_led
loop:
                call
                        delay
                        r20
                dec
                        loop
               brne
                cbi
                        PORTB, 1
                        PORTB, 0
                sbi
               pop
                        r20
                reti
switch_led:
               push
                       r16
                       r17
                push
                       r16, PORTB
                ldi
                       r17, 0x02
                eor
                       r16, r17
                       PORTB, r16
                out
                       r17
               pop
               pop
                       r16
                ret
delay:
               push
                            r20
                            r21
               push
                push
                            r22
                ldi
                            r22, 40
loop1:
                             r21, 255
                ldi
                             r20, 255
loop2:
                ldi
100p3:
                dec
                             r20
               brne
                            loop3
                dec
                            r21
                            loop2
               brne
                            r22
                dec
               brne
                            loop1
                            r22
                рор
                pop
                            r21
                             r20
                pop
                ret
```

### Que hay que modificar para usar pull-ups:

Primero, se encienden las pull up internas del puerto.

```
ldi dummyreg,0x04 ; Pullups 2

out PORTD, dummyreg
```

Segundo se utiliza el int0 en falling edge.

```
ldi dummyreg,(1 << ISC01) ;0x02 ; IE0 falling edge

(ISC01=1;ISC00=0)

sts EICRA,dummyreg</pre>
```

#### Resultado:

Se logra controlar la interrupción 0 por flanco.

### **Conclusiones:**

Se puede controlar la interrupción 0 por flanco, sin embargo cada tanto, se dispara 2 veces.

Esto debe ser producto del rebote, probablemente se tendría que implementar un control del rebote del switch por software.