首先我們回想一下注冊(cè)雜項(xiàng)設(shè)備的三大流程,我們?cè)?Windows 上面新建 misc.c 文件,并用 sourceinsight 打開(kāi)。我們可以將上次編寫(xiě)的 helloworld.c 里面的代碼拷貝到 misc.c 文件,并修改為如下圖所示: ![]() 添加頭文件 /*注冊(cè)雜項(xiàng)設(shè)備頭文件*/ #include /*注冊(cè)設(shè)備節(jié)點(diǎn)的文件結(jié)構(gòu)體*/ #include 填充 miscdevice 結(jié)構(gòu)體 struct miscdevice misc_dev = { .minor = MISC_DYNAMIC_MINOR, .name = "hello_misc", .fops = &misc_fops, }; 上述代碼第 2 行的 minor 為 MISC_DYNAMIC_MINOR,miscdevice 核心層會(huì)自動(dòng)找一個(gè)空閑的次設(shè)備號(hào), 否則用 minor 指定的次設(shè)備號(hào)。上述代碼第 3 行 name 是設(shè)備的名稱,我們自定義為"hello_misc" 填充 file_operations 結(jié)構(gòu)體 struct file_operations misc_fops={ .owner = THIS_MODULE }; THIS_MODULE 宏是什么意思呢?它在 include/linux/module.h 里的定義是 #define THIS_MODULE (&__this_module) 它是一個(gè) struct module 變量,代表當(dāng)前模塊,可以通過(guò) THIS_MODULE 宏來(lái)引用模塊的 struct module 結(jié)構(gòu),比如使用 THIS_MODULE->state 可以獲得當(dāng)前模塊的狀態(tài)。這個(gè) owner 指針指向的就是你的模塊。 注冊(cè)雜項(xiàng)設(shè)備并生成設(shè)備節(jié)點(diǎn) 在 misc_init()函數(shù)中填充 misc_register()函數(shù)注冊(cè)雜項(xiàng)設(shè)備,并判斷雜項(xiàng)設(shè)備是否注冊(cè)成功。 static int misc_init(void){ int ret; ret = misc_register(&misc_dev); //注冊(cè)雜項(xiàng)設(shè)備 if(ret<0) //判斷雜項(xiàng)設(shè)備是否注冊(cè)成功 { printk("misc registe is error \n"); //打印雜項(xiàng)設(shè)備注冊(cè)失敗 } printk("misc registe is succeed \n"); //打印雜項(xiàng)設(shè)備注冊(cè)成功 return 0; } 在 misc_exit()函數(shù)中填充 misc_deregister()函數(shù)注銷雜項(xiàng)設(shè)備。 static void misc_exit(void){ misc_deregister(&misc_dev); //注銷雜項(xiàng)設(shè)備 printk("misc gooodbye! \n"); //打印雜項(xiàng)設(shè)備注銷成功 } 完整的代碼如下圖所示: /* * @Descripttion: 最簡(jiǎn)單的雜項(xiàng)設(shè)備驅(qū)動(dòng) * @version: 1.0 * @Author: topeet */ #include #include #include #include struct file_operations misc_fops = { //文件操作集 .owner = THIS_MODULE}; struct miscdevice misc_dev = { //雜項(xiàng)設(shè)備結(jié)構(gòu)體 .minor = MISC_DYNAMIC_MINOR, //動(dòng)態(tài)申請(qǐng)的次設(shè)備號(hào) .name = "hello_misc", //雜項(xiàng)設(shè)備名字是 hello_misc .fops = &misc_fops, //文件操作集 }; static int misc_init(void) { //在初始化函數(shù)中注冊(cè)雜項(xiàng)設(shè)備 int ret; ret = misc_register(&misc_dev); if (ret < 0) { printk("misc registe is error \n"); } printk("misc registe is succeed \n"); return 0; } static void misc_exit(void) { //在卸載函數(shù)中注銷雜項(xiàng)設(shè)備 misc_deregister(&misc_dev); printk(" misc gooodbye! \n"); } module_init(misc_init); module_exit(misc_exit); MODULE_LICENSE("GPL"); 現(xiàn)在最簡(jiǎn)單的雜項(xiàng)設(shè)備的驅(qū)動(dòng)就寫(xiě)完了,那么接下來(lái)我們可以把這個(gè)驅(qū)動(dòng)編譯一下,然后放到我們的 開(kāi)發(fā)板上面運(yùn)行。我們編譯驅(qū)動(dòng),可以將它編譯進(jìn)內(nèi)核里面,也可以將它編譯成模塊。 |