Start_Kernel (Week 2)
Start_Kernel (Week 2)

Start_Kernel (Week 2)

카테고리
⚙️ Start Kernel
작성자
박용성박용성
작성일
2024년 06월 02일
태그
C
Linux
Slug
start-kernel-1

주제

💡
리눅스 부팅 과정 (start_kernel함수 호출 전까지의 과정)
 
공부한 것

start_kernel 호출 전까지의 리눅스 부팅 과정

1. 전원 공급

  1. 전원이 들어오면 CPUROM 에 저장된 BIOS (기본 입출력 시스템) 를 불러온다. 바이오스는 전원 공급과 함께 메모리의 특정 번지에 자동 로드된다.
    1. 💡
      초기 부팅시에는 전체 메모리의 1MB 영역까지만 접근이 된다. 이 때는 protection이나 privilege는 의미가 없다.
      notion image
  1. 바이오스가 로드되면 컴퓨터는 POST (Power-On Self Test) 테스트 후 장치들을 초기화하고, 부팅이 가능한 장치를 탐색한다. (보통 지정된 부트 드라이브로 진입한다.)
    1. Post의 과정은 다음과 같이 흘러간다.
      1. CPU TEST
      2. 기본 컨트롤러 초기화
      3. 키보드 초기화
      4. ROM BIOS 초기화
      5. CMOS RAM 테스트
      6. 메모리 테스트
      7. 캐시 초기화
      8. 인터럽트 벡터 테이블 초기화, 설치
      9. CMOS RAM CHECKSUM 테스트 (중복 검사의 한 종류. 오류 정정을 통해 송신된 자료의 무결성 보호)
 

2. 부트로더 호출

  1. 부팅이 가능한 장치에서 MBR (Master Boot Record) 를 찾는다. 보통 MBR 은 디스크의 첫 번째 섹터에 위치하며, 부트로더가 저장되어 있다.
    1. notion image
      • Boot Code 부팅 가능한 파티션을 찾아 해당 파티션의 부트 섹터를 호출
      • Partition Table 파티션의 정보가 포함되어 있음, 총 4개
      • Signature 섹터의 오류 유무를 확인
  1. 리눅스의 GRUB 은 Windows의 active partition 으로 처리되지 않고, 다음과 같은 순서를 따른다.
    1. MBR 자체에 bootloader 을 내장하고 있다. (GRUB 에서는 stage 1)
    2. MBR의 크기는 작기 때문에, 추가 부트스트랩 코드가 포함된 디스크에서 코드를 로드한다.
      1. 부트스트랩 : 매우 간단하고 작은 코드, 부팅 가능한 장치로부터 부트로더를 로드하고 실행하는 역할
    3. 로드한 부트스트랩 코드와 MBR의 부트 코드가 부트 로더의 두 번째 단계가 포함된 파일을 읽는다. (GRUB 에서는 stage 2)
      1. 이 두 번째 단계 코드는 부팅 구성 파일 (GRUBgrub.conf )을 읽어온다.
    4. 부트 로더 코드는 이제 커널 이미지를 로딩한다. 이를 위해 파일 시스템에 대한 정보를 갖고 있어야 하므로, Linux에서는 vmlinuz-x.x.x-version 과 같은 바이너리를 디스크로부터 읽어온다.
 

