gccgo и LD_PRELOAD
package hello
import "fmt"
func Hello() {
fmt.Println("hello, world!")
}
gccgo -c hello.go -o libhello.so -shared
nm libhello.so
...
0000000000000000 T go.hello.Hello
0000000000000000 R go.hello.Hello$descriptor
package main
import "./hello"
func main() {
hello.Hello()
}
gccgo -g main.go -L. -lhello -ldl -o main
./main
hello, world!
это работает отлично. но когда я добавляю exec-файл, он не имеет динамической ссылки на libhello.so, почему??
ldd main
linux-vdso.so.1 => (0x00007ffd7bb88000)
libgo.so.4 => /lib64/libgo.so.4 (0x00007f134bca3000)
libm.so.6 => /lib64/libm.so.6 (0x00007f134b9a0000)
libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007f134b78a000)
libc.so.6 => /lib64/libc.so.6 (0x00007f134b3c8000)
/lib64/ld-linux-x86-64.so.2 (0x00007f134c9ce000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007f134b1ab000)
Как я могу написать хук LD_PRELOAD для функции угона (здесь go.hello.Hello?), потому что имя функции в C не может включать точку
#include <stdio.h>
#include <string.h>
#define __USE_GNU
#include <dlfcn.h>
static void (*hello) () = 0;
__attribute__ ((constructor))
void hello_init (void)
{
hello = dlsym (RTLD_NEXT, "go.hello.Hello");
}
void Hello()
{
int fd;
if (!hello)
return;
printf("pre hello\n");
hello();
printf("post hello\n");
}
LD_PRELOAD=./libxxx.so ./main
hello, world!