

Interrupt

임베디드스쿨1기 Lv1과정 2021. 07. 16 이충재

#### 인터럽트란?

급한 작업을 먼저 실행하고 작업이 끝나면 다시 하던 작업을 하는 동작.

#### 인터럽트 수행과정

인터럽트 요청 → 인터럽트 허용 여부 판단 → 복귀주소 저장 → 인터럽트 서비스 루틴 실행 → 인터럽트 서비스 루틴 종료 후 인터럽트 이전 프로그램으로 복귀

예시) 밤 늦게 부모님 몰래 컴퓨터 게임하는 상황

부모님이 방으로 다가오는 발소리 들림 → 도중에 중단해도 되는 게임인지 판단 → 하던 게임을 일시 정지 → 방 불을 끄고 침대에 누움 → 부모님이 방을 확인하고 돌아가면 다시 게임시작



## 6.3.1 SREG – AVR Status Register

The AVR status register – SREG – is defined as:

| Bit           | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   | _    |
|---------------|-----|-----|-----|-----|-----|-----|-----|-----|------|
| 0x3F (0x5F)   | I   | T   | Н   | S   | ٧   | N   | Z   | С   | SREG |
| Read/Write    | R/W |      |
| Initial Value | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |      |

SREG 레지스터는 avr의 상태를 나타내는 레지스터이다.

여기에서 I비트는 인터럽트를 허용해주는 비트이다.

인터럽트를 사용하기 위해서는 반드시 I비트가 set되어야 한다.

일단 인터럽트가 발생하면 ISR프로그램이 실행되고

SREG 레지스터의 I비트는 0으로 clear된다. ISR이 끝나면 I비트가 다시 1로 set된다.

SEI명령어와 CLI명령어를 통해 I비트를 set또는 clear시킬수 있다.



## 12.2.4 PCICR – Pin Change Interrupt Control Register

| Bit           | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |       |
|---------------|---|---|---|---|---|-------|-------|-------|-------|
| (0x68)        | - | - | - | - | - | PCIE2 | PCIE1 | PCIE0 | PCICR |
| Read/Write    | R | R | R | R | R | R/W   | R/W   | R/W   |       |
| Initial Value | 0 | 0 | 0 | 0 | 0 | 0     | 0     | 0     |       |

PCICR은 PCINT에서 발생한 인터럽트를 허용해주는 권한을 가지는 레지스터이다.

PCIE 0~2는 다음과 같이 권한을 나눠 가진다.

```
PCIE0 - PCINT0 ~ 7 // PCINT0 벡터에 의하여 인터럽트 발생
PCIE1 - PCINT8 ~ 15 // PCINT1 벡터에 의하여 인터럽트 발생
PCIE2 - PCINT16 ~ 23 // PCINT2 벡터에 의하여 인터럽트 발생
```

\* PCINT는 PCMSK레지스터에 포함된 비트이다. (다음 장에 설명)



# 12.2.5 PCIFR – Pin Change Interrupt Flag Register

| Bit           | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |       |
|---------------|---|---|---|---|---|-------|-------|-------|-------|
| 0x1B (0x3B)   | - | - | - | - | - | PCIF2 | PCIF1 | PCIF0 | PCIFR |
| Read/Write    | R | R | R | R | R | R/W   | R/W   | R/W   |       |
| Initial Value | 0 | 0 | 0 | 0 | 0 | 0     | 0     | 0     |       |

PCIFR 레지스터는 인터럽트 요청을 받았을때 PCIF비트에 표시를 하는 레지스터

PCIF0은 PCINT  $0 \sim 7$ 로 부터 인터럽트 요청을 받을 때 1이 된다. PCIF1은 PCINT  $8 \sim 15$ 로 부터 인터럽트 요청을 받을 때 1이 된다. PCIF2는 PCINT  $16 \sim 23$ 으로 부터 인터럽트 요청을 받을 때 1이 된다.

인터럽트가 실행되면 PCIF비트는 다시 0이 된다.

\*\* 일반적으로 레지스터의 비트에 0을 써서 클리어 하지만 PCIF비트는 직접 1로 세팅하여 0으로 클리어 할 수 있다.



## L2.2.8 PCMSK0 – Pin Change Mask Register 0

| Bit           | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |        |
|---------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| (0x6B)        | PCINT7 | PCINT6 | PCINT5 | PCINT4 | PCINT3 | PCINT2 | PCINT1 | PCINT0 | PCMSK0 |
| Read/Write    | R/W    | '      |
| Initial Value | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |        |

PCINT는 해당하는 핀의 상태변화를 감지하여 인터럽트를 발생시키는 비트이다. PCINT비트가 1로 set되어 있어야 인터럽트를 발생시킬수 있다.

PCMSK1은 PCINT8 ~ 15, PCMSK2는 PCINT16 ~ 23 비트를 가지고 있다.

\*\* 주의: 인터럽트를 사용하기 위해서는

SREG – I비트와 해당하는 PCICR – PCIE비트가 set 되어야 한다.



#### 12.2.1 EICRA – External Interrupt Control Register A

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     |       |

ISC 0n – INT0핀의 인터럽트 발생조건 결정 ISC 1n – INT1핀의 인터럽트 발생조건 결정

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.    |

// INT1핀 low 일때 // INT1핀 변화 있을때 // INT1핀 상승엣지 // INT1핀 하강엣지

ISC0n 도 ISC1n과 똑같이 동작한다.



#### L2.2.2 EIMSK – External Interrupt Mask Register

| 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    |       |

INT1 비트에 1을 쓰면 INT1핀으로 부터 발생하는 인터럽트 허용 INT0 비트에 0을 쓰면 INT0핀으로 부터 발생하는 인터럽트 허용

### 12.2.3 EIFR – External Interrupt Flag Register

| Bit           | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     | _    |
|---------------|---|---|---|---|---|---|-------|-------|------|
| 0x1C (0x3C)   | - | - | - | - | - | - | INTF1 | INTF0 | EIFR |
| Read/Write    | R | R | R | R | R | R | R/W   | R/W   |      |
| Initial Value | 0 | 0 | 0 | 0 | 0 | 0 | 0     | 0     |      |

엣지 또는 논리적 변화에 의해 INT1핀 또는 INT0핀이 인터럽트를 요청하면 INTF1 비트 또는 INTF0 비트는 1로 세팅된다. 인터럽트 루틴이 실행되면 다시 0으로 돌아간다.



```
#include <avr/io.h>
#include <avr/interrupt.h>
int main(void)
                                   PB4를 출력으로 설정
   DDRB = 0x10;
                                   PB5만은 입력으로 설정
   DDRB = \sim (1 << DDB5);
                                  PB5 출력 high
   PORTB = 0x10;
   sei();
                                  SREG 레지스터 I비트 set
   PCICR |= (1 << PCIE0);
                                  PCICR 레지스터의 PCIE0비트 set
   PCMSKO = (1 \ll PCINT5);
                                  PCMSK0레지스터의 PCINT5비트 set
   while(1);
   return 0;
```



```
ISR(PCINTO_vect) Pcint0 벡터에 의한 인터럽트 서비스 루틴

[□ {
    PORTB ^= 0x10; PB5를 토글한다.
}
```

- 인터럽트 서비스 루틴(ISR) 인터럽트 발생시 실행중인 프로그램을 멈추고 ISR을 실행한다. ISR이 끝나면 다시 원래 진행하던 프로그램으로 되돌아간다.



