cpu는 기계어를 하나씩 읽어서 실행한다
프린터,모니터 아웃풋 디바이스
cpu보다 disk는 느리다. 디스크는 디바이스 컨트롤러가 담당한다.cpu는 읽고 실행하는 역할.
키보드에서 입력이 들어옴, 디스크에서 뭔가를 읽는다는걸 cpu가 어떻게 아느냐? 인터럽트 라인으로 알 수 있다
cpu는 디바이스에 직접적으로 접근하지않고 메모리에만 접근해서 인스트럭션을 실행한다
디스크에서 요청은 어떻게 보내냐? cpu가 디스크 컨트롤러에게 일을 시킨다
CPU는 기계어를 하나씩 읽어서 실행하는 역할을 합니다. 이때, CPU는 메모리에서 명령어와 데이터를 읽어오고, 실행 결과를 다시 메모리에 저장합니다. CPU가 명령어를 실행할 때, 레지스터라는 공간을 사용합니다. 레지스터는 메모리보다 빠르면서 정보를 저장할 수 있는 작은 공간으로, CPU에서 레지스터를 이용해 데이터를 처리하고 저장합니다.
시스템의 구조와 동작 방식은 크게 운영체제와 응용 프로그램으로 나뉩니다. 운영체제는 하드웨어와 응용 프로그램을 관리하는 소프트웨어입니다. 이를 통해 하드웨어와 응용 프로그램 간의 상호작용을 조정하며, 시스템 자원을 효율적으로 분배합니다. 응용 프로그램은 운영체제 위에서 실행되며, CPU, 메모리, 디스크 등의 자원을 사용하여 작업을 수행합니다.
CPU가 쉬지 않고 일하는 이유는, 컴퓨터 시스템이 짧은 간격으로 일을 처리하기 때문입니다. 이를 통해 사용자는 컴퓨터 시스템과 인터랙티브하게 작업할 수 있습니다. 또한, 컴퓨터 시스템에는 타이머라는 하드웨어가 있으며, 이는 특정 프로그램이 CPU를 독점하는 것을 막기 위해 사용됩니다
I/O Device Controller
I/O는 실제 디바이스와 로컬 버퍼 사이에서 일어난다
Device controller는 입출력이 끝났을 경우 인터럽트로 CPU에 그 사실을 알려준다
device driver(장치 구동기)
OS 코드 중 각 장치별 처리 루틴 → 소프트웨어
device controller(장치제어기)
각 장치를 통제하는 일종의 작은 CPU → 하드웨어
컴퓨터 시스템에서 데이터를 메인 메모리와 주변 장치 간에 직접 전송하기 위한 하드웨어 장치이다. CPU의 개입 없이 데이터를 주변 장치와 메모리 사이에서 직접 전송하여 시스템의 전송 속도를 향상 시킨다.
DMA 컨트롤러는 주변 장치(예: 하드디스트, 네트워크 카드, 사운드 카드 등)가 데이터를 메모리로 전송하는 동안 CPU를 해방시켜 다른 작업을 수행할 수 있도록 한다. 이는 데이터 전송 속도를 향상 시키고 CPU의 부하를 줄여 시스템 성능을 향상시키는데 도움을 준다
시스템 콜(System Call)은 운영체제에서 제공하는 서비스를 응용 프로그램이 호출하여 사용할 수 있는 인터페이스입니다. 시스템 콜은 응용 프로그램이 커널(Kernel)이라 불리는 운영체제의 핵심 부분에 있는 기능을 사용할 수 있도록 합니다. 응용 프로그램은 시스템 콜을 사용하여 운영체제에게 작업을 요청하고, 운영체제는 이를 처리하여 요청된 작업을 수행한 후 결과를 응용 프로그램에 반환합니다.
시스템 콜은 운영체제가 제공하는 다양한 서비스를 사용할 수 있도록 해줍니다. 예를 들어, 파일 시스템 접근, 프로세스 생성 및 제어, 네트워크 통신, 입출력 장치 관리 등의 작업을 시스템 콜을 통해 수행할 수 있습니다.
시스템 콜의 사용은 일반적으로 고급 언어(C, C++, 자바 등)에서 운영체제의 기능을 호출하는 형태로 이루어집니다. 응용 프로그램은 시스템 콜을 호출하여 운영체제에게 작업을 요청하고, 운영체제는 해당 요청을 처리하여 필요한 동작을 수행한 후, 결과를 응용 프로그램에 반환합니다. 시스템 콜은 운영체제와 응용 프로그램 간의 인터페이스로서 중요한 역할을 수행하며, 운영체제의 기능을 활용하여 다양한 작업을 수행할 수 있게 해줍니다.
인터럽트(Interrupt)는 컴퓨터 시스템에서 현재 실행 중인 프로그램의 흐름을 중단하고, 특정 이벤트가 발생했을 때 운영체제 또는 하드웨어가 처리해야 하는 작업을 수행하는 기술적인 메커니즘입니다.
인터럽트는 주로 하드웨어 장치나 외부 이벤트가 발생했을 때 사용됩니다. 예를 들어, 키보드나 마우스 입력, 타이머 등의 하드웨어 장치가 데이터를 전송하거나 처리 결과를 알리기 위해 인터럽트를 발생시킬 수 있습니다. 또한, 예외 상황이 발생했을 때(예: 0으로 나누기, 메모리 접근 오류 등) 운영체제가 이를 감지하고 처리하기 위해 인터럽트를 사용할 수도 있습니다.
인터럽트는 현재 실행 중인 프로그램의 흐름을 중단하고, 운영체제 또는 하드웨어가 미리 정의된 처리 루틴(Interrupt Service Routine, ISR)을 실행하여 인터럽트가 발생한 이벤트를 처리합니다. ISR은 해당 인터럽트에 대한 처리를 수행한 후, 원래의 프로그램 실행을 재개하거나 다음에 실행될 프로그램의 주소를 지정하는 등의 작업을 수행합니다.
인터럽트는 시스템의 성능과 안정성을 향상시키는데 중요한 역할을 합니다. 운영체제는 인터럽트를 통해 하드웨어 이벤트를 실시간으로 처리하고, 응용 프로그램은 인터럽트를 통해 운영체제의 서비스를 호출하여 다양한 기능을 사용할 수 있습니다. 인터럽트는 컴퓨터 시스템의 중요한 기술적인 개념이며, 운영체제, 하드웨어, 응용 프로그램 간의 상호작용을 가능하게 합니다.
cpu는 프로그램 카운터라는 레지스터가 가리키는 메모리 주소에서 인스트럭션을 하나 읽어서 실행하는 일만 하게된다.
다음 인스트럭션을 실행하기전에 인터럽트가 들어온게 있는지 체크한다.
만약 인터럽트가 들어온게 있다면 지금 프로그램 카운터가 가르키고 있던 걸 중단하고 cpu를 누가 사용하고 있던 상관없이 제어권이 운영체제로 넘어간다.
운영체제가 cpu를 가지고 있을땐 모드빗이 0이라서 모든 인스트럭션을 다 실행할 수 있다.
그 중 다른 사용자 프로그램의 메모리 영역을 본다거나, IO디바이스를 접근한다거나 하는 운영체제가 할수있는 인스트럭션으로 정의되어 있다.
1일땐 사용자 프로그램이 cpu를 가지고 있을때다. 그래서 한정된 인스트럭션만 실행할 수 있는데, 사용자 프로그램을 100% 신뢰할 수 없기때문에 (시스템이 망가진다거나) 자기 주소 메모리 영역에서만 일해야한다.
IO디바이스에 접근하는 모든 인스트럭션은 모드빗이 0일때 가능하다.
사용자 프로그램이 운영체제에게 서비스를 요청할땐 시스템 콜을 한다.
시스템 콜은 어떻게 하느냐? 의도적으로 인터럽트 라인에 세팅을 한다.
그럼 cpu는 인터럽트 라인이 세팅되었기 때문에 하던 일을 멈추고 cpu 제어권이 사용자 프로그램으로부터 운영체제로 넘어가게 된다.
두 경우 모두 IO의 완료는 인터럽트로 알려준다
프로그램은 실행파일로 파일 시스템에 저장되어 있다. 실행 파일을 실행시키면 메모리로 올라가서 프로세스가 된다. 물리적인 메모리에 바로 올라가는 것이 아니라 가상메모리에 먼저 올라간다. 프로세스들은 각자 주소공간을 가지고 있는데, 주소 공간은 0번지부터 시작한다. 주소 공간은 코드, 데이터, 스택 영역으로 이루어져 있다.
가상메모리의 주소 공간에서 프로세스가 사용하는 메모리 중 일부만 실제 물리적인 메인 메모리에 올려져 있고, 나머지는 스왑 영역(또는 페이지 파일)으로 저장된다. 이를 페이징이라고 한다.
파일 시스템은 전원이 나가도 파일 내용을 유지가 되지만, 스왑 영역이 있는 하드디스크는 전원이 나가면 내용도 날아간다. 메모리 연장 공간으로써 사용하는 것이 스왑영역이다.
메모리 주소 변환을 해주는 계층이 있다 → 하드웨어 장치가 있음.
프로세스마다 PCB가 하나씩 만들어져서 관리를 하고있다
커널 영역은 운영체제의 핵심 부분으로, 운영체제의 코드, 데이터, 스택 등이 위치하며 시스템 레벨의 권한을 가진 코드가 실행된다. 유저 영역은 사용자 프로세스의 코드, 데이터, 스택 등이 위치하며, 사용자 레벨의 권한을 가진 코드가 실행된다.
커널 영역과 유저 영역은 보안 및 안정성을 위해 분리되어 있다.
유저 영역은 사용자 프로세스들이 실행되는 공간으로, 프로그램 실행에 필요한 데이터, 코드, 스택 등이 위치하며, 사용자 레벨의 권한을 가진 코드가 실행된다. 유저 영역은 사용자 프로세스들이 서로 독립적으로 실행되는 공간이기 때문에, 서로 간 상호작용이나 데이터 공유가 가능하게끔 설계되어 있지만, 유저 영역의 프소세스는 커널 영역의 자원이나 기능에 직접 접근하는 것이 불가능하다.
시스템 콜을 사용하여 운영체제의 기능과 서비스를 호출할 수 있다.
시스템 콜은 사용자 프로세스가 커널 모드로 전환되어 운영 체제의 커널 영역에서 실행되는 함수 호출이다. 사용자 프로세스가 시스템 콜을 호출하면 해당 요청이 운영체제의 커널 영역으로 전달되어, 필요한 작업이 수행되고 그 결과가 사용자 프로세스에 반환된다. 이를 통해 사용자 프로세스는 커널 영역의 주소 공간에 접근하고, 운영체제의 기능을 사용할 수 있다.