'Computer Science/Linux'에 해당되는 글 15건
- 2010.06.04 우분투 10.04 설치 후 만져주기
- 2010.05.17 EXPORT_SYMBOL_GPL vs EXPORT_SYMBOL
- 2010.01.26 VirtualBox 가변크기 가상디스크 용량 줄이기 2
- 2010.01.07 Fedora에서 소프트웨어 개발 패키지 추가...
- 2009.11.13 리눅스 커널 이미지의 구조
- 2009.11.09 Linux용 UltraEdit..
- 2009.10.01 LCD4Linux
- 2009.09.15 리눅스에서 윈도우 공유 폴더 접근하기
- 2009.09.02 putty에서 한글 쓰기 (페도라 코어 10)
- 2009.04.09 Linux에서 I/O Scheduler 변경
yum install gcc yum groupinstall 'Development Tools'
2.2. 커널 이미지 파일의 구조
이미 커널을 컴파일 해본 사람은 최종 커널 이미지 파일이 압축되어 있단 것을 알 수있을 것이다. [1]이제 LILO가 메모리에 커널을 읽어 올리고 실행해 주기 까지의 과정을 살펴볼 것이다.
그에 앞서 커널 이미지 파일의 구조에 대해 먼저 알아본다. 구조를 알아야 LILO가 커널을 어떤 식으로 부팅하게 해주는지 이해가 빠를 것이다.
zImage나 bzImage나 구조는 같다. 단지 메모리에 올려지는 위치나 동작 방식이 약간 차이가 있기 때문에 이것이 감안된 각각에 맞는 코드가 사용될 뿐이다.
그림 2-2. bzImage의 구조
bbootsect나 bsetup의 앞에 붙은 b는 bzImage의 앞에 붙은 b와 같은 의미로 "big kernel"을 의미한다. bbootsect는 플로피로 부팅될 때 즉 부트로더가 없이 커널이 직접 읽혀져 부팅될 때 필요한 부트 섹터다. lilo에 의해 부팅되는 경우는 필요 없는 부분이다.
2.2.1. 커널의 부팅
lilo에 의해 부팅이 시작되면 LILO는 bzImage를 하드 디스크에서 읽어 메모리에 올려 놓고 LILO에 의한 부팅일 경우 필요 없는 bbootsect를 건너뛴 bsetup에서부터 실행되도록 해준다. LILO의 역할은 bsetup에 실행 권을 넘겨주는데 까지다.
실행된 bsetup은 메모리 세팅을 마치고 압축된 커널 이미지의 압축을 풀기 위한 코드로 실행을 옮긴다. "head + misc"로 표시된 부분이고 이곳이 실행되면 piggy.o는 압축이 풀려 실행 가능한 리눅스 커널이 메모리에 존재하게 된다. 압축이 풀릴 때 화면에 "Uncompressing Linux... "란 메시지가 출력된다.
그러나 압축이 풀렸다고 해서 바로 커널을 실행하는 것은 아니고 메모리 낭비를 막기 위한 정리를 한번 다시 하고 나서 커널이 실행된다. 압축이 풀리고나면 처음 LILO에 의해 읽혀진 커널 이미지는 필요 없게 된다. 그러므로 이 부분을 내버려두면 그만큼 메모리 낭비이므로 압축 풀린 커널 이미지를 옮겨와 되도록 많은 메모리를 사용하도록 한 후 커널을 실행해 준다. 커널이 실행되기 시작하면 "ok, booting the kernel."이 출려되고 커널에 의한 출력이 화면에 나타나게 된다.
2.2.2. zimage와 bzImage의 차이
zimage와 bzImage는 무슨 차이가 있는걸까? 필자는 처음에 z와 b의 의미 때문에 gzip으로 압축하거나 아니면 bzip2로 압축한 것의 차이인줄 알았지만 압축은 gzip으로 같고 단지 z는 압축했단 의미고 b는 'big kernel'이란 뜻인걸 알았다. 왜 이렇게 나눠졌는가?
이미 1.7절에서 언급했던 것 처럼 커널의 크기가 너무 커서 압축 후에도 일정 크기를 넘어가면 zImage 대신 bzImage를 사용해야한다고 했는데 이유는 다음과 같다.
pc가 처음 만들어질 땐 OS로 도스가 사용됐고 이 때 M$의 유명한 분이 640KB면 충분하다고 했단 소릴 들은적이 있을 것이다. 처음 PC가 만들어질 때의 CPU는 8086으로 16bit CPU 였다. 이 프로세서가 지원하는 최대의 메모리는 1MB였기 때문에 모든 어드레스 스페이스가 1MB 내로 제한됐다. 그러므로 램을 640kb 사용하고 나머지 영역엔 MGA, VGA와 같은 다른 디바이스를 할당해 줬다.
문제는 여기서 시작되는데 AT시절의 PC 기본 구조는 현재까지도 계속 유지되고 있기 때문에 PC가 처음 부팅되면 하위 1MB 만을 사용한다고 생각하면 된다. 보호모드라고 알고 있는 386 이상의 cpu가 가진 기능을 사용하지 않고 리얼모드란 8086 호환 모드를 사용하기 때문인데 이는 OS가 보호모드를 사용할 상태를 만들고 전환하기 전까지는 계속 리얼모드로 남아있기 때문이다.
리눅스 커널의 크기가 커서 커널을 읽어들이는 프로그램 크기나 시스템에서 사용되는 약간의 메모리를 제외한 나머지 램의 빈공간에 읽어 들이지 못하면 하위 1MB가 아니라 그 이상의 연속된 메모리에 커널을 읽어 들이고 압축을 푸는 등의 일을 해야할 것이다. 반대로 남은 용량에 커널이 들어갈 수 있다면 당연히 읽어 들이고 압축을 풀면 끝날 것이고...
이렇게 메모리에 처음 적재되고 압축 풀리고 하는 절차와 위치가 다르기 때문에 zImage와 bzImage오 나뉜 것이고 커널 이미지 파일의 앞부분 bootsect와 setup이 각각에 따라 맞는 것으로 합쳐지게된다. 그리고 bzimage의 경우 하위 1M는 사용하지 못하는데 리눅스에선 그렇다!
컴파일 단계에서 make zImage 했을 경우 System is too big. Try using bzImage or modules. 라고 에러가 난다면 더 많은 부분을 module로 만들거나 bzImage를 사용해야한다.
주석
[1] | zImage, bzImage 등에서 z가 의미하는 것이 gzip으로 압축됐단 것이다. |

