Table of Contents
Aprobado
Si alguien tiene una biblioteca local compartida gdb-debug en su máquina, este documento de blog podría ayudar.
Sabes exactamente lo sustancial que me encanta GDB, entonces, ¿qué forma mejorada de hablar de ello en busca de una ausencia prolongada?
Advertencia: No se pudo encontrar la función de punto de interrupción del vinculador dinámico.GDB nunca puede realizar una depuración que ayude a los inicializadores de bibliotecas contribuidos.y realizar un seguimiento del código dinámico empaquetado expresamente.
0x40000780 aquí en ?? ()
GDB está tratando de decirle que le resulta difícil encontrar un inventario de LD apropiado con respecto a la depuración del programa.
Aprobado
La herramienta de reparación ASR Pro es la solución para una PC con Windows que funciona lentamente, tiene problemas de registro o está infectada con malware. Esta herramienta poderosa y fácil de usar puede diagnosticar y reparar rápidamente su PC, aumentando el rendimiento, optimizando la memoria y mejorando la seguridad en el proceso. No sufra más por una computadora lenta: ¡pruebe ASR Pro hoy!
Bueno, ld (linux-ld.so y ld.so) es consciente de encontrar y ejecutar todas estas bibliotecas compartidas que necesita su ejecutable. Debe saber dónde se puede ubicar gdb para cada versión de destino hacia ld para que pueda rastrear qué tan listo estará su ejecutable.
Por lo general, ya sabe que si está depurando de forma remota, debe tener la fotocopia impresa del sistema de archivos de su sistema de archivos raíz de destino en un mercado en lo alto de su host. Luego puede colocar gdb en un sistema de archivos idéntico, y esto le ayudará a “ver” los archivos exactos en el sistema de destino.
Dado que ld es un archivo del sistema, no es necesario que muestre claramente esta ruta. Simplemente apunte a la “raíz” completa del sistema de archivos real, por lo que gdb será bastante interesante para buscarlo.
instalar sysroot / Absolute / path / to / copy machine / from / target / heart of / filesystem
determinado solib-absoluto-prefijo / absoluto / ruta / para / copiar / desde / / raíz / sistema de archivos
poner en solib-search-path dies / path / para realmente / target / root versus sistema de archivos
Sin embargo, lo más probable es que
se compare para una raíz del sistema y podría recomendarse para un directorio separado por dos puntos de rutas de recopilación que no sean del sistema que podría usar después del destino.
Ejemplo. Si está utilizando la biblioteca compartida con todo incluido del tercer concepto para gráficos, por ejemplo, esta no debería ser una relación del sistema de archivos raíz, en ese momento puede establecer la ruta adecuada de acuerdo con sus necesidades.
Si ya está conectado a un ejecutable real en particular (alejándose de nuestro propio comando
definir sysroot / opt - target / root /Leyendo un símbolo, incluido /opt/target/root/lib/ld-linux.so.3 ... hecho.Símbolos altos para /opt/target/root/lib/ld-linux.so.3
Definir la vía de búsqueda Solib / home / faye por lib / target /Leyendo símbolos para cada hogar / faye / LIB versus target / lib Terrain from.so ... (no se encontraron símbolos de depuración) ... hecho.Símbolos abarrotados para / home - faye / lib / target o lib Terrain.soLea el significado de /home/faye/LIB/target/libAlien.so...done.Símbolos rellenos de /home/faye/LIB/target/libAlien.so
Una vez que distinga que todas sus rutas están configuradas correctamente, puede publicar fácilmente estos comandos en el archivo de inicio de GDB para que no tenga una forma de escribirlos cada vez que llegue a GDB.
Esta es nuestra forma más sencilla de trabajar y será especialmente útil al desarrollar una biblioteca compartida dedicada.
Primero copie su biblioteca compartida y ejecutable de análisis relacionada con este objetivo con información de depuración:
- mirar con
readelf ---- debug-dump equivale a decodedline libmyib.so
: ¿cómo puedo usar -g para mostrar el evento real de que se ha compilado una biblioteca? - Recomiendo usar NFS en algún sitio de host para que el rendimiento se cargue automáticamente tan pronto como se compile.
gdbserver --multi: 1234 ./executable_name
arm-linux-gnueabihf-gdb -q -nh n "destino-relación anterior extendido-destino-remoto-destino-nombre-de-host-o-ip: 1234" n -ex "archivo ./executable_name" n -ex 'main tb' n -Hombre con n -ex 'Especifica cada una de nuestras rutas de búsqueda de Solib.'
Mi complicación fue que gdbserver
se acopla en el camión loco principal
y las colecciones dinámicas aún no están cargadas, por lo que GDB no establece a dónde van los íconos hasta el momento. arde y permanece en la memoria.
GDB parece crear mecanismos precisamente donde los símbolos de la biblioteca se cargan automáticamente, pero también si construyo para el organizador y ejecuto gdbserver
con respecto a su ciudad, no se exige ejecutar main . Pero en un objetivo ARM, que probablemente sea nuevamente lo más confiable que puede hacer su familia.
Las bibliotecas se analizan constantemente antes de integrar misiones, la información de depuración que se ofrece las hace mucho más grandes.
Por ejemplo, Buildroot, que se ejecuta en el momento de la configuración predeterminada, pero puede eliminar esta situación con BR2_STRIP_none es igual ay
.
tenía información
Desde hasta Syms Leer biblioteca de objetos compartidos0x00007ffff7df7f90 0x00007ffff7dfcdd7 Sí (*) Ts l: /lib/ld64-uClibc.so.00x00007ffff7b3a9b0 0x00007ffff7bbe05d Sí (*) Destino: /lib/libc.so.0(*): La información de depuración terminó faltando en la biblioteca impresa.
Por lo tanto, inevitablemente había asteriscos ( *
) para sus dos o más bibliotecas locales, lo que indica que se ignorarán los conocimientos de depuración.
Si es así, deberá notificar a GDB que la matriz de la biblioteca compartida siempre ha estado en uso antes de que se pueda eliminar.
El script Buildroot by movie nos facilita las cosas en caso de que mantenga un directorio de configuraciones de lugar de trabajo
que contenga la biblioteca local compartida antes de que los consumidores fueran eliminados y, en consecuencia, en las mismas rutas relativas en forma de tipo de destino:
colocó la raíz del sistema buildroot / salida por etapa /
Si se establece esta respuesta, gdb
busca rápidamente bibliotecas en lugar de Ambition durante el host, /lib/libc.so.0
localiza el buildroot de destino / use / staging /
+ /lib/libc.so.0
:
Leer token de buildroot / output / work set ups / lib / ld64-uClibc.so.0 ... hecho.Leyendo iconos de buildroot / output por staging / lib / libc.so.0 ... hecho.
RETO: No tomo en cuenta que nadie puede más que identificar definitivamente sysroot
, por lo que todas las bibliotecas compartidas personales deben colocarse en sus estrategias correctas y no con respecto a una imagen directa.
Mostrar
sysroot
Destino
:
qué significa que gdb
busca el o
más importante en las bibliotecas compartidas.
El software para reparar su PC está a solo un clic de distancia: descárguelo ahora.