728x90
반응형
elf32-littlearm.lds 파일 분석.
링커 스크립트는 링커에게 코드배치를 이렇게 하라고 설명하는 파일이다.
링커 스크립트
링커 스트립트는 링커 명령 언어로 쓰여진다.
링커는 항상 링커 스크립트를 사용한다. 직접 제공하지 않으면 링커는 링커 실행파일에 컴파일된 기본 스크립트를 사용한다.
링커 스크립트의 주목적은 입력파일의 섹션이 어떻게 출력파일로 대응하는지와 출력파일의 메모리 상태를 어떻게 조정하는지를 지정하는 것이다. 대부분의 링커 스크립트는 이것으로 충분하다.
링커 스크립트 형식
링커 스크립트는 일련의 명령어로 이루어져 있다. 각 명령어는 키워드로 뒤에 아규먼트를 가지거나, 심볼에 할당될 수 있다. ';'으로 각 명령어를 구분한다. 공백은 일반적으로 무시된다.
파일이나 형식 이름과 같은 문자열은 보통 직접 입력한다. 파일명이 보통 파일명을 구분하는 ',' 같은 문자를 포함한다면 파일명을 쌍따옴표 안에 두어야 한다. 파일명에 쌍따옴표를 사용할 수는 없다.
링커 스크립트는 C와 같이 '/*' 와 '*/'로 둘러싸인 주석을 포함할 수 있다.
/* elf32-littlearm.lds 파일 */
//이 부분은 arm-linux-ld가 만들어 낼 최종 결과 파일의 포맷을 나타낸다.
//즉, little endian 포맷의 파일을 생성할 것인지,
//big endian 포맷의 파일을 생성할 것인지를 결정하는 역할을 한다.
OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
//이 부분은 최종 결과 파일이 동작할 CPU의 architecture를 나타낸다.
//즉, 이 파일은 ARM CPU 상에서 동작한다는 의미이다.
OUTPUT_ARCH(arm)
//최종 결과 파일의 시작 지점을 나타낸다.
//즉, 여기서 파일의 시작 지점은 reset_handler가 된다.
//reset_handler는 Cstartup.s 파일에 정의되어 있다.
ENTRY(reset_handler)
//SECTIONS{ ... }부분은 링커(arm-linux-ld)가 입력 파일들의 섹션들을
//결과 파일의 어떤 섹션들로 위치시킬지를 결정하는 역할을 한다.
SECTIONS
{
.text : { //프로그램의 코드영역
_stext = .; //코드영역의 시작주소를 makefile로 부터 가져온다.
//이 부분은 arm-linux-ld가 만들어 낼 최종 결과 파일의 포맷을 나타낸다.
//즉, little endian 포맷의 파일을 생성할 것인지,
//big endian 포맷의 파일을 생성할 것인지를 결정하는 역할을 한다.
OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
//이 부분은 최종 결과 파일이 동작할 CPU의 architecture를 나타낸다.
//즉, 이 파일은 ARM CPU 상에서 동작한다는 의미이다.
OUTPUT_ARCH(arm)
//최종 결과 파일의 시작 지점을 나타낸다.
//즉, 여기서 파일의 시작 지점은 reset_handler가 된다.
//reset_handler는 Cstartup.s 파일에 정의되어 있다.
ENTRY(reset_handler)
//SECTIONS{ ... }부분은 링커(arm-linux-ld)가 입력 파일들의 섹션들을
//결과 파일의 어떤 섹션들로 위치시킬지를 결정하는 역할을 한다.
SECTIONS
{
.text : { //프로그램의 코드영역
_stext = .; //코드영역의 시작주소를 makefile로 부터 가져온다.
*(.text) //모든 입력 파일들(*)의 .text 섹션을 결과 파일의 .text 섹션에 위치시킨다.
*(.rodata) //readonly 파일들을 .text 섹션에 위치시킨다.
*(.rodata*) //그외 모든 데이터들을 .text 섹션에 위치시킨다.
. = ALIGN(4); //현재의 위치에서 4 바이트 단위로 놓겠다는 의미이다.
// 즉, 4바이트 단위로 메모리를 정렬한다.
_etext = . ; //코드영역의 끝을 현재 위치포인트로 하겠다는 의미이다.
}
//데이터 영역
//코드영역 시작주소부터 코드영역의 크기만큼 더한다음 주소 즉, 코드영역 다음 주소
.data : AT ( ADDR (.text) + SIZEOF (.text) ) {
_sdata = .;
*(.vectors) //모든 입력 파일의 벡터 테이블을 데이터 영역에 포함
*(.data) //모든 입력 파일의 초기화 된 데이터를 데이터 영역에 포함
_edata = .;
}
//bss 영역
//noload = 적재하지 않는다.
.bss (NOLOAD) : {
. = ALIGN(4);
_sbss = .;
*(.bss) //모든 입력 파일의 bss영역을 출력파일의 bss영역에 포함한다.
_ebss = .;
}
}
end = .;
*(.rodata) //readonly 파일들을 .text 섹션에 위치시킨다.
*(.rodata*) //그외 모든 데이터들을 .text 섹션에 위치시킨다.
. = ALIGN(4); //현재의 위치에서 4 바이트 단위로 놓겠다는 의미이다.
// 즉, 4바이트 단위로 메모리를 정렬한다.
_etext = . ; //코드영역의 끝을 현재 위치포인트로 하겠다는 의미이다.
}
//데이터 영역
//코드영역 시작주소부터 코드영역의 크기만큼 더한다음 주소 즉, 코드영역 다음 주소
.data : AT ( ADDR (.text) + SIZEOF (.text) ) {
_sdata = .;
*(.vectors) //모든 입력 파일의 벡터 테이블을 데이터 영역에 포함
*(.data) //모든 입력 파일의 초기화 된 데이터를 데이터 영역에 포함
_edata = .;
}
//bss 영역
//noload = 적재하지 않는다.
.bss (NOLOAD) : {
. = ALIGN(4);
_sbss = .;
*(.bss) //모든 입력 파일의 bss영역을 출력파일의 bss영역에 포함한다.
_ebss = .;
}
}
end = .;
728x90
'코스웨어 > 10년 스마트폰BSP' 카테고리의 다른 글
막바지에 고생들이 많으시네요. (2) | 2010.11.06 |
---|---|
안드로이드 1초안에 부팅완료, Quickboot (2) | 2010.10.09 |
초보자를 위한 임베디드 리눅스 학습 가이드 (1) | 2010.10.08 |
데브피아 Ver.IT 떡실신 시리즈 (19) | 2010.10.05 |
[BSP]업무일지-서동준-20101004 (0) | 2010.10.04 |
리눅스 커널 프로그래밍 - 커널 내부 제어 방법 (Micro software 2006.7) by.국중진 (2) | 2010.10.04 |
[BSP]업무일지-김상식-20101002 (0) | 2010.10.04 |
[BSP]20100930-임종현 (0) | 2010.09.30 |