mingw libtool gcc не разрешает ссылки в других библиотеках
Не мой код (AGAR GUI), но он компилируется нормально в Linux.
Теперь, когда я пытаюсь собрать его в mingw64 (Win), я получаю эту ошибку при сборке одной из библиотек (libag_gui.la):
.libs/**drv_sdl2.o**:drv_sdl2.c:(.rdata$.refptr.agCondEndRender[.refptr.agCondEndRender]+0x0): undefined reference to `agCondEndRender'
agCondEndRender существует в другой библиотеке с именем ag_core, которая содержит файл time_renderer.c (.o,,.lo), где он определен.
Эта библиотека построена так:
../mk/libtool/libtool --quiet --mode=link gcc -o **libag_core.la** -no-undefined -Wl,--no-undefined -XCClinker -static-libgcc -rpath /c/msys64/mingw64/lib -version-info 5:0:0
time_win32.lo time_posix.lo **time_renderer.lo** net.lo net_dummy.lo user_win32.lo variable.lo config.lo core.lo error.lo event.lo object.lo prop.lo timeout.lo class.lo cpuinfo.lo data_source.lo load_string.lo load_version.lo vsnprintf.lo vasprintf.lo asprintf.lo dir.lo md5.lo sha1.lo rmd160.lo file.lo string.lo dso.lo tree.lo time.lo time_dummy.lo db.lo tbl.lo getopt.lo exec.lo text.lo user.lo user_dummy.lo -lpthread -lwinmm
И эта библиотека (ag_core) используется для построения библиотеки задач следующим образом:
../mk/libtool/libtool --quiet --mode=link gcc -o **libag_gui.la** -no-undefined -Wl,--no-undefined -XCClinker -static-libgcc -rpath /c/msys64/mingw64/lib -version-info 5:0:0
drv_sdl2_common.lo **drv_sdl2.lo** drv_gl_common.lo drv_wgl.lo drv.lo drv_sw.lo drv_mw.lo gui.lo widget.lo window.lo iconmgr.lo geometry.lo colors.lo cursors.lo ttf.lo text.lo keymap.lo keymap_latin1.lo keymap_compose.lo keysyms.lo editable.lo box.lo label.lo button.lo checkbox.lo textbox.lo radio.lo fixed_plotter.lo tlist.lo scrollbar.lo spinbutton.lo titlebar.lo toolbar.lo fspinbutton.lo combo.lo ucombo.lo units.lo nlunits.lo hsvpal.lo mspinbutton.lo mfspinbutton.lo statusbar.lo menu.lo menu_view.lo treetbl.lo separator.lo notebook.lo pixmap.lo file_dlg.lo objsel.lo fixed.lo numerical.lo table.lo glview.lo mpane.lo pane.lo console.lo graph.lo socket.lo icon.lo progress_bar.lo slider.lo text_cache.lo load_surface.lo load_color.lo load_xcf.lo file_selector.lo scrollview.lo font_selector.lo time_sdl.lo debugger.lo surface.lo widget_legacy.lo global_keys.lo input_device.lo mouse.lo keyboard.lo packedpixel.lo load_bmp.lo load_jpg.lo load_png.lo dir_dlg.lo anim.lo stylesheet.lo **-L../core -lag_core** -L/mingw64/lib -lSDL2 -LC:/msys64/mingw64/lib -lfreetype -L/c/msys64/mingw64/lib -lopengl32 -lgdi32 -L/c/msys64/mingw64/lib -ljpeg -L/mingw64/lib -lpng16
-lm
(Изменить: добавлен objdump из lib ag_core)
objdump -t libag_core.a | grep agCond
[ 40](sec 0)(fl 0x00)(ty 0)(scl 2) (nx 0) 0x0000000000000008 agCondBeginRender
[ 41](sec 0)(fl 0x00)(ty 0)(scl 2) (nx 0) 0x0000000000000008 agCondEndRender
[ 42](sec 0)(fl 0x00)(ty 0)(scl 2) (nx 0) 0x0000000000000008 agCondRenderLock
objdump -t libag_core-5.dll | grep agCond
[4031](sec 6)(fl 0x00)(ty 0)(scl 2) (nx 0) 0x0000000000001710 agCondEndRender
[4117](sec 6)(fl 0x00)(ty 0)(scl 2) (nx 0) 0x0000000000001718 agCondRenderLock
[4330](sec 6)(fl 0x00)(ty 0)(scl 2) (nx 0) 0x0000000000001720 agCondBeginRender
Я не совсем уверен, что означает этот вывод, но libag_core.a кажется неправильным! Почему все значения 0x0...08?
Вот первые несколько строк time_renderer.c (похоже, нет #ifdefs
/* Public domain */
/*
* Rendering-aware time backend. This is useful for applications performing
* offline rendering, where the outcome of the rendering may be influenced by
* different threads, each using AG_Delay() calls or Agar timers.
*
* Using this backend, the start of a rendering cycle causes AG_Delay() to
* block until the rendering cycle is complete.
*/
#include <sys/types.h>
#include <time.h>
#include <string.h>
#include <unistd.h>
#include <agar/core/core.h>
AG_Cond agCondBeginRender;
AG_Cond agCondEndRender;
AG_Mutex agCondRenderLock;
static struct timespec t0;
Есть какие-то подсказки, на что мне стоит смотреть?
1 ответ
Оказалось, что это libtool. AGAR GUI поставляется со своим собственным, который он использует, если вы не скажете иначе. Он содержится в подпапке AGAR mk / libtool.
Добавьте --with-libtool=/usr/bin/libtool (чтобы использовать какой-либо другой libtool) в командную строку./configure следующим образом:
./configure --host=x86_64-w64-mingw32 --prefix=$MINGWROOT --enable-debug --with-{freetype,sdl,png,jpeg,gl}=$MI
NGWROOT --with-libtool=/usr/bin/libtool --without-{fontconfig,sndfile,gettext,iconv}
Вам может понадобиться добавить --tag CC в mk / build.lib.mk следующим образом:
LIBTOOLOPTS?= --tag CC --quiet
Похоже, пакет AGT libtool немного староват!
Спустя почти 3 месяца я нашел актуальную проблему и исправление.
Ранее я говорил, что более поздняя версия libtool разрешила проблему. К сожалению, это только скрыло проблему. Когда я позже попытался создать новую сборку dev на чистой машине, обновление libtool не имело никакого значения.
Актуальной проблемой были три переменные:
AG_Cond agCondBeginRender;
AG_Cond agCondEndRender;
AG_Mutex agCondRenderLock;
В mingw для правильного экспорта этих переменных требуется declspec.
__declspec(dllexport) AG_Cond agCondBeginRender;
__declspec(dllexport) AG_Cond agCondEndRender;
__declspec(dllexport) AG_Mutex agCondRenderLock;
И теперь все версии libtool работают правильно, и на переменные можно ссылаться из того, что требуется.