我是使用内核的新手。 我想在我的内核中添加一个链表,我尝试像这个链接一样修复它: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;
再次感谢您的回复。
答案 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);