it-swarm-es.tech

¿Podemos obtener información del compilador de un binario elfo?

¿Hay alguna posibilidad de saber cómo se construyó un binario en Linux? (y otro Unix)

Compilador, versión, hora, banderas, etc.

Miré readelf y no pude encontrar mucho, pero podría haber otras formas de analizar el código binario/sección, etc.

¿Algo que sepas extraer?

53
elmarco

No existe una forma universal, pero puede hacer una suposición educada buscando cosas que solo hace un compilador.

GCC es el más fácil; escribe un .comment sección que contiene la cadena de versión de GCC (la misma cadena que obtienes si ejecutas gcc --version). No sé si hay una manera de mostrarlo con readelf, pero con objdump es:

objdump -s --section .comment /path/binary

Me acabo de dar cuenta de que ignoré el resto de tu pregunta. Las banderas generalmente no se guardan en ningún lado; probablemente estarían en una sección de comentarios, pero nunca he visto eso hecho. Hay un lugar en el encabezado COFF para una marca de tiempo, pero no hay equivalente en ELF, por lo que tampoco creo que el tiempo de compilación esté disponible

52
Michael Mrozek

Qué tal si:

readelf -p .comment a.out
29
Colin King

Puede intentar usar el comando strings. Creará una gran cantidad de salida de texto; al marcarlo, puede adivinar el compilador.

[email protected]:~$ strings -a a.out |grep -i gcc
GCC: (Ubuntu 4.4.3-4ubuntu5) 4.4.3

Aquí sé que está compilado con gcc pero siempre puedes redirigir la salida de strings a un archivo y examinarlo.

Hay una muy buena utilidad llamada peid para Windows pero no puedo encontrar ninguna alternativa en Linux.

19
Hemant

readelf u objdump ambos pueden hacer esto.

El archivo ELF compilado por gcc agregará .note.ABI-tag y .note.gnu.build-id dos secciones. ambos podrían mostrarse por

objdump -sj .note.ABI-tag ELFFILE
objdump -sj .note.gnu-build-id ELFFILE

la opción "s" significa mostrar el contenido completo, "j" para indicar el nombre de la sección. Este estilo obtiene contenidos hexadecimales de esas secciones.

readelf -n

mostrará contenido legible para humanos de ELFFILE una vez. la opción "n" significa NOTAS.

Elige uno como quieras.

Por cierto, use objcopy, puede agregar su propia sección en el archivo elf.

5
liuyang1

Hay dos métodos Ambos darán el mismo resultado.

objdump -s --section .comment path/to/binary

Usando el comando readelf, readelf -S binary mostrará los 40 encabezados de sección en el binario. Tenga en cuenta el número de serie de .comment encabezado de sección. En mi sistema, se mostró como 27 (puede ser diferente para su caso)

readelf -x 30 path/to/binary -> que mostrará el volcado hexadecimal de la sección '.comment'. En ese volcado, puede ver el compilador utilizado para construir el binario.

5
Ranjini

También puede usar este script inteligente que cuenta los números de varias instrucciones de CPU utilizadas por el binario. Se basa en el análisis de salida objdump. Tenga en cuenta que puede llevar bastante tiempo terminarlo si lo usa en un gran binario.

4
rozcietrzewiacz

Si abre un archivo binario ELF en 7-Zip, enumerará las diferentes secciones dentro. Desde allí, puede usar la opción Ver menú contextual en, digamos, la sección ".comment", para ver los comentarios del compilador (por ejemplo, "GCC: (GNU) 4.9 20150123 (versión preliminar) Android = clang versión 3.8.256229 (basado en LLVM 3.8.256229) ").

Tenga en cuenta que la sección ".comment", si existe, parece comenzar con un carácter nulo, así que asegúrese de elegir una aplicación de visor para usar dentro de 7-Zip que no se confunda con esto (por ejemplo, intenta interpretar el datos como Unicode). Otras secciones que pueden existir y ser de interés son ".note. *".

0
Joe

Puede valer la pena un golpe de suerte, dependiendo de qué programa. Algunos programas tendrán esto compilado como información y accesible mediante algún tipo de llamada de versión (-V, --version, -Version, etc.). Puede encontrar cualquier subconjunto de los elementos que está buscando (incluido el conjunto nulo). Aquí hay un ejemplo particularmente fructífero, Perl 5:

$ Perl -V

