Skip to content
forked from djolertrk/gdb_tls

One solution for reading a value of a TLS variable from a core file generated on a target machine. This was implemented on top of GDB 7.12 (https://www.gnu.org/software/gdb/).

License

GPL-2.0, Unknown licenses found

Licenses found

GPL-2.0
COPYING
Unknown
COPYING.LIB
Notifications You must be signed in to change notification settings

djtodoro/gdb_tls

This branch is up to date with djolertrk/gdb_tls:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

e5fa5b1 · Sep 3, 2019

History

9 Commits
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Sep 3, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019
Mar 9, 2019

Repository files navigation

One solution for reading a value of a TLS variable from a core file generated on a target machine

-Building the tool (Multiarch version):

mkdir build
cd build
~/$GDB_SRC/configure --enable-thread-access --enable-build-with-cxx=no --with-python --enable-targets=all
make

-Installing the tool:

mkdir INSTALL
make install DESTDIR= ~/$path_to_build/INSTALL

-Using the tool: (NOTE: The version of the glibc on the host machine should match the glibc version of the target process being debugged. In the following example we built glibc 2.22, because the program being debugged from target machine (with MIPS arch) was built with glibc 2.22.. We are trying to print, by using Multiarch GNU GDB, the value of the TLS variable (declared as __thread int foo = 0xdeadbeef;) from a core file generated on a target machine.)

...

(gdb) add-auto-load-safe-path ~/path_to_the_glibc22_build/INSTALL/lib
(gdb) set libthread-db-search-path ~/path_to_the_glibc22_build/INSTALL/lib
(gdb) set solib-search-path ~/path_to_libs_from_target_machine/
(gdb) file exampleFromMipsPlatform
Reading symbols from exampleFromMipsPlatform...done.
(gdb) core-file core.mips
[Thread debugging using libthread_db enabled]
Using host libthread_db library "~/path_to_the_glibc22_build/INSTALL/liblibthread_db.so.1".
Core was generated by `./exampleFromMipsPlatform'.
Program terminated with signal SIGABRT, Aborted.
#0  0x00000000 in ?? ()
[Current thread is 1 (Thread 0x771bf000 (LWP 21808))]

-before patching:

(gdb) p/x foo
Cannot find user-level thread for LWP 21808: generic error

-after patching:

(gdb) p/x foo
$1 = 0xdeadbeef

About

One solution for reading a value of a TLS variable from a core file generated on a target machine. This was implemented on top of GDB 7.12 (https://www.gnu.org/software/gdb/).

Resources

License

GPL-2.0, Unknown licenses found

Licenses found

GPL-2.0
COPYING
Unknown
COPYING.LIB

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 75.6%
  • Assembly 9.7%
  • Objective-C 5.6%
  • Makefile 2.3%
  • Scheme 1.9%
  • C++ 1.4%
  • Other 3.5%