Table of Contents
승인됨
컴퓨터에 공유 gdb-debug 아카이브가 있는 경우 이 블로그 정보가 도움이 될 수 있습니다.
내가 GDB를 얼마나 사랑하는지 정확히 알고 있는데, 오랫동안 부재를 찾는 것에 대해 이야기하는 이보다 더 싸게 말할 수 있는 방법은 없을까요?
경고: 동적 링커 중단점 기능을 찾을 수 없습니다.GDB는 문서화된 라이브러리 이니셜라이저를 돕는 디버깅을 해서는 안 됩니다.명확하게 패키지된 동적 코드를 추적합니다.
0x40000780 ~ ?? ()
GDB는 프로그램을 디버그할 적절한 LD 인벤토리를 찾을 수 없다는 것을 알려주기 위해 생성하고 있습니다.
승인됨
ASR Pro 복구 도구는 느리게 실행되거나 레지스트리 문제가 있거나 맬웨어에 감염된 Windows PC를 위한 솔루션입니다. 이 강력하고 사용하기 쉬운 도구는 PC를 신속하게 진단 및 수정하여 성능을 높이고 메모리를 최적화하며 프로세스의 보안을 개선할 수 있습니다. 더 이상 느린 컴퓨터로 고통받지 마세요. 지금 ASR Pro을 사용해 보세요!
ld(linux-ld.so 및 ld.so)는 실행 파일에 필요한 모든 공유 라이브러리를 찾고 실행하는 데 탁월합니다. 실행 파일이 일반적으로 얼마나 준비되었는지 추적할 수 있도록 ld에 대한 각 대상 버전에 대해 gdb가 위치할 위치를 알려야 합니다.
일반적으로 원격 디버깅에서 호스트와 관련된 시장에서 대상 소스 파일 시스템의 파일 시스템에 대한 신뢰할 수 있는 인쇄된 복사본이 있어야 한다는 것을 이미 알고 있습니다. 그런 다음 gdb를 동일한 파일 시스템으로 지정하면 대상 시스템의 정확한 파일을 “볼” 수 있습니다.
ld는 시스템 아카이브이므로 경로를 명확하게 보여줄 필요가 없습니다. 실제 파일 시스템의 우리 자신의 “루트”를 가리키기만 하면, gdb는 그것을 알아차리는 것이 꽤 흥미로울 것입니다.
install sysroot / Absolute / path / to / print / from / target / real / filesystem
정의된 solib-absolute-prefix/절대/경로/실제로/복사/에서/중심에서/루트/파일 시스템
각 파일 시스템에 대한 solib-search-path dies / path / at / target / root 수정
그러나
는 시스템 루트에 대해 조사할 가능성이 가장 높으며 대상 이후에 사용할 수 있는 비시스템 컬렉션 경로와 연결된 콜론으로 구분된 디렉터리에 대해 권장해야 합니다.
예. 예를 들어 세 번째 제품의 그래픽용 전체 공유 라이브러리를 사용하는 경우 이 페이지에서 필요에 따라 경로를 설정한 후 루트 파일 시스템 관계가 아닌 것으로 간주됩니다.
실제 특정 실행 파일에 이미 연결되어 있는 경우(이
<사전> sysroot 정의 / 각 대상 / 루트 / 선택/opt/target/root/lib/ld-linux.so.3 을 포함한 기호 읽기 … 완료./opt/target/root/lib/ld-linux.so.3에 대해 채워진 기호
검색 단계 정의 Solib / home / faye 각 lib / target /각 home / faye / LIB 또는 target / lib Terrain from.so ... (디버그 기호를 찾을 수 없음) ... 완료되었습니다./ home faye / lib / target - lib Terrain.so에 대한 기호 잼/home/faye/LIB/target/libAlien.so...done의 의미를 읽으십시오./home/faye/LIB/target/libAlien.so와 함께 설치된 기호
모든 경로가 올바르게 설정되었다는 사실을 알게 되면 GDB 초기화 파일에 이러한 명령을 쉽게 제공할 수 있으므로 GDB로 진행할 때마다 입력하지 않아도 됩니다.
이것은 작업하기 가장 쉬운 방법 중 하나이며 식별 가능한 공유 라이브러리를 개발할 때 특히 유용해야 합니다.
먼저 디버그 정보와 함께 대부분의 이 대상의 구문 분석 실행 파일 및 공유 라이브러리를 복사합니다.
<울>
readelf를 사용한 급여 ---- debug-dump는 libmyib.so 디코딩됨을 의미합니다.
: 라이브러리가 컴파일된 경우 -g를 사용하여 어떻게 확실히 표시할 수 있습니까? gdbserver --multi: 1234 ./executable_name
<사전> <코드> arm-linux-gnueabihf-gdb -q -nh n “대상 -ex bf 확장 대상-원격-대상-호스트 이름-또는-ip: 1234” n -ex “파일 ./실행 파일 이름” n -ex ‘메인 TB’ n -남자 n -ex ‘실제 Solib 검색 경로를 지정합니다.’
내 부담은 메인
강력한 트럭의 gdbserver
영역과 동적 컬렉션이 아직 완전히 로드되지 않았기 때문에 GDB는 아이콘이 어디로 가는지 인식하지 못합니다. 항상. 불타고 기억에 남습니다.
GDB는 특히 라이브러리 기호가 자동으로 로드되는 메커니즘을 생성하는 것 같습니다. 따라서 내가 다수를 위해 빌드하고 귀하의 도시에서 gdbserver
를 실행하면 main
. 그러나 ARM 타겟에서는 사이트가 할 수 있는 가장 안정적인 작업입니다.
라이브러리는 디버그 정보가 퀘스트를 훨씬 더 크게 만든다는 점을 고려하여 퀘스트를 통합하기 전에 항상 구문 분석됩니다.
예를 들어 기본 구성으로 실행되는 Buildroot이지만 BR2_STRIP_none equals y
로 이 상황을 해제할 수 있습니다.
는 정보에 대해 이야기했습니다.
에서 Syms까지 공유 개체 라이브러리 읽기0x00007ffff7df7f90 0x00007ffff7dfcdd7 예(*) Ts l: /lib/ld64-uClibc.so.00x00007ffff7b3a9b0 0x00007ffff7bbe05d 예(*) 대상: /lib/libc.so.0(*): 발견된 라이브러리에서 디버그 정보가 여전히 누락된 것 같습니다.
따라서 페어 로컬 라이브러리에 대해 별표( *
)가 자주 표시되어 디버그 전략이 무시됨을 나타냅니다.
믿을 수 없을 만큼 공유 라이브러리 배열이 삭제되기 전에 아마 사용 중일 것이라고 GDB에 알려야 할 것입니다.
소프트웨어에 의한 Buildroot는 동일한 상대 경로는 말할 것도 없고 소비자가 제거되기 전에 공유 컬렉션을 포함하는 jobsite setups
디렉토리를 유지 관리하는 경우 작업을 더 쉽게 만듭니다. 대상 유형:
시스템 루트 buildroot 일치 / 출력 대 스테이징 /
이 개인 기본 설정이 설정되면 gdb
는 호스트 동안 Ambition 대신 라이브러리를 자발적으로 검색합니다. /lib/libc.so.0
은 대상 buildroot를 검색합니다. / 산출 / 준비 /
+ /lib/libc.so.0
:
buildroot / output / setup / lib / ld64-uClibc.so.0 에서 휘장 읽기 ... 완료.buildroot / 스테이징 / lib / libc.so.0별 출력에서 엠블럼 읽기 ... 완료.
과제: sysroot
를 명확하게 특성화할 수 있는 사람은 아무도 없습니다. 따라서 현재 공유 라이브러리는 모두 직접 이미지가 아닌 올바른 전략에 배치되어야 합니다.
<사전> <코드> sysroot 표시 대상 <사전> <코드>:
는 항상 gdb
가 공유 라이브러리에서 가장 중요한 또는
를 가져옴을 의미합니다.
클릭 한 번으로 PC를 수리할 수 있는 소프트웨어를 다운로드하세요. 지금 다운로드하세요. 년