> 백엔드 개발 > C++ > C 링커는 연결 프로세스 중에 주소 재배치를 어떻게 처리합니까?

C 링커는 연결 프로세스 중에 주소 재배치를 어떻게 처리합니까?

Patricia Arquette
풀어 주다: 2024-12-06 10:25:12
원래의
715명이 탐색했습니다.

How Does the C   Linker Handle Address Relocation During the Linking Process?

C 링크는 실제로 어떻게 작동하나요?

C 링크에는 여러 개체 파일(.o 파일)을 결합하여 실행 파일이나 공유 라이브러리를 만드는 작업이 포함됩니다. 이 프로세스에는 주소 재배치 및 기호 확인을 포함한 다양한 단계가 포함됩니다.

주소 재배치

연결의 중요한 기능 중 하나는 _주소 재배치_입니다. 컴파일러는 각 소스 파일을 개체 파일로 컴파일할 때 다른 소스 파일에 정의된 기호(함수, 변수 등)에 대한 참조가 포함된 코드를 생성합니다. 그러나 모든 개체 파일이 함께 링크될 때까지는 이러한 기호의 최종 주소를 알 수 없습니다.

링크하는 동안 링커는 개체 파일의 재배치 섹션을 읽습니다. 이러한 섹션에는 올바른 기호 위치를 가리키도록 .text 및 .data 섹션에서 수정해야 하는 주소에 대한 정보가 포함되어 있습니다. 그런 다음 링커는 기호의 최종 위치에 따라 이러한 주소를 조정합니다.

주소 재배치를 설명하려면 다음 예를 고려하세요.

; object file hello_world.o
.data
hello_world db "Hello world!", 10
.text
.global _start
_start:
    mov rax, 1 ; sys_write
    mov rdi, 1 ; stdout
    mov rsi, hello_world ; placeholder for string address
    mov rdx, 13 ; number of characters to write
    syscall
로그인 후 복사

이 .o 파일이 컴파일되면 컴파일러는 자리 표시자 값(예: 0)을 삽입합니다. "Hello world!" 주소로 끈. 링커는 이 파일의 .rela.text 섹션을 읽습니다.

Offset          Info           Type           Sym. Value    Sym. Name + Addend
00000000000c  000200000001 R_X86_64_64       0000000000000000 .data + 0
로그인 후 복사

이 항목은 링커에게 오프셋 0x0c(mov rsi, hello_world 명령어 내부)에서 64비트 값을 수정해야 함을 알려줍니다. .data 섹션을 가리킵니다.

링커는 모든 개체 파일을 결합할 때 오프셋의 값을 조정합니다. 0x0c는 최종 실행 파일에서 문자열의 올바른 주소를 가리킵니다.

위 내용은 C 링커는 연결 프로세스 중에 주소 재배치를 어떻게 처리합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