![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /opt/rh/gcc-toolset-11/root/usr/share/systemtap/examples/memory/ |
#!/opt/rh/gcc-toolset-11/root/usr/bin/stap global bt%[100] probe process("/lib*/libc.so.*").function("free") { // we use @defined($mem) here because on 64 bit systems, the // wildcard search takes us through both 64 bit and 32 bit // libc (which doesn't have debuginfo), this means the probe // point resolved from the 32 bit library has no context info if (@defined($mem)) { bt[execname(),tid(),$mem,sprint_ubacktrace()] <<< local_clock_ns() } // Any monotonically increasing expression would do. // With some arbitrary expression or constant instead, // at worst we get the last 100ish results out of order. } probe end,error { foreach ([e,t,p,b] in bt @max+) // iterate in increasing index order printf("free #%d: %s[%d], pointer %p:\n%s\n\n", @max(bt[e,t,p,b]), e, t, p, b) }