학교 운영체제 과목을 수강하며 진행했던 nachos os 설치및 컴파일 과정입니다. 프로젝트 진행당시 제대로된 레퍼런스가 없어 고생한 기억이 있어 참고용으로 업로드하였습니다.
1)ThreadedKernel, UserProgKernel 두 class는 어떤 관련이 있는가? (코드 분석 설명)
-> c++에서
..
class 클래스명 {
// ..
}
class (상속받을)클래스명 : 접근제한자 (상속할) 클래스명 {
// ..
}
.. 이러한 구조를 띠는 것은 상속(Inheritance)을 의미합니다.상속이란 한 클래스가 다른 클래스에서 정의된 속성(자료,함수)를 이어받아 그대로 사용하는 것이며, 이미 정의된 클래스를 바탕으로 필요한 기능을 추가하여 정의할 수 있는 것입니다. UserProgKernel함수와 ThreadedKernel함수는
이러한 구조를 가지고 있기 때문에 UserProgKernel이 상속받는 관계로써 상속받는 UserProgkernel은 자식, ThreadedKernel은 부모의 관계입니다.즉 객체지향의 상속 관계에서 보았을 때 is a 관계라고 할 수 있다.
그림으로 표현한다면 다음과 같습니다.
2) thread/nachos, userprog/nachos 두 실행 파일을 실행할 때의 main 함수가 수행하는 작업의 차이점은 무엇인가? (main.h, main.cc)
우선 main.h에서 표시한 부분을 분석해보자면
1. 첫 줄의 #ifdef는 ‘만약 ~가 정의되어 있다면 실행하는 것’을 뜻하며 if문과는 달리 이 값이 True인지 False인지 상관하지 않습니다. 그렇기 때문에
2-1. USER_PROGRAM이 정의되어 있다면 아래의 코드를 실행합니다.
- #define은 메크로 함수이다. 메크로 함수란 함수처럼 인자를 설정할 수 있는 매크로를 의미합니다. 형식은 [#define (메크로 함수 이름) (메크로 함수 기능)]으로 작성한다.
-즉, userprog/nachos는 main.h에서 KernelType이 UserProgKernel로 정의된다.
2-2. 만약 - USER_PROGRAM이 정의되어 있지 않다면 아래의 코드를 실행합니다.
-즉, thread/nachos는 main.h에서 KernelType이 ThreadedKernel로 정의가 된다.
3. main.cc의 표시한 부분을 보면 Kernel이 KernelType에 따라서 객체가 생성되고,
각각 KernelType에 따라서 Initialize, Run, SelfTest 함수를 실행하는 것을 알 수 있다. 이는 각각의 thread/nachos와 userprog/nachos의 세 함수의 내용이 KernelType에 의해 서로 다른 실행 결과를 나타내는 것을 의미한다.
사실 학교 팀프로젝트 과제로 nachos설치를 받았을땐 별로 어려운 과정이 아닐꺼라 생각하고 있었지만 정말 3일동안 밤을 새며 진행한 기억이있다. 애초에 낯설기만 했던 우분투환경에서 익숙치 않은 c++을 다뤄보게 되었고 난생 처음보는 에러들이 눈앞에 뜰때마다 스트레스를 장난아니게 받았다. 사실 nachos자체를 컴파일하는 과정은 운영체제 학습에 도움이 되었나?라는 질문을 던진다면 그렇지 않다라고 말할것 같다. 하지만 이프로젝트에서 얻은 것은 소프트웨어 상에서 문제가 생겼을때 이것을 해결하는 능력에 대한 소양을 기를 수 있다는 점에 있다. 낯선 언어에 대한 마음의 장벽을 허물수 있었고 에러에 대한 스트레스를 받는것이 아닌 해결할수 있다는 자신감을 키워준 프로젝트 였다. 또한 어려움을극복 해냈을때 거기서 멈추는게 아닌 문제 해결방법을 공유하는 것에 대해 중요함을 느끼게 된 계기가 되었다.
크로스 컴파일러(cross compiler)는 컴파일러가 실행되는 플랫폼이 아닌 다른 플랫폼에서 실행 가능한 코드를 생성할 수 있는 컴파일러이다. 크로스 컴파일러 툴은 임베디드 시스템 혹은 여러 플랫폼에서 실행파일을 생성하는데 사용된다. 이것은 운영 체제를 지원하지 않는 마이크로 컨트롤러와 같이 컴파일이 실현 불가능한 플랫폼에 컴파일하는데 사용된다. 즉, 컴파일이 불가능한 곳에서 컴파일하여 실행파일을 생성하는 데 사용하기 위한 것으로 정의할 수 있다. 이것은 시스템이 사용하는데 하나 이상의 플랫폼을 쓰는반가상화에 이 도구를 사용하는 것이 더 일반적이게 되었다. 아래는 cross컴파일러와 일반적으로 사용되는 Native컴파일러의 차이점에 관한 표이다.
종류
차이점
Native(네티이브) 컴파일러
동일한 환경에서 동작되는 컴파일러로 이로 인해 생성되는 실행 파일을 동일한 환경에서 수행할 수 있음.
cross(크로스) 컴파일러
컴파일러가 동작하는 시스템과 컴파일러에 의해 생성된 실행 파일이 동작하는 시스템이 다른 것
3-1) cross컴파일러와 Native컴파일러의 차이점
3. cross-compiler설치
Nachos os는 오래된 os로써 컴파일간 에러가 많이 떳으므로 binutils와 gcc를 구버전을 구글 검색을 통해 다운받았다. (우분투 웹에서 직접 다운)
# sudo passwd root
#su
nachos설치 진행간 사용권한이 필요하므로 초기 루트계정 패스워드 설정 및 root사용자 전환을 해준다.
# apt-get upgrade
개발환경을 최신상태로 업그레이드 해준다.
# g++ -v
# apt-get install g++
g++ 버전 확인후 설치가 안됨을 인지하고 g++ 설치하였다.
# apt-get install csh
추후 Makefile 파일에서 csh을 이용하여 명령어를 주는 경우가 있기 때문에 설치하였다.
학교 운영체제 과목을 수강하며 진행했던 nachos os 설치및 컴파일 과정입니다. 프로젝트 진행당시 제대로된 레퍼런스가 없어 고생한 기억이 있어 참고용으로 업로드하였습니다.
1. Nachos란?
U.C.Berkeley대학의 Tom Anderson 교수가 운영체제 실습을 위해 만든 Operating System이다. Nachos와 운영체제의 차이점을 살펴보자면 운영체제는 기본적으로 컴퓨터의 하드웨어를 제어하고 응용소프트웨어를 위한 기반 환경을 제공하여, 사용자가 컴퓨터를 사용할 수 있도록 중재하는 프로그램이다. Nachos는 운영체제와는 달리 하드웨어 위에서 하드웨어를 직접 제어하는 OS가 아니라 HOST OS위에 작동하는 가상의 OS이며, MIPS machine을 가상으로 시뮬레이션하여 이 가상으로 작동하고 있는 MIPS 머신 위에서 커널로서 작동하게 된다.
종류
차이점
공통점
Nachos
유닉스나 리눅스의 응용프로그램의 형태, MIPS 또는 I386 machine 등의 하드웨어 위에서 구동된다.
인터럽트, 가상메모리, 입출력장치사용가능
실제 운영체제
하드웨어 기반에서 동작한다
Nachos의 경우 운영 체제 시뮬레이터는 단순히Bochs/VMware와 유사한 다른 OS(호스트 OS) 위에 OS(게스트 OS)를 실행할 수 있다는 것을 의미한다. 다음에 대한 에뮬레이션 기능을 제공한다.
·CPU(MIPS CPU)
·하드 드라이브
·인터럽트 컨트롤러, 타이머 및 misc. 기타 구성 요소
Nachos는 MIPS또는 i386 machine 등의 하드웨어 위에서 real OS로 사용할 수 있을 정도 수준이어서 실제 운영체제가 하는 것처럼 인터럽트, 가상메모리, 입출력장치 등을 시뮬레이션 할 수 있다. 교육 목적으로 만들어 진 것으로 소스 코드를 이해하는 것이 비교적 용의하며 kernel의 내부가 단순하고 체계적이므로 기본 os기능을 이해하기가 쉽다.
프로젝트 실습시에는 debugging이나 test의 편의를 위해 Nachos를 실제 하드웨어위에 동작 시키지 않고 Linux나 Solaris등의 다른 운영 체제에서 하나의 응용 프로그램을 실행시킨다. 그래서 일반 응용 프로그램을 debugging하는 것과 마찬가지로 GDB 등을 그대로 사용할 수 있다. 이럴 경우에는 하드웨어를 대신할 수 있는 시뮬레이터를 사용하게 되며 일반적으로 Nachos는 MIPS 시뮬레이터 코드도 함께 포함하고 있어 Nachos 커널과 MIPS 시뮬레이터를 하나의 프로그램으로 링크하여 사용한다. Nachos는 C++로 만들어졌으며 코드를 이해하고 수정하기 위해서 C++언어를 알아야 한다.
OS 커널의 다양한 시스템 호출에 대한 함수는 일반적으로 UNIX 시스템 호출과 유사한 방식으로 구현된다. 다양한 부분에서 운영 체제의 native코드를 사용하여 개체로 instance화 된다. 예를 들어 클래스 Machine은 파일 시스템, 프로세서, 타이머, 등 다양한 하드웨어 측면을 시뮬레이션하기 위해 정의되는 다양한 개체를 포함한다.
Nachos를 컴파일하기 위해서는 gcc가 필요하며, Nachos가 수행시키는 응용 프로그램이 MIPS코드로 컴파일 되어 있어야 하므로 cross-compiler가 필요하다. 따라서 Nachos를 compile 하고 cross-compiler를 설치한 후, 응용프로그램을 MIPS binary code로 만들어 Nachos에서 수행시킨다.
Nachos는 1992년 처음 개발되었을 때에는 C++로 만들어졌지만, 이식성 문제로 적극적으로 사용되지 않고 있었다. 2000년 UC Berkeley의 Dan Hennta가 JAVA로 다시 작성하여 학생들이 더 쉽게 Nachos를 사용할 수 있도록 만든 Nachos 5.0j 버전이 업데이트 되었다.이는 JVM을 사용하여 쓰레드를 돌리는 것으로 확인되었다.
3. Nachos의 구조
그림2-1은 Nachos의 구조를 나타내고 있다. Nachos는 HOST OS위에서 작동하는 가상의 OS이다. MIPS머신을 가상으로 시뮬레이션 하며 이 가상으로 작동하고 있는 MIPS머신위에서 커널로서 작동하게 됨을 알 수 있다.
4. Nachos의 구성요소
Nachos Machine은 3가지로 구성된다. 이는 레지스터, 물리적 메모리, 가상메모리이다.
- 레지스터: 프로세서에 위치한 고속메모리로 극히 소량의데이터나 처리 중인 중간 결과와도 같은 프로세서가 바로 사용할 수 있는 데이터를 담고 있는 영역을 말한다. Nachos에서는 40개의 레지스터로 이루어진 하나의 array는 스택 포인터, 더블 레지스터, 프로그램 카운터, 넥스트 프로그램 카운터, 레지스터 타겟 등으로 이루어져 있다. 이 레지스터는 0~39의 번호가 할당되어 있다.
- 메인 메모리:Random Access Memory (랜덤 액세스 메모리)또는 RAM이라고 한다. 이것은 중앙 처리 장치 (CPU)가 작업을 수행하는 데 필요할 때 빠르고 직접 액세스 할 수 있도록 운영 체제 소프트웨어, 소프트웨어 응용 프로그램 및 기타 정보를 저장하는 컴퓨터의 일부이다. Nachos에서 메모리는 바이트 단위의 주소를 가지며, 128바이트의 페이지들로 구성되어 있다. 이것은 디스크 섹터와 같은 크기이다. 메모리는 물리적인 주소를 메모리 주소로 엑세스 할 수 있게 한다. 기본적으로 Nachos Machine은 31페이지의 물리적 메모리를 갖는다.
- 가상메모리:가상 메모리는메모리를 관리하는 방법의 하나로, 각 프로그램에 실제 메모리 주소가 아닌 가상의 메모리 주소를 주는 방식을 말한다. 이러한 방식은멀티태스킹운영 체제에서 흔히 사용되며, 실제주기억장치(RAM)보다 큰 메모리 영역을 제공하는 방법으로 사용된다. Nachos는 single linear page나 소프트웨어로 관리되는 TLB 등으로 통해 가상메모리를 지원한다. 이러한 선택은 TLB나 Page Table 변수를 초기화 하는 것에 영향을 끼친다.