abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    včera 23:44 | Nová verze

    Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Zajímavý článek

    50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.

    Ladislav Hagara | Komentářů: 0
    včera 16:22 | Pozvánky

    Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.

    TomasVondra | Komentářů: 0
    včera 03:00 | IT novinky

    Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].

    Ladislav Hagara | Komentářů: 6
    včera 02:00 | IT novinky

    Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).

    Ladislav Hagara | Komentářů: 3
    21.4. 19:11 | Komunita

    Thunderbird 128, příští major verze naplánovaná na červenec, přijde s nativní podporou Exchange napsanou v Rustu.

    Ladislav Hagara | Komentářů: 20
    21.4. 04:44 | Komunita

    Byly vyhlášeny výsledky letošní volby vedoucího projektu Debian (DPL, Wikipedie). Novým vedoucím je Andreas Tille.

    Ladislav Hagara | Komentářů: 7
    21.4. 00:11 | Nová verze

    Po osmi měsících vývoje byla vydána nová verze 0.12.0 programovacího jazyka Zig (GitHub, Wikipedie). Přispělo 268 vývojářů. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    20.4. 23:55 | Pozvánky

    Poslední měsíc byl plný zajímavých akcí, o kterých Vám bastlíři z projektu MacGyver mohou povědět, protože se na ně sami vydali. Kde všude byli, ptáte se? Objevili se na Installfestu, Arduino Day, Hackaday Europe a tajném srazu bastlířů z Twitteru. A z každé akce pro vás mají zajímavé poznatky.

    … více »
    bkralik | Komentářů: 1
    KDE Plasma 6
     (71%)
     (10%)
     (2%)
     (17%)
    Celkem 670 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: Statická kompilace a pkg-config

    30.5.2020 14:13 MilanC | skóre: 16
    Statická kompilace a pkg-config
    Přečteno: 291×
    Ahoj,

    překládám si staticky ffmpeg, ale u jedné knihovny (libvmaf) se mi nedaří její integrace. Pokud ji předem vykompiluji a nainstaluji do systému, je vše OK. Když si ale vypřekládám do vlastní adresářové struktury, tak ffmpeg libvmaf nevidí a při kompilaci vyhodí: "ERROR: libvmaf >= 1.3.9 not found using pkg-config". Je to jediná knihovna, která má problém, jinak kompiluji staticky s dalšími (fdkaac,mp3lame,x264,x265,libaom...) bez problému.

    Takto vypadá vybuilděná struktura souborů: https://pastebin.com/8VuyXEEa

    Je vidět, že libvmaf.a je na svém místě, libvmaf.pc v pkgconfig adresáři také je, jeho obsah také vypadá ok:
    # cat lib/pkgconfig/libvmaf.pc
    prefix=/tmp/stream_install/ffmpeg-build-static
    libdir=${prefix}/lib
    includedir=${prefix}/include
    
    Name: libvmaf
    Description: VMAF, Video Multimethod Assessment Fusion
    Version: 1.3.16
    Libs: -L${libdir} -lvmaf
    Libs.private: -pthread
    Cflags: -I${includedir}/libvmaf
    
    ffmpeg překládám následovně, PKG_CONFIG_PATH odkazuje správně ($DEST_DIR je můj root adresář pro build = /tmp/stream_install/ffmpeg-build-static).

    PKG_CONFIG_PATH="$DEST_DIR/lib/pkgconfig:$DEST_DIR/lib64/pkgconfig" \ ./configure \ --enable-static \ --pkg-config-flags="--static" \ --disable-shared \ --prefix="$DEST_DIR" \ --extra-cflags="-I $DEST_DIR/include -static -I $CUDA_HOME/include/" \ --extra-ldflags="-L $DEST_DIR/lib -static -L $CUDA_HOME/lib64/" \ --enable-gpl \ --enable-nonfree \ --enable-libx264 \ --enable-libx265 \ --enable-libfdk-aac \ --enable-openssl \ --enable-libvmaf --enable-version3 \ --enable-pthreads \ --enable-runtime-cpudetect \ --enable-filter=drawtext --enable-libfreetype \ --extra-libs="-lpthread -lm -lz -ldl"

    Nemůžu už den přijít na to, kde je problém. Bohužel s pkgconfig tolik nepracuji, ale prostě tam nic chybového nevidím. :( Díky za radu.

    Řešení dotazu:


    Odpovědi

    30.5.2020 15:06 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Co ti vyhodi:
    pkg-config --list-all | grep libvmaf
    30.5.2020 15:27 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Ahoj, vůbec nic. V kterém adresáři bych měl spustit? V systémovém pkg-config nic nemám, kompiluji bokem (ne do systému) a pak do správného místa sahám přes PKG_CONFIG_PATH.
    30.5.2020 15:30 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    PKG_CONFIG_LIBDIR=/tmp/stream_install/ffmpeg-build-static/lib/pkgconfig/ pkg-config --list-all
    fdk-aac   Fraunhofer FDK AAC Codec Library - AAC codec library
    ffnvcodec ffnvcodec - FFmpeg version of Nvidia Codec SDK headers
    aom       aom - Alliance for Open Media AV1 codec library v2.0.0-284-gcfd029691.
    x264      x264 - H.264 (MPEG4 AVC) encoder library
    libvmaf   libvmaf - VMAF, Video Multimethod Assessment Fusion
    x265      x265 - H.265/HEVC video encoder
    
    30.5.2020 17:03 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Premennu definuj cez:
    export PKG_CONFIG_LIBDIR="bla"
    pkg-config
    Neprepisuje tuto premennu skript ./configure resp. Makefile.ac?

    Ak by si prekladal v chroote, tak tam si v chroote mozes aj instalovat do systemu a bez toho aby si dobral tvoj hlavny pouzivany system.
    30.5.2020 20:43 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Ahoj, nedaří se. Když nastavím PKG_CONFIG_LIBDIR místo PKG_CONFIG_PATH, tak pak zase nevidí nějaké systémové knihovny (libfree...). Spíš mi přijde, ež je chyba někde v tom libvmaf, možná libvmaf.pc, když to ostatní veme bez problému. Zkoušel jsem v tom .pc laborovat s cestami, protože se mi tam něco moc nezdá, ale také jsem nebyl úspěšný.

    Pokud bys měl třeba čs, můžu poskytnout celý build skript popř. možná lepší vzdálenou plochu na SSH.
    30.5.2020 21:00 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Aky mas OS?
    30.5.2020 21:01 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Ubuntu 20.04.
    30.5.2020 21:16 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Asi si nevidel nieco take:
    export PATH="$PATH:/opt/hello_world/bin/"
    Ak nastavujes nove hodnoty, tak pridavaj aj defaulne systemove hodnoty s tou novou hodnotou (tj. vychodiskove cesty). Hodnoty su oddelene ":".

    Vychodiskove hodnoty sa daju zistit z live systemu (pozri).
    30.5.2020 21:45 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Tak překlad už se mi podařil bez chyby. Díky. Nicméně je zde jiný problém. Jakoby se ten libvmaf nezakompiloval staticky?

    ldd na vykompilovanou binárku ffmpegu, a 3. řádek. Po spuštění: ffmpeg: error while loading shared libraries: libvmaf.so.0: cannot open shared object file: No such file or directory
            linux-vdso.so.1 (0x00007ffd6f5f0000)
            libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f687d28e000)
            libvmaf.so.0 => not found
            libnppig.so.10 => /usr/local/cuda-10.2/targets/x86_64-linux/lib/libnppig.so.10 (0x00007f687b6a6000)
            libnppicc.so.10 => /usr/local/cuda-10.2/targets/x86_64-linux/lib/libnppicc.so.10 (0x00007f687b01b000)
            libnppidei.so.10 => /usr/local/cuda-10.2/targets/x86_64-linux/lib/libnppidei.so.10 (0x00007f687a5ab000)
            libva.so.2 => /lib/x86_64-linux-gnu/libva.so.2 (0x00007f687a582000)
            libfreetype.so.6 => /lib/x86_64-linux-gnu/libfreetype.so.6 (0x00007f687a4c1000)
            libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f687a4a5000)
            libssl.so.1.1 => /lib/x86_64-linux-gnu/libssl.so.1.1 (0x00007f687a412000)
            libcrypto.so.1.1 => /lib/x86_64-linux-gnu/libcrypto.so.1.1 (0x00007f687a13c000)
            libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f687a136000)
            libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f687a113000)
            libstdc++.so.6 => /lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f6879f30000)
            libmvec.so.1 => /lib/x86_64-linux-gnu/libmvec.so.1 (0x00007f6879f04000)
            libva-drm.so.2 => /lib/x86_64-linux-gnu/libva-drm.so.2 (0x00007f6879eff000)
            libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f6879d0d000)
            /lib64/ld-linux-x86-64.so.2 (0x00007f68805a8000)
            libnppc.so.10 => /usr/local/cuda-10.2/targets/x86_64-linux/lib/libnppc.so.10 (0x00007f6879a91000)
            librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007f6879a86000)
            libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f6879a69000)
            libpng16.so.16 => /lib/x86_64-linux-gnu/libpng16.so.16 (0x00007f6879a31000)
            libdrm.so.2 => /lib/x86_64-linux-gnu/libdrm.so.2 (0x00007f6879a1d000)
    
    30.5.2020 22:01 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Vies mi povedat rozdiel medzi statickym a dynamickym prekladom? Lebo to, co si tu vlozit je dynamicky preklad ffmpeg.
    30.5.2020 22:09 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Podle mého, při statické kompilaci se přilinkují do binárky přímo knihovny .a, kdežto při dynamické se odkáže na existující .so, které se napojí až při spuštění/za běhu. Takže pokud vytvářím binárku statickou kompilací, neměl bych ty statické knihovny už později potřebovat, protože budou součástí té binárky. OK?

    Já netvrdím, že chci staticky kompilovat úplně vše, ale jen něco, včetně toho libvmaf.

    A podle mého řada jich je staticky, protože v ldd nejsou (třeba libaom), takže částečně to určitě funguje. Tomu nasvědčuje i zvětšující se velikost výsledné binárky, když přidávám jednotlivé --enable-*, které jsem předtím vypřekládal do vlastního binu.

    Ale možná jsem mimo a funguje to jinak.
    31.5.2020 12:34 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    dynamicka - to ide este dalej, cez dlopen() vies volat funkciu z hocijakej zdielanej kniznice (.so). Co sa napriklad vyuziva na modulov v C programoch.
    A podle mého řada jich je staticky, protože v ldd nejsou (třeba libaom), takže částečně to určitě funguje.
    libaom v Debiane a Ubuntu

    Rob v Linuxe podla Linuxu (ak nie su ine dovody).

    Nainstaluj si ju do /usr/local/lib a pridaj priecinok /usr/local/lib do /etc/ld.so.conf (urcuje kde hladat zdielane kniznice). Index vsetkych .so suborov sa aktualizuje prikazom ldconfig.

    Alebo prilozenu kniznicu kopirujes vedla Tvojej binarky a pri spustani uprav/nastav premennu LD_LIBRARY_PATH, aby hladalo v priecinku kde mas binarku.

    A najlepsie si je vytvor balicek a ten mat v systeme.

    Ber, ze pri aktualizacii staci zmenit kniznicu a nie cely program.
    když přidávám jednotlivé --enable-*, které jsem předtím vypřekládal do vlastního binu
    Zle chapes --enable-. To sluzis na jednoduche nastavenie prekladu, bez toho aby pouzivatel studoval a upravoval Makefile.{am,ac}.

    Napriklad miesto pre gtkmm (GTK) prekladaj pre QT. Kod programu je napisane pre obe rozhrania ale ktory kod sa realne bude vykonavat sa nastavuje s predprocesom v C/C++.

    Mozes napriklad vyberat rozne kniznice napr. na spracovanie urciteho formatu - napr. volba na teba podla efektivnosti, rychlosti.

    Alebo zapinas/vypisanie bonus casti, ktore nie su uplne nevyhnutne k behu programu - napr. povolit notifikacie na obrazovku alebo zakazanie systemd casti (monitor stavu baterky).
    30.5.2020 21:50 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Myslím, že pomohla tato úprava:

    --extra-cflags="-I $DEST_DIR/include -static -I $CUDA_HOME/include/" \ --extra-ldflags="-L $DEST_DIR/lib -static -L $CUDA_HOME/lib64/" \ Na (bez static): --extra-cflags="-I $DEST_DIR/include -I $CUDA_HOME/include/" \ --extra-ldflags="-L $DEST_DIR/lib -L $CUDA_HOME/lib64/" \
    30.5.2020 22:03 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Jasne. Extra flag je lepsie. Neprepise (rozumej nahradi) defaulne premenne, len ich doplni o toto.
    Řešení 1× (MilanC (tazatel))
    30.5.2020 22:49 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Tak jsem na to asi přišel, kde je zakopán pes. Vypřekládání libvmaf hodí do mého lib jak dynamickou (.so), tak statickou (.a) knihovnu. Ffmpeg si při kompilaci šáhne primárně po dynamické, proto jí pak chce v systému a tato závislost je vidět v ldd.

    Můj lib pak vypadá následovně: :/tmp/stream_install/ffmpeg-build-static/lib# ls libaom.a libavdevice.a libavformat.a libfdk-aac.a libmp3lame.a libpostproc.a libswscale.a libx264.a libyasm.a libavcodec.a libavfilter.a libavutil.a libfdk-aac.la libmp3lame.la libswresample.a libvmaf.a libx265.a pkgconfig

    Když jsem dynamické ručně odmazal a nechal jen statickou, tak už si přeložil se statickou. Je to tedy jediná knihovna (libvmaf), která se vypřekládá dynamicky i staticky...

    libvmaf překládám následovně:

    git clone https://github.com/Netflix/vmaf cd vmaf/libvmaf # pokud knihovnu chceme mít v systému, tak: meson build --buildtype release meson build --prefix="$DEST_DIR" --libdir="$DEST_DIR/lib" --default-library static --buildtype release

    ninja -vC build ninja -vC build test ninja -vC build install

    Nicméně co jsem našel, ta volba --default-library (both,dynamic,static) lidem spíš nefunguje. Ale to je info z 2018, tak je mi divné, že to nejde ani dnes... https://github.com/mesonbuild/meson/issues/2910

    mimochodem v ofic. dokumentaci https://mesonbuild.com/Builtin-options.html je ta volba s podtržítkem, ale to mi nejde vůbec. meson: error: unrecognized arguments: --default_library static

    meson z repa meson -v 0.53.2
    30.5.2020 22:50 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    jinak výpis lib výše byl udělán až po odmazání .so
    31.5.2020 13:53 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Ten libvmaf ještě zlobil, občas se mi jej sice povedlo přeložit, ale častěji ne. Na základě této rady pomohlo přidání -lstdc++ do --extra-libs ffmpegu. https://github.com/Netflix/vmaf/issues/569
    31.5.2020 14:20 debian+
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Preco to prekladas s libvmaf?
    31.5.2020 14:25 MilanC | skóre: 16
    Rozbalit Rozbalit vše Re: Statická kompilace a pkg-config
    Potřebuji používat tu metriku ale nechtěl jsem to instalovat do systému.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.