묻공러
4-3] CPU의 작동원리: 명령어 사이클과 인터럽트
묻공러
묻지마공부
묻공러
전체
오늘
어제
  • 분류 전체보기 (494) N
    • C (54)
      • [코드조선] C 핵심 (35)
      • [언어본색] C 기초 (19)
    • C++ (72)
      • [루키스] C++ (9)
      • [루키스] 콜백함수 (6)
      • [루키스] STL (8)
      • [루키스] Modern C++ (11)
      • [노코프] C++ (10)
      • [노코프] Tips (16)
      • [일지] C++ (12)
    • C# (7) N
      • [루키스] C# (7) N
      • [루키스] 자료구조 (0)
      • [루키스] 실전 문법 (0)
    • 자료구조 & 알고리즘 (50)
      • [코드조선] C 자료구조 & 알고리즘 (6)
      • [합격자되기] C++ 코딩테스트 (12)
      • [루키스] C++ 자료구조 & 알고리즘 (32)
    • CS (69)
      • [널널한 개발자] CS 개론 (19)
      • [혼자 공부하는] 컴퓨터 구조 (16)
      • [혼자 공부하는] 운영체제 (18)
      • [널널한 개발자] 네트워크 (16)
    • 게임 그래픽스 (46)
      • [전북대] OpenGL (25)
      • [일지] DirectX (21)
    • 게임 엔진 (124)
      • [코드조선] 언리얼 (53)
      • [코드조선] 언리얼 데디서버 (8)
      • [일지] 언리얼 (59)
      • [일지] 언리얼 (2) (3)
      • 유니티 (1)
    • 게임 서버 (17)
    • 게임 수학 & 물리 (19)
      • 게임 수학 (12)
      • 게임 물리 (7)
    • GIT & GITHUB (4)
    • 영어 (18)
      • [The Outfit] 대본 공부 (11)
      • the others (7)
    • 그 외 (14)
      • In (5)
      • Out (5)
      • Review (4)

인기 글

최근 글

hELLO · Designed By 정상우.
CS/[혼자 공부하는] 컴퓨터 구조

4-3] CPU의 작동원리: 명령어 사이클과 인터럽트

2023. 3. 31. 08:35

1] 명령어 사이클: 프로그램 속 명령어들은 일정한 주기가 반복되며 실행되는데 이 주기를 명령어 사이클이라고 함

1. 인출 사이클: 가장 먼저 CPU로 갖고 와야 한다

2. 간접 사이클: 메모리 접근이 필요한 경우에 간접 사이클이 실행된다

3. 실행 사이클: 갖고 왔으면 실행해야 한다

 

2] 인터럽트

(1) 인터럽트 개념

인출 > (간접) > 실행을 하는 일반적인 명령어 사이클 중에

인터럽트가 발생하면 명령어 사이클이 끊기게 된다

그렇게 된다면, 인출 사이클 > (간접 사이클)  > 실행 사이클 > (인터럽트 사이클)의 방식으로 동작한다

 

(2) 인터럽트의 종류

1. 동기 인터럽트(예외) - 폴트, 트랩, 중단, 소프트웨어 인터럽트

: CPU가 예기치 못한 상황을 접했을 때 발생 ex. 하드웨어 고장, 정전...

 

2. 비동기 인터럽트(하드웨어 인터럽트)

: 주로 입출력 장치에 의해 발생, 알림(세탁기, 전자레인지의 알림)과 같은 역할

 

(3) 왜 비동기 인터럽트가 필요한가?

입출력 작업 도중에도 효율적으로 명령어를 처리하기 위해 하드웨어 인터럽트가 사용됨

입출력장치는 CPU에 비해 느리기 때문에

인터럽트가 없다면 CPU는 프린트 완료 여루블 확인하기 위해 주기적으로 확인해야 한다

반면, 인터럽트가 있다면 입출력 작업 동안 CPU는 다른 일을 할 수 있다

 

(4) 하드웨어 인터럽트의 처리 순서

1. 입출력장치는 CPU에 인터럽트 요청 신호를 보냅니다

2. CPU는 실행 사이클이 끝나고 명령어를 인출하기 전 항상 인터럽트 여부를 확인합니다

3. CPU는 인터럽트 요청을 확인하고 인터럽트 플래그를 통해 현재 인터럽트를 받아들일 수 있는지 여부를 확인합니다

4. 인터럽트를 받아들일 수 있다면 CPU는 지금까지의 작업(기존 레지스터 값들)을 스택에 백업합니다

5. CPU는 인터럽트 벡터를 참조하여 인터럽트 서비스 루틴을 실행합니다

6. 인터럽트 서비스 루틴 실행이 끝나면 4. 에서 백업해 둔 작업을 복구하여 실행을 재개합니다

 

용어정리)

인터럽트 요청 신호:

입출력장치가 인터럽트를 하기 위해 요청을 보내는 신호

 

인터럽트 플래그:

CPU가 인터럽트 요청 신호를 받아들이면, 실행사이클이 끝나고 항상 플래그 레지스터 중 인터럽트 플래그를 확인하게 되는데 현재 인터럽트를 받아들일 수 있는지를 0과 1로 담고 있다

다만, 모든 인터럽트를 인터럽트 플래그로 막을 수 있는 건 아니며 긴급하거나 중요한 동기 인터럽트는 막을 수 없음

이처럼 인터럽트 플래그로 막을 수 없는 인터럽트를 NMI(Non-maskable Interrupt)라고 부름

따라서, 비동기 인터럽트(하드웨어 인터럽트)는 막을 수 있는 인터럽트와 막을 수 없는 인터럽트로 구분된다

 

인터럽트 서비스 루틴:

인터럽트가 발생했을 때 해당 인터럽트를 어떻게 처리하기 위한 프로그램

 

인터럽트 벡터:

각각의 인터럽트를 구분하기 위한 정보이며, 인터럽트 벡터를 통해 서비스 루틴의 시작점을 알 수 있다

또한, 인터럽트 벡터를 표의 형태로 모아놓을 것을 인터럽트 벡터 테이블이라고 부름

저작자표시 비영리 변경금지 (새창열림)

'CS > [혼자 공부하는] 컴퓨터 구조' 카테고리의 다른 글

5-2] CPU의 성능 향상 기법: 명령어 병렬 처리 기법  (0) 2023.03.31
5-1] CPU의 성능 향상 기법: 코어와 스레드  (0) 2023.03.31
4-2] CPU의 작동원리: 레지스터  (0) 2023.03.31
4-1] CPU의 작동원리: ALU와 제어장치  (0) 2023.03.31
3] 명령어  (0) 2023.03.31
'CS/[혼자 공부하는] 컴퓨터 구조' 카테고리의 다른 글
  • 5-2] CPU의 성능 향상 기법: 명령어 병렬 처리 기법
  • 5-1] CPU의 성능 향상 기법: 코어와 스레드
  • 4-2] CPU의 작동원리: 레지스터
  • 4-1] CPU의 작동원리: ALU와 제어장치
묻공러
묻공러
묻지마공부묻공러 님의 블로그입니다.
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.