임베디드 리눅스 시스템에서 커널이 장치에서 실행되기 전에 실행되는 단계들을 알아보자.
1) ROM
2) SPL
3) TPL
4) Linux Kernel
부팅 순서. 1 단계 : ROM 코드
ROM 코드는 사전 프로그래밍 된 여러 위치 중 하나에서 SRAM으로 작은 부트코드를 로드한다.
예를 들면 NAND 플래시 메모리, SPI (Serial Peripheral Interface)를 통해 연결된 플래시 메모리, MMC 장치의 첫 번째 섹터 (SD 카드) 등에서 SPL을 읽는다.
부팅 순서. 2 단계 : SPL(Secondary Program Loader)
일반적으로 SRAM이 U-Boot와 같은 전체 부트로더를 로드하기에 충분히 크지 않기 때문에 보조 프로그램 로더 (SPL)가 있어야한다.
SPL은 TPL을 주 메모리 (DRAM)에 로드하도록 메모리 컨트롤러 및 시스템의 기타 필수 부분의 초기화를 수행한다.
그 다음 플래시 장치의 시작 부분에서 사전 프로그래밍 된 오프셋 또는 u-boot.bin 등과 같은 알려진 파일 이름을 사용하여 ROM 코드와 마찬가지로 저장 장치 목록에서 프로그램을 주 메모리에 올린다.
부팅 순서. 3 단계 : TPL(Tertiary Program Loader)
U-Boot 또는 Barebox와 같은 전체 부트 로더는 간단한 명령 줄 사용자 인터페이스, 커널 이미지를 네트웍 또는 플래시 저장소에서 로드 및 부팅과 같은 유지 관리 작업을 수행한다. 커널이 실행되면 부트로더는 일반적으로 메모리에서 사라지고 시스템 작동에 더 이상 참여하지 않는다.
부팅 순서. 4 단계 : Kernel
비로소 커널이 실행되고 시스템의 제어권을 갖는다.
ROM 및 SPL 부트 로더는 내부 RAM을 사용하여 실행하는 반면 U-Boot 및 커널은 DDR(각각 0x80000000 및 0x82000000)에서 실행된다.
아래 이미지는 wandboard 용 SD카드에 있는 rootfs의 boot디렉토리 내용이다. SPL, U-Boot를 비롯하여 커널이미지, 디바이스 트리등을 확인 할 수 있다.
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
» |
임베디드 리눅스 부팅 절차
![]() | makersweb | 2019.10.21 | 6309 |
11 |
라즈베리파이3와 PC간 Serial 통신 테스트
[1] ![]() | makersweb | 2019.05.20 | 6418 |
10 | 플랫폼 디바이스 및 드라이버에 대해서 | makersweb | 2020.02.01 | 6591 |
9 |
AVRISP mkII 펌웨어 업그레이드
![]() | makersweb | 2015.07.22 | 6945 |
8 |
USB 핀아웃
![]() | pjk | 2014.10.11 | 8439 |
7 |
이클립스에서 IAR프로젝트 사용방법
![]() | makersweb | 2015.07.09 | 8788 |
6 | ST, STM32 MCU용 ‘통합 개발 환경(IDE)’ 무료 제공 | makersweb | 2015.03.04 | 8867 |
5 |
ESP-IDF 의 A2DP리뷰 (ESP32)
![]() | makersweb | 2019.10.28 | 9559 |
4 | [Uboot 명령어 및 환경 변수 요약]U-Boot에 Command 및 Parameter에 대한 설명 | pjk | 2014.01.09 | 10487 |
3 |
yocto project, 라즈베리파이를 위한 Qt + 임베디드리눅스 빌드
![]() | makersweb | 2019.02.01 | 11067 |
2 |
USB OTG 기술의 개념
![]() | pjk | 2014.11.03 | 15352 |
1 |
윈도우10에서 Prolific USB to Serial 드라이버 인식문제
![]() | makersweb | 2016.01.24 | 22832 |