임베디드 시스템-인터럽트
인터럽트는 즉각적인주의가 필요한 이벤트를 나타내는 하드웨어 또는 소프트웨어에 의해 방출되는 프로세서에 대한 신호입니다. 인터럽트가 발생할 때마다 컨트롤러는 현재 명령의 실행을 완료하고Interrupt Service Routine (ISR) 또는 Interrupt Handler. ISR은 프로세서 또는 컨트롤러에 인터럽트 발생시 수행 할 작업을 알려줍니다. 인터럽트는 하드웨어 인터럽트 또는 소프트웨어 인터럽트 일 수 있습니다.
하드웨어 인터럽트
하드웨어 인터럽트는 디스크 컨트롤러 또는 외부 주변 장치와 같은 외부 장치에서 프로세서로 전송되는 전자 경고 신호입니다. 예를 들어, 키보드의 키를 누르거나 마우스를 움직이면 프로세서가 키 입력 또는 마우스 위치를 읽도록하는 하드웨어 인터럽트가 트리거됩니다.
소프트웨어 인터럽트
소프트웨어 인터럽트는 예외적 인 조건이나 프로세서에 의해 실행될 때 인터럽트를 발생시키는 명령 세트의 특수 명령에 의해 발생합니다. 예를 들어 프로세서의 산술 논리 장치가 숫자를 0으로 나누는 명령을 실행하면 0으로 나누기 예외가 발생하여 컴퓨터가 계산을 중단하거나 오류 메시지를 표시하게됩니다. 소프트웨어 인터럽트 명령은 서브 루틴 호출과 유사하게 작동합니다.
폴링이란 무엇입니까?
지속적인 모니터링 상태는 다음과 같이 알려져 있습니다. polling. 마이크로 컨트롤러는 다른 장치의 상태를 계속 확인합니다. 그렇게하는 동안 다른 작업을 수행하지 않고 모니터링을 위해 모든 처리 시간을 소비합니다. 이 문제는 인터럽트를 사용하여 해결할 수 있습니다.
인터럽트 방식에서 컨트롤러는 인터럽트가 발생한 경우에만 응답합니다. 따라서 컨트롤러는 인터페이스 및 내장 장치의 상태 (플래그, 신호 등)를 정기적으로 모니터링 할 필요가 없습니다.
인터럽트 대 폴링
다음은 폴링과 인터럽트를 구별하는 비유입니다.
일시 정지 | 투표 |
---|---|
인터럽트는 shopkeeper. 서비스 나 제품이 필요하면 그에게 가서 자신의 필요를 알려줍니다. 인터럽트의 경우 플래그 또는 신호가 수신되면 컨트롤러에 서비스가 필요함을 알립니다. | 폴링 방법은 salesperson. 판매원은 제품이나 서비스 구매를 요청하면서 집집마다 방문합니다. 마찬가지로 컨트롤러는 모든 장치에 대해 하나씩 플래그 또는 신호를 모니터링하고 서비스가 필요한 구성 요소에 서비스를 제공합니다. |
인터럽트 서비스 루틴
모든 인터럽트에 대해 ISR (인터럽트 서비스 루틴)이 있어야합니다. interrupt handler. 인터럽트가 발생하면 마이크로 컨트롤러는 인터럽트 서비스 루틴을 실행합니다. 모든 인터럽트에 대해 인터럽트 서비스 루틴 ISR의 주소를 보유하는 고정 된 위치가 메모리에 있습니다. ISR의 주소를 저장하기 위해 따로 설정 한 메모리 위치 테이블을 인터럽트 벡터 테이블이라고합니다.
인터럽트 벡터 테이블
8051의 RESET을 포함하여 6 개의 인터럽트가 있습니다.
인터럽트 | ROM 위치 (16 진수) | 핀 |
---|---|---|
인터럽트 | ROM 위치 (HEX) | |
직렬 COM (RI 및 TI) | 0023 | |
타이머 1 인터럽트 (TF1) | 001B | |
외부 HW 인터럽트 1 (INT1) | 0013 | P3.3 (13) |
외부 HW 인터럽트 0 (INT0) | 0003 | P3.2 (12) |
타이머 0 (TF0) | 000B | |
초기화 | 0000 | 9 |
리셋 핀이 활성화되면 8051은 주소 위치 0000으로 점프합니다. 이것은 파워 업 리셋입니다.
두 개의 인터럽트가 타이머에 대해 따로 설정됩니다. 하나는 타이머 0 용이고 다른 하나는 타이머 1 용입니다. 메모리 위치는 인터럽트 벡터 테이블에서 각각 000BH 및 001BH입니다.
하드웨어 외부 인터럽트를 위해 두 개의 인터럽트가 따로 설정됩니다. 핀 번호. 12 및 핀 번호. 포트 3의 13은 각각 외부 하드웨어 인터럽트 INT0 및 INT1 용입니다. 메모리 위치는 인터럽트 벡터 테이블에서 각각 0003H 및 0013H입니다.
직렬 통신에는 수신 및 전송 모두에 속하는 단일 인터럽트가 있습니다. 메모리 위치 0023H는이 인터럽트에 속합니다.
인터럽트를 실행하는 단계
인터럽트가 활성화되면 마이크로 컨트롤러는 다음 단계를 거칩니다.
마이크로 컨트롤러는 현재 실행중인 명령어를 닫고 다음 명령어 (PC)의 주소를 스택에 저장합니다.
또한 모든 인터럽트의 현재 상태를 내부적으로 (즉, 스택이 아님) 저장합니다.
인터럽트 서비스 루틴의 주소를 보유하는 인터럽트 벡터 테이블의 메모리 위치로 점프합니다.
마이크로 컨트롤러는 인터럽트 벡터 테이블에서 ISR의 주소를 가져 와서 점프합니다. 인터럽트 서비스 서브 루틴 인 RETI (인터럽트에서 복귀)를 실행하기 시작합니다.
RETI 명령을 실행하면 마이크로 컨트롤러는 중단 된 위치로 돌아갑니다. 첫째, 스택의 최상위 바이트를 PC로 팝하여 스택에서 프로그램 카운터 (PC) 주소를 가져옵니다. 그런 다음 해당 주소에서 실행을 시작합니다.
에지 트리거링과 레벨 트리거링
인터럽트 모듈은 레벨 트리거 또는 에지 트리거의 두 가지 유형입니다.
트리거 된 레벨 | 에지 트리거 |
---|---|
레벨 트리거 인터럽트 모듈은 인터럽트 소스의 레벨이 어설 션 될 때마다 항상 인터럽트를 생성합니다. | 에지 트리거 인터럽트 모듈은 인터럽트 소스의 어설 션 에지를 감지 할 때만 인터럽트를 생성합니다. 인터럽트 소스 레벨이 실제로 변경 될 때 에지가 감지됩니다. 또한 주기적 샘플링을 통해 감지 할 수 있으며 이전 샘플이 어설 션 해제되었을 때 어설 션 된 레벨을 감지 할 수 있습니다. |
펌웨어 인터럽트 처리기가 인터럽트를 처리 할 때 인터럽트 소스가 여전히 어설 션되면 인터럽트 모듈이 인터럽트를 다시 생성하여 인터럽트 처리기가 다시 호출되도록합니다. | 에지 트리거 인터럽트 모듈은 인터럽트 소스의 작동 방식에 관계없이 즉시 작동 할 수 있습니다. |
레벨 트리거 인터럽트는 펌웨어에서 번거 롭습니다. | 에지 트리거 인터럽트는 펌웨어의 코드 복잡성을 낮게 유지하고 펌웨어 조건 수를 줄이며 인터럽트 처리시 더 많은 유연성을 제공합니다. |
인터럽트 활성화 및 비활성화
재설정시 모든 인터럽트는 활성화 된 경우에도 비활성화됩니다. 마이크로 컨트롤러가 이러한 인터럽트에 응답하려면 소프트웨어를 사용하여 인터럽트를 활성화해야합니다.
IE (인터럽트 활성화) 레지스터는 인터럽트 활성화 및 비활성화를 담당합니다. IE는 비트 주소 지정이 가능한 레지스터입니다.
인터럽트 활성화 레지스터
EA | - | ET2 | ES | ET1 | EX1 | ET0 | EX0 |
---|
EA − 전역 활성화 / 비활성화.
- − 정의되지 않음.
ET2 − 타이머 2 인터럽트를 활성화합니다.
ES − 직렬 포트 인터럽트를 활성화합니다.
ET1 − 타이머 1 인터럽트를 활성화합니다.
EX1 − 외부 1 인터럽트를 활성화합니다.
ET0 − 타이머 0 인터럽트를 활성화합니다.
EX0 − 외부 0 인터럽트를 활성화합니다.
인터럽트를 활성화하려면 다음 단계를 따릅니다.
나머지 레지스터를 적용하려면 IE 레지스터 (EA)의 비트 D7이 높아야합니다.
EA = 1이면 인터럽트가 활성화되고 IE의 해당 비트가 높으면 이에 응답합니다. EA = 0이면 IE 레지스터의 관련 핀이 높은 경우에도 인터럽트가 응답하지 않습니다.
8051의 인터럽트 우선 순위
인터럽트 중 하나에 더 높은 우선 순위를 할당하여 인터럽트 우선 순위를 변경할 수 있습니다. 이것은 레지스터를 프로그래밍하여 수행됩니다.IP (인터럽트 우선 순위).
다음 그림은 IP 레지스터의 비트를 보여줍니다. 재설정시 IP 레지스터에는 모두 0이 포함됩니다. 인터럽트에 더 높은 우선 순위를 부여하기 위해 IP 레지스터의 해당 비트를 높게 만듭니다.
- | - | - | - | PT1 | PX1 | PT0 | PX0 |
---|
- | IP.7 | 구현되지 않았습니다. |
- | IP.6 | 구현되지 않았습니다. |
- | IP.5 | 구현되지 않았습니다. |
- | IP.4 | 구현되지 않았습니다. |
PT1 | IP.3 | 타이머 1 인터럽트 우선 순위 레벨을 정의합니다. |
PX1 | IP.2 | 외부 인터럽트 1 우선 순위 수준을 정의합니다. |
PT0 | IP.1 | 타이머 0 인터럽트 우선 순위 레벨을 정의합니다. |
PX0 | IP.0 | 외부 인터럽트 0 우선 순위 수준을 정의합니다. |
인터럽트 내부 인터럽트
8051이 인터럽트에 속하는 ISR을 실행하고 다른 ISR이 활성화되면 어떻게됩니까? 이러한 경우 높은 우선 순위 인터럽트는 낮은 우선 순위 인터럽트를 인터럽트 할 수 있습니다. 이것은interrupt inside interrupt. 8051에서 낮은 우선 순위 인터럽트는 높은 우선 순위 인터럽트에 의해 인터럽트 될 수 있지만 다른 낮은 우선 순위 인터럽트에 의해 인터럽트되지 않습니다.
소프트웨어에 의한 인터럽트 트리거
시뮬레이션을 통해 ISR을 테스트해야하는 경우가 있습니다. 이것은 인터럽트를 high로 설정하는 간단한 명령으로 수행 할 수 있으며, 따라서 8051이 인터럽트 벡터 테이블로 점프하게합니다. 예를 들어, 타이머 1에 대해 IE 비트를 1로 설정합니다.SETB TF1 8051을 중단하고 강제로 인터럽트 벡터 테이블로 점프합니다.