Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Possibility to print decodable addresses with ASLR anabled #180

Open
McCzarny opened this issue Sep 7, 2024 · 2 comments
Open

Possibility to print decodable addresses with ASLR anabled #180

McCzarny opened this issue Sep 7, 2024 · 2 comments

Comments

@McCzarny
Copy link

McCzarny commented Sep 7, 2024

Hello, I was trying to use the library to log backtraces so they could be later decoded using the binary. I've noticed that when Address Space Layout Randomization is enabled, I'm getting different address on each run:

$ ./build/Debug/boost-stacktrace-address-randomization 
 0# 0x000055655F1BB761 in ./build/Debug/boost-stacktrace-address-randomization
 1# 0x000055655F1BB7DE in ./build/Debug/boost-stacktrace-address-randomization
 2# 0x000055655F1BB7EE in ./build/Debug/boost-stacktrace-address-randomization
 3# 0x00007FDBA333FD90 in /lib/x86_64-linux-gnu/libc.so.6
 4# __libc_start_main in /lib/x86_64-linux-gnu/libc.so.6
 5# 0x000055655F1BB645 in ./build/Debug/boost-stacktrace-address-randomization

$ ./build/Debug/boost-stacktrace-address-randomization 
 0# 0x0000560C98DD3761 in ./build/Debug/boost-stacktrace-address-randomization
 1# 0x0000560C98DD37DE in ./build/Debug/boost-stacktrace-address-randomization
 2# 0x0000560C98DD37EE in ./build/Debug/boost-stacktrace-address-randomization
 3# 0x00007FAAD04E7D90 in /lib/x86_64-linux-gnu/libc.so.6
 4# __libc_start_main in /lib/x86_64-linux-gnu/libc.so.6
 5# 0x0000560C98DD3645 in ./build/Debug/boost-stacktrace-address-randomization

It seems that I can still decode the addresses if I get /proc/self/maps and subtract the base address from the generated stacktrace. I've noticed that there is a similar logic when addr2line flavor is enabled.

  • Is there a way to get backtrace with addresses matching the binary?
  • If not, is it worth to implement it? I could try to provide the implementation.

I'm aware that the work on the libarary may be limited because of C++23, but still there is a lot projects where it's easier to use a newer version of boost than upgrade a compiler.

@apolukhin
Copy link
Member

If not, is it worth to implement it? I could try to provide the implementation.

Yes, please give it a try

@McCzarny
Copy link
Author

@apolukhin So far the code change needed to make it work on unix is quite simple but I have some difficulties with deciding how to provide a way to enable the new behavior. I will appreciate any help here.

The thing is that it can work with every mode like _BASIC , _ADDR2LINE, _BACKTRACE, so I think that there is no point with creating a new library variant. The easiest option would be to define a new macro flag, but it would require a rebuild to change the way of address printing for projects that links to boost_stacktrace_*. Alternatively I could add a new type, which will require more code. What do you think?

McCzarny@ec6066f

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants