《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > Linux內(nèi)核模塊和驅(qū)動(dòng)程序的編寫(xiě)
Linux內(nèi)核模塊和驅(qū)動(dòng)程序的編寫(xiě)
摘要: Linux中的大部分驅(qū)動(dòng)程序,是以模塊的形式編寫(xiě)的.這些驅(qū)動(dòng)程序源碼可以修改到內(nèi)核中,也可以把他們編譯成模塊形勢(shì),在需要的時(shí)候動(dòng)態(tài)加載.
關(guān)鍵詞: 軟件 Linux
Abstract:
Key words :

Linux中的大部分驅(qū)動(dòng)程序,是以模塊的形式編寫(xiě)的.這些驅(qū)動(dòng)程序源碼可以修改到內(nèi)核中,也可以把他們編譯成模塊形勢(shì),在需要的時(shí)候動(dòng)態(tài)加載.

一個(gè)典型的驅(qū)動(dòng)程序,大體上可以分為這么幾個(gè)部分:

1,、注冊(cè)設(shè)備

在系統(tǒng)初啟,或者模塊加載時(shí)候,必須將設(shè)備登記到相應(yīng)的設(shè)備數(shù)組,并返回設(shè)備的主驅(qū)動(dòng)號(hào),例如:對(duì)快設(shè)備來(lái)說(shuō)調(diào)用refister_blkdec()將設(shè)備添加到數(shù)組blkdev中.并且獲得該設(shè)備號(hào).并利用這些設(shè)備號(hào)對(duì)此數(shù)組進(jìn)行索引.對(duì)于字符驅(qū)動(dòng)設(shè)備來(lái)說(shuō),要使用module_register_chrdev()來(lái)獲得祝設(shè)備的驅(qū)動(dòng)號(hào).然后對(duì)這個(gè)設(shè)備的所有調(diào)用都用這個(gè)設(shè)備號(hào)來(lái)實(shí)現(xiàn)

2、定義功能函數(shù)

對(duì)于每一個(gè)驅(qū)動(dòng)函數(shù)來(lái)說(shuō).都有一些和此設(shè)備密切相關(guān)的功能函數(shù).那最常用的塊設(shè)備或者字符設(shè)備來(lái)說(shuō).都存在著諸如 open() read() write() ioctrol()這一類的操作.當(dāng)系統(tǒng)社用這些調(diào)用時(shí).將自動(dòng)的使用驅(qū)動(dòng)函數(shù)中特定的模塊.來(lái)實(shí)現(xiàn)具體的操作.而對(duì)于特定的設(shè)備.上面的系統(tǒng)調(diào)用對(duì)應(yīng)的函數(shù)是一定的.

如:在塊驅(qū)動(dòng)設(shè)備中.當(dāng)系統(tǒng)試圖讀取這個(gè)設(shè)備(即調(diào)用read()時(shí)),就會(huì)運(yùn)行驅(qū)動(dòng)程序中的block_read() 這個(gè)函數(shù). 打開(kāi)新設(shè)備時(shí)會(huì)調(diào)用這個(gè)設(shè)備驅(qū)動(dòng)程序的device_open() 這個(gè)函數(shù).

3,、卸載模塊

在不用這個(gè)設(shè)備時(shí),可以將他卸載.主要是從/proc 中取消這個(gè)設(shè)備的特殊文件.可用特定的函數(shù)實(shí)現(xiàn).

下面我們列舉一個(gè)字符設(shè)備驅(qū)動(dòng)程序的框架.來(lái)說(shuō)明這個(gè)過(guò)程.

/* a module of a character device */

/* some include files*/

#include "param.h"

#include "user.h"

#include "tty.h"

#include "dir.h"

#include "fs.h"

/* the include files modules need*/

#include "linux/kernel.h"

#include "linux/module.h"

#if CONFIG_MODBERSIONS==1

define MODBERSIONS

#include" linux.modversions.h"

#endif

#difine devicename mydevice

/* the init funcion*/

int init_module()

{

int tag=module_register_chrdev(0,mydevice,&Fops);

if (tag<0)

{

printk("the device init is erro!\n");

return 1;

}

return 0;

}

/*the funcion which the device will be used */

int device_open ()

{

…….

}

int device_read ()

{

…….

}

int device_write ()

{

…….

}

int device_ioctl ()

{

…….

}

……

/* the deltter function of this module*/

int cleanup_module()

{

int re=module_unregister_chrdev(tag,mydevice);

if( re<0)

{

printk("erro unregister the module !!\n");

return 1;

}

return 0;

}

此內(nèi)容為AET網(wǎng)站原創(chuàng),,未經(jīng)授權(quán)禁止轉(zhuǎn)載。