3. 부트로더(GRUB)로 커널 이미지 로딩

  1. 커널 이미지는 결국 부트로더에서 BIOS disk I/O Service 를 이용해 메모리로 로딩된다.
    1. /boot/vmlinux-x.x.x-version 과 비슷한 이미지를 디스크에서 읽어와 복사본으로 올린다.
  1. arch/x86/boot/compressed/head_32.S 를 호출해서 startup_32 함수를 실행합니다.
    1. /* * These symbols needed to be marked as .hidden to prevent the BFD linker from * generating R_386_32 (rather than R_386_RELATIVE) relocations for them when * the 32-bit compressed kernel is linked as PIE. This is no longer necessary, * but it doesn't hurt to keep them .hidden. */ .hidden _bss .hidden _ebss .hidden _end __HEAD SYM_FUNC_START(startup_32) cld cli
     
     
     
     
     
     
    이전 리눅스 버전?
    💡
    여기서부턴 예전 리눅스 버전..?
    1. arch/i386/boot/setup.S 에서 커널 이미지가 호출되어, start() 함수가 실행된다.
      1. → 기본적인 하드웨어 수정 작업을 거친다.
        arch/i386/boot/compressed/head.Sstartup_32() 함수 호출
    1. startup_32() 함수는 스택 설정, BSS(Block Started by Symbol 을 초기화
      1. arch/i386/boot/compressed/misc.c 내의 decompress_kernel() 함수를 호출해 압축된 커널을 해제
        arch/x86/kernel/head_32.S 에 위치하는듯 함
    1. startup_32() 함수의 기능
        • 하드웨어의 종속적인 초기화
            1. 세그먼트 값들 설정
            1. 페이지 테이블 초기화
            1. IDT 설정
            1. CPU 유형 검사, FPU 검사
            1. GDT와 IDT 로딩
            1. start_kernel() 호출
     
     
     
     

    // arch/alpha/boot/bootp.c /* * Start the kernel. */ static inline void runkernel(void) { __asm__ __volatile__( "bis %0,%0,$27\n\t" "jmp ($27)" : /* no outputs: it doesn't even return */ : "r" (START_ADDR)); } extern char _end; #define KERNEL_ORIGIN \ ((((unsigned long)&_end) + 511) & ~511)
    notion image

    참고 문헌



     
    예전 레거시, 요즘은 UEFI 바이오스
     
    왜 커널을 압축했을까? (커널을 빌드할때 압축됨)
    → 압축 안하면 꽤큼, 그래서 메모리에 올릴 수 있게됨
    KERNEL-IMAGE-SIZE : 1GB
    압축을 했을때 1GB?
     
    /arch/x86/include/asm/page_64_types.h
     

    참고 문헌

    컴퓨터 초급코스1 : #13 컴퓨터의 부팅 과정.
    컴퓨터 초급코스1 : #13 컴퓨터의 부팅 과정. 컴퓨터는 준비 되었겠죠? 이제 컴퓨터를 사용하기 위해서 컴퓨터의 전원 버튼을 눌러 봅시다. 컴퓨터는 왜 TV처럼 빠르게 시작되지 않을까요? 과연 컴퓨터 속에서는 어떤 일들이 벌어지고 있는 걸까요? 한 번 들여다 볼까요? 아래 편을 안보신 분들은 먼저 보세요~ - '하드웨어, 소프트웨어 그리고 또 하나' 편 https://youtu.be/RLE0EzS5urA - '펌웨어 = 하드웨어 + 소프트웨어'편 https://youtu.be/NMTN1FZurgI Chapters: 0:00 Intro 00:34 BIOS (Basic Input/Output System) 01:45 POST (Power On Self Test) 02:39 하드 디스크 드라이브 구조 (Track, Partition, Sector) 03:06 파일 시스템 (File System) 03:40 디스크 포맷, 볼륨 (File System, Disk Format, Volume) 04:03 마스터 부트 레코드, 부트 코드 (Master Boot Record, Boot Code) 04:50 볼륨 부트 레코드 (Volume Boot Record) 05:21 부트 로더 (Boot loader) 06:03 BIOS 셋업 유틸리티, CMOS 셋업 (BIOS Setup Utility) 07:28 UEFI (통일 확장 펌웨어 인터페이스) 08:14 GPT (GUID Partition Table) 09:10 운영체제 커널과 셸 (OS, Kernel, Shell) 10:10 서비스, 데몬 (Service, Daemon) 10:45 시작 프로그램 (start-up program) 11:12 프로세스, 멀티태스크 (Process, Multitask) 11:47 마무리 @background Knowledge (백그라운드 날리지) 이미지 출처 (thanks!) 👍 : 'Award-BIOS의 셋업 유틸리티 화면' Photo by Kephir (public domain) https://commons.wikimedia.org/wiki/File:Award_BIOS_setup_utility.png 'AMI-BIOS의 셋업 유틸리티 화면' Photo by HombreDHojalata (CC BY-SA 3.0 es) https://commons.wikimedia.org/wiki/File:MEDION_AKOYA_E1210.JPG 'Award-BIOS의 부팅 장치 순서 설정 화면' Photo by Toniperis (CC BY-SA 3.0) https://commons.wikimedia.org/wiki/File:Award_BIOS_setup_utility.png 'Award-BIOS의 장치/기능 설정 화면' Photo by Toniperis (CC BY-SA 3.0) https://commons.wikimedia.org/wiki/File:Bios-configuracion-smart-habilitada.png 'Mainboard의 BIOS Chip과 CMOS Battery' Photo by Rotatebot (CC BY-SA 3.0) https://commons.wikimedia.org/wiki/File:MSI_865PE_Neo2-P_motherboard.jpg 'UEFI가 저장된 Winbond BIOS 칩' Photo by Mixabest (CC BY-SA 3.0) https://commons.wikimedia.org/wiki/File:BIOS@ASUS_P8H67.JPG 'UEFI BIOS의 셋업 유틸리티 화면' Photo by Beñat Arkarazo (CC BY-SA 4.0) https://commons.wikimedia.org/wiki/File:Bios_asus.jpg '리눅스 셸, 그래픽 인터페이스 (Linux Shell, X Window)' Photo by KDE (GPL) https://commons.wikimedia.org/wiki/File:KDE_Plasma_5.16.png '리눅스 셸, 명령줄 인터페이스 (Linux Shell, Bash)' Photo by Emx (GPL) https://commons.wikimedia.org/wiki/File:Bash_screenshot.png '윈도우즈의 프로세스들 (Windows, processes)' Photo by Microsoft (Fair use) https://en.wikipedia.org/wiki/File:Windows_Task_Manager_screenshot.png pexels (https://www.pexels.com/) 에서 멋진 사진을 제공해준 분들😘 Ali Pazani, cottonbro studio, Brett Sayles 사이트에서 이름으로 검색하여 이분들이 올린 멋진 사진들을 감상해 보세요. #부팅 #MBR #GPT #컴퓨터 #초급 #기본개념
    컴퓨터 초급코스1 : #13 컴퓨터의 부팅 과정.

    댓글

    guest