인터럽트 처리 중에 동일한 인터럽트가 또 발생하면?
글쓴이: gurugio / 작성시간: 토, 2009/01/24 - 11:24오전
리눅스 커널에서 x86계열의 인터럽트 처리 관련 코드를 보다보니
인터럽트 핸들러를 호출하기 전에 irq_enter() 함수에서 커널 선점을 막고
스케줄링만 안되게 하고는 인터럽트를 막지 않더라구요.
단지 같은 인터럽트가 또 발생하면 IRQ_PENDING 비트를 설정해주어서
인터럽트 핸들러가 끝난 후에 또 다시 핸들러가 실행할 수 있도록 하는 것을 보았습니다.
(인터럽트 우선 순위 등의 하드웨어 적인 설정에 상관없이 프로세서가 받아들이는 관점에서만 봤을 때)
인터럽트 처리를 하고 있는 중간에 다른 인터럽트가 발생하면 다른 인터럽트의 핸들러가 실행되나요?
그리고 동일한 인터럽트가 발생하면 핸들러가 호출되는 코드 전까지는 실행되구요?
Forums:
제 기억엔 ISR로
제 기억엔 ISR로 들어갈 때는 하드웨어적으로 인터럽트가 disable되는 걸로 압니다만..
CPU 데이타쉬트를 찾아보시는 게 좋을 것 같습니다.
보통 챕터에 한 섹션으로 (Programmer's model의 Exception handling 정도)에 자세히 설명되어있죠.
예를 들어 오래된 ARM CPU의 경우
인터럽트 소스(Reset이냐 FIQ냐 IRQ나 Abort냐) 에 따라 자기이하의 우선순위 소스는 disable됩니다.
rommance.net
rommance.net
인터럽트가 발생하면
인터럽트가 발생하면 일단 그 인터럽트 라인은 disable 시킵니다. 그리고 인터럽트 처리가 완료된후 enable 시키도록 되어 있습니다.
가장 쉽게 볼 수 있는 형태가 디바이스 드라이버쪽 코드인데 request_irq() 에 등록되어 있는 인터럽트 처리 루틴을 보시면 될 겁니다.
========================
조직 : E.L.D(Embedded Linux Developer/Designer)
블로그 : poplinux@tistory.com
카페 : cafe.naver.com/poplinux
임베디드 리눅스 관련 프리렌서 지향
handle_level_irq(),
handle_level_irq(), handle_edge_irq() 가 제공됩니다.
전자는 서비스루틴 호출 전에 irqchip.mask() 콜백을 먼저 호출하고, 서비스루틴 종료 후 irqchip.unmask() 콜백을 호출합니다.
후자는 mask,unmask 없이 서비스루틴을 호출합니다.
level 인터럽트와 edge 인터럽트에 대해 이해하고 계신다면 저 두 함수의 동작특성도 이해가 가실겁니다.
OTL
댓글 달기