양쪽 이전 판 이전 판 다음 판 | 이전 판 |
linuxfromscratch:12.1:036-gcc-13.2.0_-_pass_1 [2024/06/11 11:54] – 바깥 편집 127.0.0.1 | linuxfromscratch:12.1:036-gcc-13.2.0_-_pass_1 [2024/06/16 23:00] (현재) – [5.3.1. Cross GCC 설치] baecy |
---|
<WRAP info round center 90%> | <WRAP info round center 90%> |
**참고** \\ | **참고** \\ |
이 장에 대해 자주 오해하는 경우가 있습니다. 절차는 앞서 설명한 대로 다른 모든 챕터와 동일합니다([[.:033-general_compilation_instructions|패키지 빌드 지침]]). 먼저 소스 디렉토리에서 gcc-13.2.0 tarball을 추출한 다음 생성한 디렉토리로 변경합니다. 그런 다음 아래 지침을 진행해야 합니다. | 이 장에 대해 자주 오해하는 경우가 있습니다. 절차는 앞서 설명한 대로 다른 모든 챕터와 동일합니다([[.:033-general_compilation_instructions|기본적인 컴파일 과정]]). 먼저 소스 디렉토리에서 gcc-13.2.0 tarball을 추출한 다음 생성한 디렉토리로 변경합니다. 그런 다음 아래 지침을 진행해야 합니다. |
</WRAP> | </WRAP> |
| |
</code> | </code> |
| |
x86_64 호스트에서는 64비트 라이브러리의 기본 디렉터리 이름을 "lib"로 설정합니다. | x86_64 호스트에서는 64비트 라이브러리의 기본 디렉터리 이름을 "lib"로 사용하도록 설정합니다. |
| |
<code bash> | <code bash> |
</code> | </code> |
| |
GCC 문서에서는 전용 빌드 디렉터리에 GCC를 빌드할 것을 권장합니다. | GCC 문서에서는 별도의 디렉터리에 GCC를 빌드할 것을 권장합니다. |
| |
<code bash> | <code bash> |
</code> | </code> |
| |
=== 설정 옵션 설명 === | === configure 옵션 설명 === |
| |
* //**--with-glibc-version=2.39**// \\ 대상에서 사용할 Glibc 버전을 지정합니다. GCC 1차로 컴파일된 모든 것이 호스트 배포판의 libc와 분리된 루트 환경에서 실행되므로 호스트 배포판의 libc와는 관련이 없습니다. | * //**--with-glibc-version=2.39**// \\ 대상에서 사용할 Glibc 버전을 지정합니다. GCC 1차로 컴파일된 모든 것이 호스트 배포판의 libc와 분리된 //chroot// 환경에서 실행되므로 호스트 배포판의 libc 버전과는 관련이 없습니다. |
* //**--with-newlib**// \\ 아직 작동하는 C 라이브러리를 사용할 수 없으므로 libgcc를 빌드할 때 inhibit_libc 상수가 정의되도록 합니다. 이렇게 하면 libc 지원이 필요한 모든 코드의 컴파일이 방지됩니다. | * //**--with-newlib**// \\ 아직 작동하는 C 라이브러리를 사용할 수 없으므로 libgcc를 빌드할 때 inhibit_libc 상수가 정의되도록 합니다. 이렇게 하면 libc 지원이 필요한 모든 코드의 컴파일이 방지됩니다. |
* //**--without-headers**// \\ 완전한 크로스 컴파일러를 만들 때 GCC는 대상 시스템과 호환되는 표준 헤더가 필요합니다. 우리의 목적상 이러한 헤더는 필요하지 않습니다. 이 스위치는 GCC가 이러한 헤더를 찾지 않도록 합니다. | * //**--without-headers**// \\ 완전한 크로스 컴파일러를 만들 때 GCC는 대상 시스템과 호환되는 표준 헤더가 필요합니다. 우리의 목적상 이러한 헤더는 필요하지 않습니다. 이 스위치는 GCC가 이러한 헤더를 찾지 않도록 합니다. |
* //**--disable-shared**// \\ GCC가 내부 라이브러리를 정적으로 연결하도록 합니다. 공유 라이브러리에는 대상 시스템에 아직 설치되지 않은 Glibc가 필요하기 때문에 이 기능이 필요합니다. | * //**--disable-shared**// \\ GCC가 내부 라이브러리를 정적으로 연결하도록 합니다. 공유 라이브러리에는 대상 시스템에 아직 설치되지 않은 Glibc가 필요하기 때문에 이 기능이 필요합니다. |
* //**--disable-multilib**// \\ x86_64에서 LFS는 멀티라이브 구성을 지원하지 않습니다. 이 스위치는 x86에는 무해합니다. | * //**--disable-multilib**// \\ x86_64에서 LFS는 멀티라이브 구성을 지원하지 않습니다. 이 스위치는 x86에는 무해합니다. |
* //**--disable-threads**//, //**--disable-libatomic**//, //**--disable-libgomp**//, //**--disable-libquadmath**//, //**--disable-libssp**//, //**--disable-libvtv**//, //**--disable-libstdcxx**// \\ 각각 스레딩, libatomic, libgomp, libquadmath, libssp, libvtv 및 C++ 표준 라이브러리에 대한 지원을 비활성화합니다. 이러한 기능은 크로스 컴파일러를 빌드할 때 컴파일에 실패할 수 있으며 임시 libc를 크로스 컴파일하는 작업에는 필요하지 않습니다. | * //**--disable-threads**//, //**--disable-libatomic**//, //**--disable-libgomp**//, //**--disable-libquadmath**//, //**--disable-libssp**//, //**--disable-libvtv**//, //**--disable-libstdcxx**// \\ 각각 threading, libatomic, libgomp, libquadmath, libssp, libvtv 및 C++ 표준 라이브러리에 대한 지원을 비활성화합니다. 이러한 기능은 크로스 컴파일러를 빌드할 때 컴파일에 실패할 수 있으며 임시 libc를 크로스 컴파일하는 작업에는 필요하지 않습니다. |
* //**--enable-languages=c,c++**// \\ 이 옵션은 C와 C++ 컴파일러만 빌드하도록 합니다. 현재 필요한 언어는 이 두 가지뿐입니다. | * //**--enable-languages=c,c++**// \\ 이 옵션은 C와 C++ 컴파일러만 빌드하도록 합니다. 현재 필요한 언어는 이 두 가지뿐입니다. |
| |
</code> | </code> |
| |
이 GCC 빌드는 몇 가지 내부 시스템 헤더를 설치했습니다. 일반적으로 그 중 하나인 ''limits.h''에는 해당 시스템 ''limits.h'' 헤더(이 경우 ''$LFS/usr/include/limits.h'')가 포함됩니다. 그러나 이 GCC 빌드 시점에는 ''$LFS/usr/include/limits.h''가 존재하지 않으므로 방금 설치한 내부 헤더는 부분적인 독립 파일이며 시스템 헤더의 확장 기능을 포함하지 않습니다. 이 정도면 Glibc를 빌드하는 데 충분하지만 나중에 전체 내부 헤더가 필요합니다. 일반적인 상황에서 GCC 빌드 시스템이 수행하는 것과 동일한 명령을 사용하여 내부 헤더의 전체 버전을 생성하세요. | 이 GCC 빌드는 몇 가지 내부 시스템 헤더를 설치했습니다. 일반적으로 그 중 하나인 ''limits.h''에는 해당 시스템 ''limits.h'' 헤더(이 경우 ''$LFS/usr/include/limits.h'')가 포함됩니다. 그러나 이 GCC 빌드 시점에는 ''$LFS/usr/include/limits.h''가 존재하지 않으므로 방금 설치한 내부 헤더는 부분적인 파일이며 시스템 헤더의 확장 기능을 포함하지 않습니다. 이 정도면 Glibc를 빌드하는 데 충분하지만 나중에 전체 내부 헤더가 필요합니다. 일반적인 상황에서 GCC 빌드 시스템이 수행하는 것과 동일한 명령을 사용하여 내부 헤더의 전체 버전을 생성합니다. |
| |
<WRAP info round center 90%> | <WRAP info round center 90%> |
**참고** \\ | **참고** \\ |
아래 명령은 역따옴표와 $() 구문이라는 두 가지 방법을 사용한 중첩 명령 대체의 예를 보여줍니다. 두 대체 방법에 대해 동일한 방법을 사용하여 다시 작성할 수도 있지만, 두 가지 방법을 혼합하여 사용할 수 있음을 보여주기 위해 이러한 방식으로 표시했습니다. 일반적으로 $() 방법을 선호합니다. | 아래 명령은 ''역따옴표''와 ''$()'' 구문, 두 가지 방법을 사용하여 중첩 명령 대체의 예를 보여줍니다. 두 대체 방법에 대해 동일한 방법을 사용하여 작성할 수도 있지만, 두 가지 방법을 혼합하여 사용할 수 있음을 보여주기 위해 이러한 방식으로 표시했습니다. 일반적으로 ''$()'' 방법을 선호합니다. |
</WRAP> | </WRAP> |
| |
----- | ----- |
| |
이 패키지의 상세한 내용은 [[.:098-gcc-13.2.0|8.28.2 "GCC의 구성"]]에 있습니다. | 이 패키지의 상세한 내용은 [[.:098-gcc-13.2.0#8.28.2 GCC 패키지 구성|8.28.2. "GCC 패키지 구성"]]에 있습니다. |