資料介紹
1.字符設備驅動編寫流程
設備驅動程序可以使用模塊的方式動態(tài)加載到內(nèi)核中去。加載模塊的方式與以往的應用程序開發(fā)有很大的不同。以往在開發(fā)應用程序時都有一個main()函數(shù)作為程序的入口點,而在驅動開發(fā)時卻沒有main()函數(shù),模塊在調(diào)用insmod命令時被加載,此時的入口點是init_module()函數(shù),通常在該函數(shù)中完成設備的注冊。同樣,模塊在調(diào)用rmmod命令時被卸載,此時的入口點是cleanup_module()函數(shù),在該函數(shù)中完成設備的卸載。在設備完成注冊加載之后,用戶的應用程序就可以對該設備進行一定的操作,如open()、read()、write()等,而驅動程序就是用于實現(xiàn)這些操作,在用戶應用程序調(diào)用相應入口函數(shù)時執(zhí)行相關的操作,init_module()入口點函數(shù)則不需要完成其他如read()、write()之類功能。
上述函數(shù)之間的關系如圖11.3所示。

圖11.3 設備驅動程序流程圖
2.重要數(shù)據(jù)結構
用戶應用程序調(diào)用設備的一些功能是在設備驅動程序中定義的,也就是設備驅動程序的入口點,它是一個在《linux/fs.h》中定義的struct file_operations結構,這是一個內(nèi)核結構,不會出現(xiàn)在用戶空間的程序中,它定義了常見文件I/O函數(shù)的入口,如下所示:
struct file_operations
{
loff_t (*llseek) (struct file *, loff_t, int);
ssize_t (*read) (struct file *filp,
char *buff, size_t count, loff_t *offp);
ssize_t (*write) (struct file *filp,
const char *buff, size_t count, loff_t *offp);
int (*readdir) (struct file *, void *, filldir_t);
unsigned int (*poll) (struct file *, struct poll_table_struct *);
int (*ioctl) (struct inode *,
struct file *, unsigned int, unsigned long);
int (*mmap) (struct file *, struct vm_area_struct *);
int (*open) (struct inode *, struct file *);
int (*flush) (struct file *);
int (*release) (struct inode *, struct file *);
int (*fsync) (struct file *, struct dentry *);
int (*fasync) (int, struct file *, int);
int (*check_media_change) (kdev_t dev);
int (*revalidate) (kdev_t dev);
int (*lock) (struct file *, int, struct file_lock *);
};
這里定義的很多函數(shù)是否跟第6章中的文件I/O系統(tǒng)調(diào)用類似?其實當時的系統(tǒng)調(diào)用函數(shù)通過內(nèi)核,最終調(diào)用對應的struct file_operations結構的接口函數(shù)(例如,open()文件操作是通過調(diào)用對應文件的file_operations結構的open函數(shù)接口而被實現(xiàn))。當然,每個設備的驅動程序不一定要實現(xiàn)其中所有的函數(shù)操作,若不需要定義實現(xiàn)時,則只需將其設為NULL即可。
struct inode結構提供了關于設備文件/dev/driver(假設此設備名為driver)的信息,struct file結構提供關于被打開的文件信息,主要用于與文件系統(tǒng)對應的設備驅動程序使用。struct file結構較為重要,這里列出了它的定義:
struct file
{
mode_t f_mode;/*標識文件是否可讀或可寫,F(xiàn)MODE_READ或FMODE_WRITE*/
dev_t f_rdev; /* 用于/dev/tty */
off_t f_pos; /* 當前文件位移 */
unsigned short f_flags; /* 文件標志,如O_RDONLY、O_NONBLOCK和O_SYNC */
unsigned short f_count; /* 打開的文件數(shù)目 */
unsigned short f_reada;
struct inode *f_inode; /*指向inode的結構指針 */
struct file_operations *f_op;/* 文件索引指針 */
};
3.設備驅動程序主要組成
(1)早期版本的字符設備注冊。
早期版本的設備注冊使用函數(shù)register_chrdev(),調(diào)用該函數(shù)后就可以向系統(tǒng)申請主設備號,如果register_chrdev()操作成功,設備名就會出現(xiàn)在/proc/devices文件里。在關閉設備時,通常需要解除原先的設備注冊,此時可使用函數(shù)unregister_chrdev(),此后該設備就會從/proc/devices里消失。其中主設備號和次設備號不能大于255。
當前不少的字符設備驅動代碼仍然使用這些早期版本的函數(shù)接口,但在未來內(nèi)核的代碼中,將不會出現(xiàn)這種編程接口機制。因此應該盡量使用后面講述的編程機制。
register_chrdev()函數(shù)格式如表11.1所示。
表11.1 register_chrdev()函數(shù)語法要點
所需頭文件#include 《linux/fs.h》
函數(shù)原型int register_chrdev(unsigned int major, const char *name,struct file_operations *fops)
函數(shù)傳入值major:設備驅動程序向系統(tǒng)申請的主設備號,如果為0則系統(tǒng)為此驅動程序動態(tài)地分配一個主設備號
設備驅動程序可以使用模塊的方式動態(tài)加載到內(nèi)核中去。加載模塊的方式與以往的應用程序開發(fā)有很大的不同。以往在開發(fā)應用程序時都有一個main()函數(shù)作為程序的入口點,而在驅動開發(fā)時卻沒有main()函數(shù),模塊在調(diào)用insmod命令時被加載,此時的入口點是init_module()函數(shù),通常在該函數(shù)中完成設備的注冊。同樣,模塊在調(diào)用rmmod命令時被卸載,此時的入口點是cleanup_module()函數(shù),在該函數(shù)中完成設備的卸載。在設備完成注冊加載之后,用戶的應用程序就可以對該設備進行一定的操作,如open()、read()、write()等,而驅動程序就是用于實現(xiàn)這些操作,在用戶應用程序調(diào)用相應入口函數(shù)時執(zhí)行相關的操作,init_module()入口點函數(shù)則不需要完成其他如read()、write()之類功能。
上述函數(shù)之間的關系如圖11.3所示。

