- 장치 컨트롤러에 대해 이해한다.
- 장치 드라이버에 대해 이해한다.
- 프로그램 입출력 방식이 무언인지 이해한다.
- 인터럽트 기반의 입출력 방식을 이해한다.
- DMA 입출력 방식을 이해한다.
◼ 입출력장치의 종류가 너무 많음 ➡ 다양한 입출력장치와 정보를 주고 받는 방식을 규격화
하기 어려움
◼ 일반적으로 CPU와 메모리의 데이터 전송률
은 높지만 입출력장치의 데이터 전송률
은 낮음 ➡ 전송률의 차이는 CPU와 메모리, 입출력장치 간의 통신을 어렵게 함
전송률
: 데이터를 얼마나 빨리 교환할 수 있는지를 나타내는 지표⭐ 위와 같은 이유로 입출력장치는 컴퓨터에 직접 연결 되지 않고, 장치 컨트롤러 (입출력 제어기, 입출력 모듈)
라는 하드웨어를 통해 연결됨
- CPU와 입출력장치 간의 통신 중개
- 오류 검출
- 데이터 버퍼링
입출력장치의 많은 종류로 인한 규격화
어려움 해결, 동시에 입출력장치에 발생한 오류 여부 검출
데이터 버퍼링
을 통해 전송률 차이를 완화 ➡ 버퍼(buffer)
라는 임시 저장 공간에 주고 받는 데이터를 저장하여 전송률
을 비슷하게 만드는 방법
- 데이터 레지스터
- 상태 레지스터
- 제어 레지스터
장치 컨트롤러의 내부구조 | |
---|---|
데이터 레지스터 | CPU와 입출력장치 사이에 주고받을 데이터가 담기는 레지스터. 버퍼 역할을 함. 주고 받는 데이터가 많은 입출력 장치에서는 레지스터 대신 RAM을 사용하기도 함 |
상태 레지스터 | 입출력장치의 상태 정보가 저장됨 |
제어 레지스터 | 입출력장치가 수행할 내용에 대한 제어 정보와 명령을 저장 |
◼ 새로운 장치를 컴퓨터에 연결하려면 장치 드라이버를 설치해야함
장치 드라이버(device driver)
란 장치 컨트롤러의 동작을 감지하고 제어함으로써 장치 컨트롤러가 컴퓨터 내부와 정보를 주고받을 수 있게 하는 프로그램
장치 컨트롤러
가 입출력장치를 연결하기 위한 하드웨어적 통로
라면, 장치 드라이버
는 입출력장치를 연결하기 위한 소프트웨어적 통로
- 프로그램 입출력
- 인터럽트 기반 입출력
- DMA 입출력
기본적으로 프로그램 속 명령어로 입출력장치를 제어하는 방법
프로그램 입출력 방식
에서의 입출력 작업은 CPU
가 장치 컨트롤러
의 레지스터 값
을 읽고 씀으로써 이뤄짐
- 메모리 맵 입출력
- 고립형 입출력
메모리에 접근하기 위한 주소 공간과 입출력장치에 접근하기 위한 주소 공간을 하나의 주소 공간으로 간주하는 방법
메모리 맵 주소 입출력 방식
에서는 메모리에 접근하는 명령어와 입출력장치에 접근하는 명령어가 같음메모리를 위한 주소 공간과 입출력장치를 위한 주소 공간을 분리하는 방법
고립형 입출력 방식
에서 CPU는 입출력 장치에 접근하기 위해 메모리에 접근하는 명령어와는 다른 입출력 명령어를 사용함입출력 장치에 의한 하드웨어 인터럽트는 정확히 말하면 장치 컨트롤러에 의해 발생함
플래그 레지스터
속 인터럽트 비트
를 비활성화하면 인터럽트 처리 도중 다른 인터럽트를 받지 않으므로 순차적 처리 가능인터럽트 비트
가 활성화되어있거나, 비활성화 되어 있더라도 NMI
가 발생한 경우, CPU는 우선순위가 높은 인터럽트 먼저 수행함NMI (Non-Maskable Interrupt)
: 인터럽트 비트가 비활성화되어 있어도 무시할 수 없는 인터럽트 프로그래머블 인터럽트 컨트롤러 (PIC)
라는 하드웨어 사용
PIC는 여러 장치 컨트롤러에 연ㄴ결되어 장치 컨트롤러에서 보낸 하드웨어 인터럽트 요청들의 우선순위를 판별한 뒤 CPU에게 알려주는 장치임
입출력장치와 메모리가 CPU를 거치지 않고 상호작용 할 수 있는 입출력 방식
프로그램 기반 입출력
과 인터럽트 기반 입출력
은 모두 입출력 장치와 메모리 간의 데이터 이동은 CPU
가 주도하고, 이동하는 데이터는 반드시 CPU
를 거친다. DMA 입출력 방식
을 하기 위해서는 시스템 버스에 연결된 DMA 컨트롤러
라는 하드웨어가 필요함➡ DMA 컨트롤러는 시스템 버스로 메모리에 직접 접근이 가능하지만, 시스템 버스
는 동시 사용이 불가능 (∵ 시스템 버스는 공유 자원)
DMA 컨트롤러
는 CPU
가 시스템 버스
를 이용하지 않을 때마다 조금씩 이용하거나, CPU
의 시스템 버스
이용을 일시적으로 제한한 뒤 사용함DMA 컨트롤러
와 장치 컨트롤러
들을 입출력 버스라는 별도의 버스에 연결하여 CPU
의 시스템 버스 이용 제한 문제 완화