Невозможно получить трассировку стека с corefile из подпрограммы cgo при использовании golang
Я использую Golang и CGO. Когда мой код C поднимает assert()
Я не могу увидеть трассировку стека кода C при использовании cgo
,
Вместо этого я вижу трассировку стека среды выполнения golang, которая поймала утверждение.
Вот пример моего кода C
#include <stdio.h>
#include <pthread.h>
#include <assert.h>
#include <string.h>
void fn2(char *arg)
{
int stackvar2 = 256;
printf("Argument %s\n", arg);
assert(1 == 2);
}
void fn1(int arg)
{
int stackvar3 = 512;
char var[256];
strcpy(var, "deadbeef");
fn2(var);
}
void *thread(void *arg)
{
printf("Hello from the thread... going in for an assert\n");
fn1(1092);
return NULL;
}
void hello_world(char *str)
{
pthread_t tid;
printf("Hello World from C and here the str is from Go: %s\n", str);
pthread_create(&tid, NULL, thread, NULL);
sleep(100000);
}
Here is my Go code
package main
/*
extern void hello_world(char *str);
#cgo LDFLAGS: -L. -lhello
#cgo CFLAGS: -g3
*/
import "C"
import (
_ "fmt"
)
func main() {
str := "From Golang"
cStr := C.CString(str)
C.hello_world(cStr)
select {}
}
И вот мой Makefile
all:
gcc -g3 -O0 -c hello.c
ar cru libhello.a hello.o
go build hello.go
clean:
rm -f *.o hello
2 ответа
Решение
На самом деле мне нужно добавить это в мой код go: signal.Ignore(syscall.SIGABRT). Это позволяет мне видеть трассировку стека кода C, который упал.
Помимо очевидной проверки ulimit -c
, запустите программу go с GOTRACEBACK=crash
, Это распечатает больше информации и позволит программе выйти с SIGABRT
вызвать дамп ядра.