1) [탐색기-도구-폴더옵션-보기] 에서 '모든 사용자에게 동일한 폴더 공유 권한을 지정(권장)' 항목의 체크를 지운다.

2) [제어판-관리도구-컴퓨터관리-시스템 도구-로컬 사용자 및 그룹-사용자] 에서 오른쪽 버튼을 눌러 새사용자를 추가한다.
*다음 로그온할 때 반드시 암호 변경'항목의 체크를 지우고 '암호 사용 기간 제한 없음'에 체크한다.

3) 탐색기에서 C:\에 대고 [오른쪽 마우스버튼 클릭-공유및보안선택-이 폴더를 공유함-새 공유 선택]
*공유 이름(꼭 기억)과 허용인원을 지정한후 확인
*밑에 밑에 있는 '사용권한'을 클릭한다. Everyone은 제거하고 추가를 눌러 2)에서 지정한 ID를 '선택할 개체 이름 입력'에 입력한다. 확인을 누르고 '모든권한'을 부여하고 확인누름.
4) 리눅스에서 삼바 클라이언트 패키지가 설치되어 있나 확인한 후,
% smbmount '\\호스트IP주소(or Domain name)\공유이름(3번에서 기억하라고 한것)' /mountpoint -o username=xxx,password=xxx
예) % smbmount '\\143.248.141.227\main' /mountpoint -o username=vampire,password=xxxx
4-1) samba 3.0.11이상 부터는 smbmount를 지원 하지 않으므로 다른 방식 사용
작성 : 20070804 by 임헌정
참고 : 네이버 카페 [낙시군의 이야기]
http://www,4ellene.net
진리의 putty가 한글에서 많은 삽질을 했다.
(그나마 이전 버전엔 관련 버그도 있었나보네)
그래서 캐릭터셋 바꾸고 어쩌고 해서 putty에서 한글이 되도록 했는데
이럴 땐 또 실제 터미널 갔을 때 한글이 안될수도...
별 불편없이 대충 써왔는데,
다른 설정 바꾸지 않고 클라이언트만 바꿔서 해결하는 방법이 있다!!
http://kldp.net/frs/?group_id=335
한글 Putty 프로젝트.. 일부러 오리지널 영문만 썼는데 이런데 쓰라고 만들고 있었군-_-
옵션에서 창-변환 에서 수신한 데이터를 이 문자셋으로 가정 에서 유니코드로 한다.
혹은 접속한 창의 왼쪽상단을 클릭하면 "유니코드로 전환"을 해도 되겠다.
하지만 이건 매번 해야하니..
페도라 코어10을 까니 기본으로 ko_KR.UTF-8 이다. 이거 안바꾸고 푸티만 바꿔서 해결하는거다.
끝
http://www.redhat.com/magazine/008jun05/features/schedulers/
술 퍼먹고 정신 맹한 다음날 유유자적하게 지식 검색들...
SSD에 좋다는 MFT 라는 것도 알게 되고...
므흣한 지식의 습득!