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 работают правильно, и на переменные можно ссылаться из того, что требуется.

Другие вопросы по тегам