当前位置: 代码迷 >> 综合 >> 操作系统第二章实验:Linux 内核模块
  详细解决方案

操作系统第二章实验:Linux 内核模块

热度:5   发布时间:2024-02-26 18:24:09.0

操作系统第二章实验:Linux 内核模块

#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/list.h>
#include <linux/types.h>struct birthday
{
    int day;int month;int year;struct list_head list;
};static LIST_HEAD(birthday_list);int simple_init(void)
{
    struct birthday *p1,*p2,*p3,*p4,*p5;p1 = kmalloc(sizeof(*p1),GFP_KERNEL);p1->day = 2;p1->month = 8;p1->year = 1995;INIT_LIST_HEAD(&p1->list);	p2 = kmalloc(sizeof(*p2),GFP_KERNEL);p2->day = 3;p2->month = 9;p2->year = 1996;INIT_LIST_HEAD(&p2->list);p3 = kmalloc(sizeof(*p3),GFP_KERNEL);p3->day = 4;p3->month = 10;p3->year = 1997;INIT_LIST_HEAD(&p3->list);p4 = kmalloc(sizeof(*p4),GFP_KERNEL);p4->day = 5;p4->month = 11;p4->year = 1998;INIT_LIST_HEAD(&p4->list);p5 = kmalloc(sizeof(*p5),GFP_KERNEL);p5->day = 6;p5->month = 12;p5->year = 1999;INIT_LIST_HEAD(&p5->list);list_add_tail(&p1->list,&birthday_list);list_add_tail(&p2->list,&birthday_list);list_add_tail(&p3->list,&birthday_list);list_add_tail(&p4->list,&birthday_list);list_add_tail(&p5->list,&birthday_list);struct birthday *ptr;list_for_each_entry(ptr,&birthday_list,list){
    printk(KERN_INFO "day: %d\tmonth: %d\tyear: %d\n",ptr->day,ptr->month,ptr->year);}printk(KERN_INFO "Loading Module\n");return 0;
}void simple_exit(void)
{
    struct birthday *ptr,*next;list_for_each_entry_safe(ptr,next,&birthday_list,list){
    list_del(&ptr->list);kfree(ptr);}printk(KERN_INFO "Removing Module\n");
}module_init(simple_init);
module_exit(simple_exit);MODULE_LICENSE("GPL");
MODULE_DESCRIPTION("Simple Module");
MODULE_AUTHOR("SGG");

按照实验要求一步一步来,挺简单的,加油!

Continue to improve…

  相关解决方案