将系统调用添加到linux内核

时间:2018-04-05 13:59:14

标签: c linux linked-list linux-kernel kernel

我是使用内核的新手。 我想在我的内核中添加一个链表,我尝试像这个链接一样修复它:Linux Kernel Programming–Linked List

这是我添加到sys.c的代码:

系统调用防御:

SYSCALL_DEFINE1(init_process_list,pid_t,ppid)
{
 LIST_HEAD(processList);
 struct scallNode* newNode;
 newNode = kmalloc(sizeof(*newNode), GFP_KERNEL);
 newNode->ID = ppid;
 INIT_LIST_HEAD(&newNode -> list);
 list_add_tail(&newNode -> list , &processList.list);
 printk(KERN_INFO "INIT PROCESS UID: %u\n", ppid);
 return 0; 
}

和我的链表结构:

struct scallNode{
    int ID;
    struct file_struct ffs;
    struct task_struct ts;
    struct list_head list;
};
struct scallNode processList;

当我编译内核时,我看到了这个错误:

error: ‘struct list_head’ has no member named ‘list’   list_add_tail(&newNode -> list , &processList.list);

感谢您的回复。

该错误消失了,但另一个仍然存在。

kernel/sys.c:2136:24: error: field ‘fs’ has incomplete type      struct file_struct fs;

再次感谢您的回复。

3 个答案:

答案 0 :(得分:0)

我从未做过任何内核编程。但据我所知,下面的内存分配不正确: -

newNode = kmalloc(sizeof(*newNode), GFP_KERNEL);

我认为应该是这样的: -

newNode = (struct scallNode *)kmalloc(sizeof(struct scallNode), GFP_KERNEL);

答案 1 :(得分:0)

终于回答了结果。

list_add_tail(&newNode -> list , &processList.list);中的

&processList最常用,而不是&processList.list

list_add_tail查找processList本身的列表。

答案 2 :(得分:0)

list_add_tail功能

void list_add_tail(struct list_head *new, struct list_head *head);

第二个参数应该是指向struct list_head的指针,所以就这样使用:

list_add_tail(&newNode -> list , &processList);