Skip to content
This repository has been archived by the owner on Aug 2, 2019. It is now read-only.

Latest commit

 

History

History
32 lines (21 loc) · 2.45 KB

README.md

File metadata and controls

32 lines (21 loc) · 2.45 KB

liblushan: Experimental Stack Introspection and Manipulation Library

题西林壁 Poem on the Wall of Xilin Temple
[]苏轼(1037-1101) by Su Shi (Song Dynasty, 1037-1101)
横看成岭侧成峰 From side, cliff walls, yet a peak from base.
远近高低各不同 Far, near, high, low, never the same place.
不识庐山真面目 Since I stand here within its midst,
只缘身在此山中 how can I know Mount Lu's true face?

This is a testbed of some of my works on stack state introspection and manipulation, where on-stack replacement (OSR) is just one special case. One goal is to show the significance of the SWAP-STACK operation so that the observer will observe the target stack "from outside" (as opposed to "observing the mountain from within", where you never find the truth), which greatly simplfies the conceptual model as well as implementation.

This project works on native (C) programs from stock compilers. It depends on the application binary interface (ABI) which includes the calling convention and the standard stack-unwinding mechanisms (involving the .eh_frame section or the compact unwind info).

Just type make in the src directory to compile all executable files. liblushan currently only works on x86_64 on Linux and Mac OS X. On Linux, libunwind needs to be installed.

There are some test programs in the src directory. Each test_*.c (and the test_*.S of the same base name if present) compiles to an executable file text_*.out.

  • src/test_realcallhandler.c demonstrates the ls_trap function which introspects the state of all registers at the call site, but does not currently perform SWAP-STACK.
  • src/test_remote_stack_*.c use libunwind to print stack traces of a swapped-away stack, and also performs stack manipulation (OSR) to force a function activation (stack frame) to return earlier.

License

MIT license. See LICENSE.

Author

Kunshan Wang [email protected]