2009-10-13 12 views
8

Mam wbudowany program testowy ELF używając LSB SDK (uwaga, że ​​moje pytanie nie jest specyficzne dla LSB):Jak mogę sprawdzić, która zależność ELF nie jest spełniona?

$ /opt/lsb/bin/lsbcc tst.c 
$ ls -l a.out 
-rwxr-xr-x 1 math math 10791 2009-10-13 20:13 a.out 
$ file a.out 
a.out: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.15, not stripped 

Ale nie jestem w stanie go uruchomić (tak, zapewniam was plik jest w katalogu ...):

$ ./a.out 
bash: ./a.out: No such file or directory 

$ uname -a 
Linux math 2.6.28-15-generiC#52-Ubuntu SMP Wed Sep 9 10:48:52 UTC 2009 x86_64 GNU/Linux 

myślę istnieje zależność ELF, który nie jest spełnić, ale nie wiem jak go znaleźć. Czy istnieje narzędzie podobne do ldd dla bibliotek, które może być użyte do znalezienia brakującego łącza?

Nie sądzę, jest to związane z różnicą 2.6.15/2.6.28-15 ponieważ LSB kompilator działa:

$ file /opt/lsb/bin/lsbcc 
/opt/lsb/bin/lsbcc: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.4, not stripped 

Tylko w przypadku, tutaj jest dynamiczna sekcja ELF tematyce .out:

0x0000000000000001 (NEEDED)    Shared library: [libpthread.so.0] 
0x0000000000000001 (NEEDED)    Shared library: [libm.so.6] 
0x0000000000000001 (NEEDED)    Shared library: [libc.so.6] 
0x000000000000000c (INIT)    0x400428 
0x000000000000000d (FINI)    0x400638 
0x0000000000000004 (HASH)    0x400278 
0x0000000000000005 (STRTAB)    0x400350 
0x0000000000000006 (SYMTAB)    0x4002a8 
0x000000000000000a (STRSZ)    121 (bytes) 
0x000000000000000b (SYMENT)    24 (bytes) 
0x0000000000000015 (DEBUG)    0x0 
0x0000000000000003 (PLTGOT)    0x600fe8 
0x0000000000000002 (PLTRELSZ)   24 (bytes) 
0x0000000000000014 (PLTREL)    RELA 
0x0000000000000017 (JMPREL)    0x400410 
0x0000000000000007 (RELA)    0x4003f8 
0x0000000000000008 (RELASZ)    24 (bytes) 
0x0000000000000009 (RELAENT)   24 (bytes) 
0x000000006ffffffe (VERNEED)   0x4003d8 
0x000000006fffffff (VERNEEDNUM)   1 
0x000000006ffffff0 (VERSYM)    0x4003ca 
0x0000000000000000 (NULL)    0x0 

Odpowiedz

11

Wygląda na to, co dzieje się, gdy brakuje interpretera ELF.

Upewnij się, że /lib/ld-lsb.so.2 (lub podobny, różni się w zależności od wersji i architektury LSB). ldd i readelf -l będą mogły pokazać programowi ELF, którego żąda plik wykonywalny.

(lsbcc (lub coś w LSB toolchain) zastępuje domyślne systemu /lib/ld-linux.so.2, prawdopodobnie poprzez przepuszczenie -Wl,--dynamic-linker=/lib/ld-lsb.so.2 do kompilatora, ze względów uważam za dość głupie (Glibc zawsze dostarczała dość doskonałą wstecznej kompatybilności tutaj), ale nie masz to.)

+0

To wszystko, nie mam w systemie interpretera LSB (/lib64/ld-lsb-x86-64.so.3). W rzeczywistości nie wiedziałem, że istnieje specyficzny dla LSB interpreter, który muszę zainstalować ... To zabawne, że pliki binarne w LSB SDK nie są zgodne z LSB. – math