Summary of my Perl5 (revision 5 version 26 Subversion 2) configuration:

  Platform:
    osname=linux
    osvers=4.15.15-1-Arch
    archname=x86_64-linux-thread-multi
    uname='linux flo-64 4.15.15-1-Arch #1 smp preempt sat mar 31 23:59:25 utc 2018 x86_64 gnulinux '
    config_args='-des -Dusethreads -Duseshrplib -Doptimize=-march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong -fno-plt -Dprefix=/usr -Dvendorprefix=/usr -Dprivlib=/usr/share/Perl5/core_Perl -Darchlib=/usr/lib/Perl5/5.26/core_Perl -Dsitelib=/usr/share/Perl5/site_Perl -Dsitearch=/usr/lib/Perl5/5.26/site_Perl -Dvendorlib=/usr/share/Perl5/vendor_Perl -Dvendorarch=/usr/lib/Perl5/5.26/vendor_Perl -Dscriptdir=/usr/bin/core_Perl -Dsitescript=/usr/bin/site_Perl -Dvendorscript=/usr/bin/vendor_Perl -Dinc_version_list=none -Dman1ext=1Perl -Dman3ext=3Perl -Dcccdlflags='-fPIC' -Dlddlflags=-shared -Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now -Dldflags=-Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now'
    hint=recommended
    useposix=true
    d_sigaction=define
    useithreads=define
    usemultiplicity=define
    use64bitint=define
    use64bitall=define
    uselongdouble=undef
    usemymalloc=n
    default_inc_excludes_dot=define
    bincompat5005=undef
  Compiler:
    cc='cc'
    ccflags ='-D_REENTRANT -D_GNU_SOURCE -fwrapv -fno-strict-aliasing -pipe -fstack-protector-strong -I/usr/local/include -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64 -D_FORTIFY_SOURCE=2'
    optimize='-march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong -fno-plt'
    cppflags='-D_REENTRANT -D_GNU_SOURCE -fwrapv -fno-strict-aliasing -pipe -fstack-protector-strong -I/usr/local/include'
    ccversion=''
    gccversion='7.3.1 20180312'
    gccosandvers=''
    intsize=4
    longsize=8
    ptrsize=8
    doublesize=8
    byteorder=12345678
    doublekind=3
    d_longlong=define
    longlongsize=8
    d_longdbl=define
    longdblsize=16
    longdblkind=3
    ivtype='long'
    ivsize=8
    nvtype='double'
    nvsize=8
    Off_t='off_t'
    lseeksize=8
    alignbytes=8
    prototype=define
  Linker and Libraries:
    ld='cc'
    ldflags ='-Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now -fstack-protector-strong -L/usr/local/lib'
    libpth=/usr/local/lib /usr/lib/gcc/x86_64-pc-linux-gnu/7.3.1/include-fixed /usr/lib /lib/../lib /usr/lib/../lib /lib /lib64 /usr/lib64
    libs=-lpthread -lnsl -lgdbm -ldb -ldl -lm -lcrypt -lutil -lc -lgdbm_compat
    perllibs=-lpthread -lnsl -ldl -lm -lcrypt -lutil -lc
    libc=libc-2.26.so
    so=so
    useshrplib=true
    libperl=libperl.so
    gnulibc_version='2.26'
  Dynamic Linking:
    dlsrc=dl_dlopen.xs
    dlext=so
    d_dlsymun=undef
    ccdlflags='-Wl,-E -Wl,-rpath,/usr/lib/Perl5/5.26/core_Perl/CORE'
    cccdlflags='-fPIC'
    lddlflags='-shared -Wl,-O1,--sort-common,--as-needed,-z,relro,-z,now -L/usr/local/lib -fstack-protector-strong'


Characteristics of this binary (from libperl): 
  Compile-time options:
    HAS_TIMES
    MULTIPLICITY
    PERLIO_LAYERS
    Perl_COPY_ON_WRITE
    Perl_DONT_CREATE_GVSV
    Perl_IMPLICIT_CONTEXT
    Perl_MALLOC_WRAP
    Perl_OP_PARENT
    Perl_PRESERVE_IVUV
    USE_64_BIT_ALL
    USE_64_BIT_INT
    USE_ITHREADS
    USE_LARGE_FILES
    USE_LOCALE
    USE_LOCALE_COLLATE
    USE_LOCALE_CTYPE
    USE_LOCALE_NUMERIC
    USE_LOCALE_TIME
    USE_PERLIO
    USE_Perl_ATOF
    USE_REENTRANT_API
  Built under linux
  Compiled at Apr 18 2018 22:21:20
  %ENV:
    Perl5LIB="/home/jhuber/Perl5/lib/Perl5"
    Perl_LOCAL_LIB_ROOT="/home/jhuber/Perl5"
    Perl_MB_OPT="--install_base "/home/jhuber/Perl5""
    Perl_MM_OPT="INSTALL_BASE=/home/jhuber/Perl5"
  @INC:
    /home/jhuber/Perl5/lib/Perl5/x86_64-linux-thread-multi
    /home/jhuber/Perl5/lib/Perl5
    /usr/lib/Perl5/5.26/site_Perl
    /usr/share/Perl5/site_Perl
    /usr/lib/Perl5/5.26/vendor_Perl
    /usr/share/Perl5/vendor_Perl
    /usr/lib/Perl5/5.26/core_Perl
    /usr/share/Perl5/core_Perl
0
Joshua Huber