[alsa-devel] Compiling alsa-lib fails with lto
Jaroslav Kysela
perex at perex.cz
Fri Jan 5 12:07:20 CET 2018
Dne 5.1.2018 v 12:00 John Frankish napsal(a):
>>>>> Using gcc-7.2.0 and alsa-lib-1.1.5
>>>>>
>>>>> Is there a way to compile alsa-lib with lto (the method below works with alsa-plugins and alsa-utils)?
>>>>>
>>>>> Compiling alsa-lib like this works fine:
>>>>>
>>>>> CC="gcc -mtune=generic -Os -pipe" CXX="g++ -mtune=generic -Os
>>>>> -pipe -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local
>>>>> --disable-static --localstatedir=/var
>>>>> --with-configdir=/usr/local/etc/alsa
>>>>>
>>>>> ..but compiling with lto like this fails as per below:
>>>>>
>>>>> CC=" gcc -flto -fuse-linker-plugin -mtune=generic -Os -pipe"
>>>>> CXX="g++ -flto -fuse-linker-plugin -mtune=generic -Os -pipe
>>>>> -fno-exceptions -fno-rtti" ./configure --prefix=/usr/local
>>>>> --disable-static --localstatedir=/var
>>>>> --with-configdir=/usr/local/etc/alsa
>>>>>
>>>>> libtool: link: gcc -flto -fuse-linker-plugin -mtune=generic -Os
>>>>> -pipe -o .libs/aserver aserver.o ../src/.libs/libasound.so -lm
>>>>> -ldl -lpthread -lrt
>>>>> /tmp/ccoTf6DH.ltrans0.ltrans.o: In function `pcm_shm_cmd':
>>>>> <artificial>:(.text+0xe7a): undefined reference to `snd_pcm_forward'
>>>>> ../src/.libs/libasound.so: undefined reference to `snd_timer_params_set_filter'
>>>>> ../src/.libs/libasound.so: undefined reference to `snd_ctl_elem_info_get_dimension'
>>>>> ../src/.libs/libasound.so: undefined reference to `snd_ctl_elem_info_get_dimensions'
>>>>> collect2: error: ld returned 1 exit status
>>>>> make[1]: *** [Makefile:333: aserver] Error 1
>>>>> make[1]: Leaving directory '/usr/src/alsa-lib-1.1.5/aserver'
>>>>> make: *** [Makefile:338: all-recursive] Error 1 Command exited
>>>>> with non-zero status 2
>>>>
>>>> That's interesting. These are basically fallouts of the internal
>>>> function calls, and they should have been called with INTERNAL()
>>>> wrapper for covering the versioned symbols.
>>>>
>>>> I fixed the latest git tree, but still something doesn't work with
>>>> linkage in aserver. I guess Makefile.am in aserver needs to be
>>>> fixed somehow, but I leave it as is for now, as you can work around
>>>> it by disabling via the configure option.
>>>>
>>> Thanks - I'm not sure though what you mean by "configure option" - there is no "--disable-aserver"?
>>
>> It can be done by specifying --with-pcm-plugins without shm.
>> But it'd be good to have --disable-aserver option for the easiness (or at best fix the aserver build :)
>>
>>> In any case, libasound is built before "make" halts and is 29kb
>>> smaller (stripped) with lto :)
>>
>> And does everything still work, hopefully?
>>
> Oops - spoke too soon :(
>
> Using libasound from alsa-lib-1.1.5 compiled with lto, but without your update from alsa git:
>
> $ speaker-test -Ddefault:1 -c2 -t wav -l1
>
> speaker-test 1.1.5
>
> Playback device is default:1
> Stream parameters are 48000Hz, S16_LE, 2 channels
> WAV file(s)
> Rate set to 48000Hz (requested 48000Hz)
> speaker-test: relocation error: speaker-test: symbol snd_pcm_hw_params_get_buffer_size_min, version ALSA_0.9.0rc4 not defined in file libasound.so.2 with link time reference
It looks like we should use 'externally_visible' flag for the versioned
symbols, too. It was introduces for '-fwhole-program' but it seems that
'-flto' sees this flag, too.
Jaroslav
--
Jaroslav Kysela <perex at perex.cz>
Linux Sound Maintainer; ALSA Project; Red Hat, Inc.
More information about the Alsa-devel
mailing list