6

我正在尝试根据以下答案将结构从 LKM 发送到用户区: Netlink Sockets in C using the 3.X linux kernel

答案本身的代码是完全可编译的,但是当我尝试发送struct而不是 achar *时,我在用户空间中遇到了段错误。

这是我改变的:

netlinkKernel.c

我加:

typedef struct test{
    int a;
    char *b;
} s_test;

并更换

char *msg = "Hello from kernel";

---

msg_size = strlen(msg);

---

strncpy(nlmsg_data(nlh),msg,msg_size);

s_test x;
x.a = 42;
x.b = "The answer";

---

msg_size(sizeof(x));

---

memcpy(nlmsg_data(nlh), &x, msg_size);

netlinkUser.c

我添加相同的结构并替换

printf("Received message payload: %s\n", (char *)NLMSG_DATA(nlh));

s_test *x = (s_test *)NLMSG_DATA(nlh);
printf("Received message payload: %d - %s\n", x->a, x->b);

问题出在哪里?

4

1 回答 1

5

这是您的问题:您的结构包含指向内核空间中其他内存的指针 ( char *b)。但是,您发送到用户空间的只是结构中的指针,而不是其他内存位("The answer")。此外,即使你还发送了额外的内存,b仍然是一个指向内核虚拟地址的指针。

最好的办法是制作 ba char 数组并将数据复制到 b 中。

在进程之间或进程与内核之间发送的数据内部的指针通常是非常有问题的。使用指针结构的系统调用,例如man 2 recvmsg,不只是在用户空间和内核之间逐字发送指针,相反,内核对用户空间进行单独访问以解析每个指针。

于 2013-09-22T16:59:16.123 回答