Exception: 두 판 사이의 차이

youngwiki
편집 요약 없음
36번째 줄: 36번째 줄:
===Interrupts (Asynchronous Exceptions)===
===Interrupts (Asynchronous Exceptions)===
프로세서 외부에서 발생하는 이벤트에 의해 발생한다.<ref>키보드의 입력, 네트워크 패킷 수신, 타이머 만료 등</ref>
프로세서 외부에서 발생하는 이벤트에 의해 발생한다.<ref>키보드의 입력, 네트워크 패킷 수신, 타이머 만료 등</ref>
CPU에는 물리적인 Interrupt Pin이 핫라인 처럼 따로 존재한다. 이때 해당 핀의 신호가 0 ->1로 바뀌면 인터럽트를 감지한다.
 
CPU에는 물리적인 Interrupt Pin이 핫라인 처럼 따로 존재하며, 해당 핀의 신호가 0 ->1로 바뀌면 인터럽트를 감지한다.
이를 Interrupt Handler가 처리하고 다시 next instruction으로 돌아간다.
이를 Interrupt Handler가 처리하고 다시 next instruction으로 돌아간다.


==각주==
==각주==
[[분류:컴퓨터 시스템]]
[[분류:컴퓨터 시스템]]

2025년 3월 11일 (화) 16:26 판

개요

Flow of Exception

Exception이란 특정 이벤트가 발생함에 따라 OS kernel로 Control을 이동시키는 것을 의미한다. 이때 exception이 발생하면 커널[1]에서 exception handler를 통해서 이를 처리한다.

  • 예시: 0나누기 / 오버플로우 / page fault[2] / I/O request completion / Ctrl - C

또한 Exception table이란 예외 발생시 해당 예외를 처리하는 Exception Handler의 주소를 저장하는 데이터 구조를 의미한다. 각각의 Exception은 고유한 예외 코드 K를 가지고 있으며, exception handler K는 해당 예외가 발생시 Exception Table에 저장된 주소를 통해 호출된다.

종류

Class Cause Async/sync Return behavior
Interrupt Signal from I/O Device Async Always returns to next instruction
Trap Intentional exception Sync Always returns to next instruction
Fault Potentially recoverable error Sync Might returns to current instruction
Abort Non recoverable error Sync Never returns

Interrupts (Asynchronous Exceptions)

프로세서 외부에서 발생하는 이벤트에 의해 발생한다.[3]

CPU에는 물리적인 Interrupt Pin이 핫라인 처럼 따로 존재하며, 해당 핀의 신호가 0 ->1로 바뀌면 인터럽트를 감지한다. 이를 Interrupt Handler가 처리하고 다시 next instruction으로 돌아간다.

각주

  1. 메모리에 존재하는 OS의 핵심 부분이다. 시스템 리소스에 직접 접근하여 시스템의 상태를 관리하고 오류나 예외상황을 처리한다.
  2. 프로그램이 가상 메모리에 접근하려고 할 때, 해당 페이지(데이터 블록)가 주기억장치(RAM)에 존재하지 않으면 발생한다.
  3. 키보드의 입력, 네트워크 패킷 수신, 타이머 만료 등