Lx4U-book/docs/build-system/gcc.md
2021-07-06 13:02:59 +03:00

7.5 KiB
Raw Blame History

Подготовка

Примените патч, исправляющий несколько проблем:

Исправьте пути установки библиотек:

Настройка

?> На данном этапе необходимы только компиляторы для C и C++, однако вы можете собрать компиляторы для любых поддерживаемых GCC языков программирования, перечислив их через запятые в опции configure --enable-languages=c,c++. GCC поддерживает следующие языки - c,c++,d,fortran,go,objc,obj-c++. вы можете собрать все доступные компиляторы, добавив параметр --enable-languages=c,c++,d,fortran,go,objc,obj-c++. Если позднее вам потребуется компилятор для какого либо языка из этого списка - пересоберите GCC с его поддержкой.

Для multilib

Значения параметров

--disable-bootstrap - Предотвращает многократную пересборку GCC

LD=ld - Сообщает GCC использовать ранее установленную версию компоновщика

Сборка

Тестирование

  • Увеличьте размер стека по умолчанию
  • Произведите тестирование от непривилегированного пользователя во избежание непредвиденных ситуаций с системой.

Тестирование занимает достаточно много времени.

Для просмотра итогов теста выполните:

../contrib/test_summary

?> Известно, что 6 тестов, связанных с get_time, дают сбои. По видимому, это связано с локалью en_HK. Кроме того, тест COSTEXPR-52830 не удается.

Установка

  • Удалите ненужную директорию,
  • Убедитесь, что владелец установленных заголовков корректный,
  • По историческим причинам некоторые программы могут пытаться найти cpp в директории /lib. Создайте ссылку,
  • Для поддержки LTO требуется следующая символическая ссылка,
  • Переместите файлы в правильное место:

Проверка работоспособности

Выполните набор команд:

echo 'int main(){}' > dummy.c
cc dummy.c -v -Wl,--verbose &> dummy.log
readelf -l a.out | grep ': /lib'

Ошибок быть не должно, а результат команды (учитывая различия в имени динамического компоновщика, зависящие от платформы) будет следующий:

Requesting program interpreter: /lib64/ld-linux-x86-64.so.2]

Проверим что задействованы правильные стартовые файлы. Выполните команду:

grep -o '/usr/lib.*/crt[1in].*succeeded' dummy.log

Результат выполнения:

/usr/lib/gcc/x86_64-pc-linux-gnu/11.1.0/../../../../lib/crt1.o succeeded
/usr/lib/gcc/x86_64-pc-linux-gnu/11.1.0/../../../../lib/crti.o succeeded
/usr/lib/gcc/x86_64-pc-linux-gnu/11.1.0/../../../../lib/crtn.o succeeded

В зависимости от архитектуры, приведенное выше может немного отличаться. Разница будет в названии каталога после /usr/lib/gcc. Здесь важно обратить внимание на то, что gcc обнаружил все три файла crt * .o в каталоге /usr/lib.

Проверим то, что компилятор выполняет поиск корректных заголовочных файлов:

grep -B4 '^ /usr/include' dummy.log

Результат выполнения:

#include <...> search starts here:
 /usr/lib/gcc/x86_64-pc-linux-gnu/11.1.0/include
 /usr/local/include
 /usr/lib/gcc/x86_64-pc-linux-gnu/11.1.0/include-fixed

Проверим, что компоновщик использует корректные пути поиска:

grep 'SEARCH.*/usr/lib' dummy.log |sed 's|; |\n|g'

Результат выполнения:

SEARCH_DIR("/usr/x86_64-pc-linux-gnu/lib64")
SEARCH_DIR("/usr/local/lib64")
SEARCH_DIR("/lib64")
SEARCH_DIR("/usr/lib64")
SEARCH_DIR("/usr/x86_64-pc-linux-gnu/lib")
SEARCH_DIR("/usr/local/lib")
SEARCH_DIR("/lib")
SEARCH_DIR("/usr/lib");

Проверим, что используется корректная стандартная библиотека

grep "/lib.*/libc.so.6 " dummy.log

Результат выполнения:

attempt to open /usr/lib/libc.so.6 succeeded

Проверим, что используется корректный динамический компоновщик:

grep "found ld-linux*" dummy.log

Результат выполнения должен быть (учитывая различия в имени динамического компоновщика, зависящие от платформы):

found ld-linux-x86-64.so.2 at /usr/lib/ld-linux-x86-64.so.2

!> Если вывод не соответствует вышеуказанному, или вообще не получен, значит, что-то не так. Изучите и повторите шаги, чтобы выяснить, в чем проблема. Перед продолжением процесса необходимо решить любые проблемы.

Удалите тестовые файлы:

rm -v dummy.c a.out dummy.log

Установленные файлы

Программы: c++ (ссылка на g++), cc (ссылка на gcc), cpp, g++, gcc, gcc-ar, gcc-nm, gcc-ranlib, gcov, gcov-dump и gcov-tool

Библиотеки: libasan.{a,so}, libatomic.{a,so}, libcc1.so, libgcc.a, libgcc_eh.a, libgcc_s.so, libgcov.a, libgomp.{a,so}, libitm.{a,so}, liblsan.{a,so}, liblto_plugin.so, libquadmath.{a,so}, libssp.{a,so}, libssp_nonshared.a, libstdc++.{a,so}, libstdc++fs.a, libsupc++.a, libtsan.{a,so} и libubsan.{a,so}

Директории: /usr/include/c++, /usr/lib/gcc, /usr/libexec/gcc и /usr/share/gcc-11.1.0