圖11.3 設備驅動程序流程圖
2.重要數(shù)據(jù)結構
用戶應用程序調(diào)用設備的一些功能是在設備驅動程序中定義的,也就是設備驅動程序的入口點,它是一個在《linux/fs.h》中定義的struct file_operations結構,這是一個內(nèi)核結構,不會出現(xiàn)在用戶空間的程序中,它定義了常見文件I/O函數(shù)的入口,如下所示:
struct file_operations
{
loff_t (*llseek) (struct file *, loff_t, int);
ssize_t (*read) (struct file *filp,
char *buff, size_t count, loff_t *offp);
ssize_t (*write) (struct file *filp,
const char *buff, size_t count, loff_t *offp);
int (*readdir) (struct file *, void *, filldir_t);
unsigned int (*poll) (struct file *, struct poll_table_struct *);
int (*ioctl) (struct inode *,
struct file *, unsigned int, unsigned long);
int (*mmap) (struct file *, struct vm_area_struct *);
int (*open) (struct inode *, struct file *);
int (*flush) (struct file *);
int (*release) (struct inode *, struct file *);
int (*fsync) (struct file *, struct dentry *);
int (*fasync) (int, struct file *, int);
int (*check_media_change) (kdev_t dev);
int (*revalidate) (kdev_t dev);
int (*lock) (struct file *, int, struct file_lock *);
};
這里定義的很多函數(shù)是否跟第6章中的文件I/O系統(tǒng)調(diào)用類似?其實當時的系統(tǒng)調(diào)用函數(shù)通過內(nèi)核,最終調(diào)用對應的struct file_operations結構的接口函數(shù)(例如,open()文件操作是通過調(diào)用對應文件的file_operations結構的open函數(shù)接口而被實現(xiàn))。當然,每個設備的驅動程序不一定要實現(xiàn)其中所有的函數(shù)操作,若不需要定義實現(xiàn)時,則只需將其設為NULL即可。
struct inode結構提供了關于設備文件/dev/driver(假設此設備名為driver)的信息,struct file結構提供關于被打開的文件信息,主要用于與文件系統(tǒng)對應的設備驅動程序使用。struct file結構較為重要,這里列出了它的定義:
struct file
{
mode_t f_mode;/*標識文件是否可讀或可寫,F(xiàn)MODE_READ或FMODE_WRITE*/
dev_t f_rdev; /* 用于/dev/tty */
off_t f_pos; /* 當前文件位移 */
unsigned short f_flags; /* 文件標志,如O_RDONLY、O_NONBLOCK和O_SYNC */
unsigned short f_count; /* 打開的文件數(shù)目 */
unsigned short f_reada;
struct inode *f_inode; /*指向inode的結構指針 */
struct file_operations *f_op;/* 文件索引指針 */
};
3.設備驅動程序主要組成
(1)早期版本的字符設備注冊。
早期版本的設備注冊使用函數(shù)register_chrdev(),調(diào)用該函數(shù)后就可以向系統(tǒng)申請主設備號,如果register_chrdev()操作成功,設備名就會出現(xiàn)在/proc/devices文件里。在關閉設備時,通常需要解除原先的設備注冊,此時可使用函數(shù)unregister_chrdev(),此后該設備就會從/proc/devices里消失。其中主設備號和次設備號不能大于255。
當前不少的字符設備驅動代碼仍然使用這些早期版本的函數(shù)接口,但在未來內(nèi)核的代碼中,將不會出現(xiàn)這種編程接口機制。因此應該盡量使用后面講述的編程機制。
register_chrdev()函數(shù)格式如表11.1所示。
表11.1 register_chrdev()函數(shù)語法要點
所需頭文件#include 《linux/fs.h》
函數(shù)原型int register_chrdev(unsigned int major, const char *name,struct file_operations *fops)
函數(shù)傳入值major:設備驅動程序向系統(tǒng)申請的主設備號,如果為0則系統(tǒng)為此驅動程序動態(tài)地分配一個主設備號
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- Linux設備驅動開發(fā)詳解 51次下載
- 嵌入式Linux設備驅動程序開發(fā)基礎知識總結免費下載 13次下載
- 《Linux設備驅動開發(fā)詳解》第6章、字符設備驅動 23次下載
- 《Linux設備驅動開發(fā)詳解》第8章、Linux設備驅動中的阻塞與非阻塞IO 9次下載
- 《Linux設備驅動開發(fā)詳解》第9章、Linux設備驅動中的異步通知與異步IO 0次下載
- 《Linux設備驅動開發(fā)詳解》第13章、Linux塊設備驅動 18次下載
- VxWorks設備驅動之字符設備驅動詳解 7次下載
- Linux設備驅動開發(fā)之設備驅動簡述 0次下載
- Linux驅動開發(fā)之塊設備驅動 0次下載
- 深度解析字符設備驅動模型 0次下載
- 基于linux系統(tǒng)的字符設備驅動研究與設計_王森 1次下載
- Linux設備驅動開發(fā)入門
- 嵌入式Linux字符設備驅動的設計與應用
- 嵌入式Linux字符設備驅動的設計與應用
- 嵌入式Linux設備驅動開發(fā)
- Linux 驅動開發(fā)與應用開發(fā),你知道多少? 871次閱讀
- Linux內(nèi)核驅動與單個PCI設備的綁定和解綁定 1730次閱讀
- i.MX6ULL|字符設備驅動開發(fā)實踐 707次閱讀
- i.MX6ULL|字符設備驅動流程深究 753次閱讀
- 關于Linux字符設備基本類型 1627次閱讀
- 如何寫一個Linux設備驅動程序 4532次閱讀
- Linux設備驅動開發(fā)的基本知識 4393次閱讀
- 米爾科技Linux設備驅動研究淺談 2035次閱讀
- 米爾科技LINUX設備驅動程序教程 2103次閱讀
- 基于PXA255開發(fā)板外圍字符設備的嵌入式Linux字符設備驅動設計與應用 1199次閱讀
- 基于嵌入式Linux內(nèi)核的系統(tǒng)設備驅動程序開發(fā)設計 1209次閱讀
- 想要駕馭Linux驅動開發(fā),必須深刻理解Linux總線設備驅動框架 1w次閱讀
- 嵌入式Linux驅動開發(fā)基礎總結(上篇) 8518次閱讀
- 基于FPGA嵌入式系統(tǒng)的設備驅動開發(fā) 2338次閱讀
- 關于Linux設備驅動中input子系統(tǒng)的介紹 2711次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關電源基礎知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
電子發(fā)燒友App






創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論