После нескольких часов поисков я решил сдаться и спросить у вас экспертов. Я пытаюсь создать 32-разрядное приложение (xgap, если кто-то заинтересован) в моей 64-й версии Ubuntu 11.10. Я добавил CFLAGS = -m32 и LDFLAGS = -L / usr / lib32 в make-файл. Объекты встроены в 32-битный штраф. Последний шаг - связать все объекты и библиотеки для X windows с этим исполняемым файлом --- xgap. Каким-то образом это продолжает давать мне эту ошибку:
gcc -o xgap xcmds.o utils.o gapgraph.o gaptext.o pty.o popdial.o xgap.o selfile.o -L/usr/lib32 -lXaw -lXmu -lXt -lXext -lX11 -lSM -lICE
/usr/bin/ld: skipping incompatible /usr/lib32/libXmu.so when searching for -lXmu
...
/usr/bin/ld: i386 architecture of input file `xcmds.o' is incompatible with i386:x86-64 output
...
Я установил поддержку ia32-libs и mutilib . Я думаю, что мне просто нужно заставить компоновщик генерировать вывод i386. Я попытался поместить два флага ld в мою команду gcc, как показано выше: -melf_i386 и -oformat elf32-i386 . Но происходит то, что gcc больше не ищет 32-битную библиотеку в / usr / lib32 . Интересно, нужно ли мне поставить эти флаги в каком-то фиксированном порядке?
Спасибо за любую идею и помощь!
РЕДАКТИРОВАТЬ: когда я добавляю флаг -m32 в моей последней команде gcc (я считаю, что это этап связывания), даже если у меня установлен флаг -L / usr / lib32, gcc больше не выполняет поиск в / usr / lib32 (на самом деле странно ...) и генерирует следующую ошибку:
/usr/bin/ld: skipping incompatible /usr/lib/gcc/x86_64-linux-gnu/4.6.1/../../../libXaw.so when searching for -lXaw
/usr/bin/ld: skipping incompatible /usr/lib/libXaw.so when searching for -lXaw
/usr/bin/ld: cannot find -lXaw
collect2: ld returned 1 exit status
Кто-нибудь знает, почему это происходит? Я использую автоматический инструмент для настройки и создания. Я действительно хорош в модификации этих файлов скриптов.
ЭЙДТ : Я решил проблему. Я думаю, что gcc ожидал архив статической библиотеки. Я использовал скрипт getlibs с http://ubuntuforums.org/showthread.php?t=474790, чтобы загрузить все архивы .a, необходимые для компоновки. Затем GCC работал. Я думаю, что gcc выполнил поиск в каталоге / usr / lib32, но не нашел архивы .a, поэтому продолжил поиск в стандартном каталоге / usr / lib , где он находит несовместимые файлы * .so .
Но тогда возникает вопрос: файлы * .so в / usr / lib32 / из пакета ia32-libs на самом деле не имеют библиотек, необходимых для компоновки? Для чего используются эти файлы в / usr / lib32 / ?
Ответы:
LDFLAGS
должен включать-m32
в себя также. Следующее должно работать:Фактически, вы можете удалить
-L/usr/lib32
часть, так как это каталог по умолчанию для 32-битных библиотек, и ваша система знает об этом.По сути, самый простой способ построить 32-битное приложение на 64-битной машине:
..или эти переменные для настройки скрипта, если вы используете автоинструменты.
ОБНОВИТЬ:
Похоже, вы не очень знакомы с различиями в связывании со статическими и динамическими библиотеками. Я постараюсь быть как можно меньше:
.a
libname.a
для динамической, так иlibname_s.a
для статической версии..so
библиотеку времени выполнения, которая должна присутствовать в вашей системе.Обратите внимание, что здесь мы не говорим о дополнительных хитростях, таких как явная загрузка DSO с использованием API dlopen () / dlsym ().
источник
-l/usr/lib32/libXaw.so
вместо этого кормить ?Я получал ошибки, такие как:
Это исправило это для меня:
если вы используете пакет gcc, отличный от пакета по умолчанию (например
gcc-7
), то вам необходимо установить пакет для этой конкретной версии:источник
g++-multilib
для g ++ (C ++), для gcc (C) вам также нужноgcc-multilib
.