亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 服務器 > Linux服務器 > 正文

Linux內核設備驅動之高級字符設備驅動筆記整理

2024-09-05 23:05:26
字體:
來源:轉載
供稿:網友
/****************** * 高級字符設備驅動 ******************/

(1)ioctl

除了讀取和寫入設備外,大部分驅動程序還需要另外一種能力,即通過設備驅動程序執行各種類型的硬件控制。比如彈出介質,改變波特率等等。這些操作通過ioctl方法支持,該方法實現了同名的系統調用。

在用戶空間,ioctl系統調用的原型是:

  • int ioctl(int fd, unsigned long cmd, ...);
  • fd: 打開的設備文件描述符
  • cmd: 命令
  • 第三個參數:根據不同的命令,可以是整數或指針,也可以沒有。
  • 采用"..."的方式只是用于避免編譯器報錯。

驅動程序的ioctl方法原型和用戶空間的版本有一些不同:

int (*ioctl) (struct inode *inode,    
      struct file *filp, 
      unsigned int cmd,
      unsigned long arg);
inode/filp: 對應用戶空間的fd
cmd: 對應用戶空間傳來的cmd
arg: 對應傳來的cmd參數

大多數ioctl的實現中都包括一個switch語句,用于根據cmd參數選擇對應的操作。用戶空間和內核空間的命令號要一致。

(2)選擇ioctl的命令號

在編寫ioctl的代碼之前,要選擇對應不同命令的編號。不能簡單地從0或1開始選擇編號,因為linux要求這個命令號應該在系統范圍內唯一。linux內核采用約定方法為驅動程序選擇ioctl號,可以參考include/asm/ioctl.h和Documentation/ioctl-number.txt。

一個ioctl號為32位,linux將其分成4個部分,構建一個ioctl號碼所需要的宏都定義在<linux/ioctl.h>:

  • type 8位幻數。其實就是為你的驅動選定一個號碼。參考ioctl-number.txt
  • number 8位序數。
  • direction 2位。定義了數據的傳輸方向。如_IOC_NONE(沒有數據傳輸),_IOC_READ|_IOC_WRITE(雙向數據傳輸)。注意這個方向是對用戶而言的,所以IOC_READ意味著從設備讀取數據,驅動應該向用戶空間寫入數據。
  • size 14位。所涉及的用戶數據大小。

可以采用<linux/ioctl.h>中的宏構建一個ioctl號

  • _IO(type, nr)
  • _IOR(type,nr,datatype)
  • _IOW(type,nr,datatype)

返回值

對于系統調用來說,正的返回值是首保護的,而負值被認為是一個錯誤,并被用來設置用戶空間的error變量。如果在調用ioctl方法時傳入了沒有定義的ioctl號,則系統返回的錯誤值為-ENVAL和-ENOTTY

(3)阻塞和非阻塞型操作

對于read和write等操作,默認的操作是阻塞型的,其特性是:

*如果一個進程調用了read但還沒有數據可讀,則此進程必須阻塞。數據到達時進程被喚醒,并把數據返回給調用者,即使數據數目少于count參數指定的數據也會返回。

*如果一個進程調用了write但緩沖區沒有空間,則此進程必須阻塞,而且必須休眠在與讀進程不同的等待隊列上。當向硬件設備寫入一些數據,從而騰出了部分輸出緩沖區后,進程即被喚醒,write調用成功。

有時我們希望改變這一特性,將其改為非阻塞型的,這樣,無論設備是否有數據可讀寫,read/write方法都馬上返回。

如果希望設定某個文件是非阻塞的,則應設定filp->f_flags的O_NONBLOCK標志。處理非阻塞型文件時,應用程序調用stdio函數必須非常小心,因為很容易把一個非阻塞型的返回誤認為是EOF,所以必須始終檢查errno。

(4)異步通知

a.異步通知的作用

大多數時候阻塞型和非阻塞型操作的組合以及select方法可以有效查詢設備,但有時候用這種技術效率就不高了。在面對某些隨機或很少出現的情況時(如通過鍵盤輸入CTRL+C),則需要采用異步通知(asynchronous notification)。

b.用戶空間程序如何啟動異步通知

為了啟動文件的異步通知機制,用戶程序必須執行兩個步驟:

  • 01.指定一個進程作為設備文件的 "屬主(owner)"。當進程使用fcntl系統調用執行F_SETOWN命令時,屬主進程的進程ID號就被保存在 filp->f_owner中。這一步是必需的,目的是讓內核知道該通知誰。
  • 02.為了真正啟動異步通知機制,用戶程序還必須在設備中設置FASYNC標志,這是通過fchtl命令F_SETFL完成的。執行完這兩步后,設備文件就可以在新數據到達時請求發送一個SIGIO信號。該信號被送到存放在file->f_owner中的進程(如果是負值就是進程組)。不是所有的設備都支持異步通知,應用程序通常假設只有套接字和終端才有異步通知能力.

(5)驅動程序中如何實現異步通知

a.用戶空間操作在內核的對應

  • 01.當設定F_SETOWN時,對file->f_owner賦值
  • 02.執行F_SETFL以啟動FASYNC時,調用驅動程序的fasync方法。只要filp->f_flags中的FASYNC標志(文件打開時,默認為清除)發生了變化,就會調用該方法。
  • 03.當數據到達時,由內核發送一個SIGIO信號給所有注冊為異步通知的進程

b.在設備結構體中加入fasync_struct的指針

該結構在<linux/fs.h>中定義:

struct fasync_struct {int magic;int fa_fd;struct fasync_struct *fa_next;struct file *fa_file;};

c.驅動要調用的兩個函數

這兩個函數在<linux/fs.h>中聲明。

定義在/fs/fcntl.c中。

原型如下:

  • 01. int fasync_helper(int fd, struct file *filp, int mode, struct fasync_struct **fa);
  • 02. void kill_fasync(struct fasync_struct **fa, int sig, int band);

當一個打開文件的FASYNC標志被修改,調用fasync_helper以便從相關的進程列表中增加或刪除文件,而kill_fasync在數據到達時通知所有相關進程。

d.例子

01.在設備類型中定義fasync_struct動態數據結構

struct my_pipe {  struct fasync_struct *async_queue; /* 異步讀取結構 */......};

02.驅動中的fasync函數調用fasync_helper

int my_fasync(fasync_file fd, struct file *filp, int mode){  my_pipe *dev = filp->private_data;  return fasync_helper(fd, filp, mode, &dev->async_queue);}

03.符合異步通知條件時調用kill_fasync

異步通知的是一個讀進程,所以要用write發送kill_fasync。

調用kill_fasync向所有注冊在設備上的異步隊列async_queue中的進程發送信號SIGIO。

ssize_t my_write(struct file *filp, const char *buf, size_t count,        loff_t *f_pos){......if (dev->async_queue)    kill_fasync(&dev->async_queue, SIGIO, POLL_IN);     ......}

04.關閉文件時必須調用fasync方法

當關閉文件時必須調用fasync方法,以便從活動的異步讀進程列表中刪除該文件。

在release中調用:scull_p_fasync(-1, filp, 0);

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到服務器教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区丝袜高跟鞋图片| 亚洲欧美国产精品va在线观看| 色偷偷9999www| 久久精品在线视频| 欧美亚洲国产精品| 91精品在线看| 国产精品美女呻吟| 九九综合九九综合| 亚洲第一在线视频| 精品久久久精品| 国产一区二区三区日韩欧美| 久久免费国产视频| 久久亚洲国产成人| 亚洲另类xxxx| 国产综合香蕉五月婷在线| 亚洲女成人图区| 97免费在线视频| 色综合天天综合网国产成人网| 中文字幕日韩精品在线| 北条麻妃在线一区二区| 精品电影在线观看| 在线观看免费高清视频97| 国产精品美女呻吟| 日本高清+成人网在线观看| 国产精品视频色| 久久精品国产亚洲一区二区| 91成人性视频| 国产一区二区三区高清在线观看| 96精品视频在线| 亚洲国产天堂网精品网站| 久久精品亚洲94久久精品| 久久久国产91| 国产精品一区久久久| 最新国产精品拍自在线播放| 亚洲资源在线看| 黑人精品xxx一区| 色综合久久久久久中文网| 91精品国产高清| 亚洲综合av影视| 91禁国产网站| 亚洲偷熟乱区亚洲香蕉av| 亚洲人精选亚洲人成在线| 色悠久久久久综合先锋影音下载| 久久久电影免费观看完整版| 久久高清视频免费| 国产精品视频地址| 国产精品高清网站| 最好看的2019的中文字幕视频| 91精品国产91久久久久久最新| 91国产精品视频在线| 国产欧洲精品视频| 久久久久国产精品www| 国产精品久久97| 深夜成人在线观看| 日韩视频免费看| 久久久久久久久电影| 国产精品网址在线| 欧美性videos高清精品| 日韩欧美高清在线视频| 久久亚洲综合国产精品99麻豆精品福利| 国产欧美久久久久久| 国产成人一区二区| 51精品国产黑色丝袜高跟鞋| 色婷婷亚洲mv天堂mv在影片| 久久久av亚洲男天堂| 欧美大尺度电影在线观看| 成人免费看片视频| 在线丨暗呦小u女国产精品| 国产偷亚洲偷欧美偷精品| 高清欧美性猛交xxxx黑人猛交| 欧美日韩亚洲成人| 亚洲欧美日韩国产中文| xxxxxxxxx欧美| 国产精品久久综合av爱欲tv| 国产精品精品久久久久久| 国产精品久久久久久久久粉嫩av| 国产精品视频久| 精品在线观看国产| 亚洲高清免费观看高清完整版| 亚洲电影免费在线观看| 91在线视频免费| 亚洲成年人影院在线| 日韩中文在线观看| 亚洲最大成人免费视频| 亚洲第一福利网| 精品亚洲一区二区三区| 91久久在线播放| 欧美巨乳在线观看| 国产一区二区免费| 久久精品99久久香蕉国产色戒| 国内成人精品一区| 51精品国产黑色丝袜高跟鞋| 韩国欧美亚洲国产| 国产福利精品av综合导导航| 91精品国产综合久久香蕉最新版| 欧美三级欧美成人高清www| 最近2019中文免费高清视频观看www99| 久久久久久91香蕉国产| 亚洲欧美一区二区三区四区| 色偷偷av一区二区三区乱| 亚洲自拍偷拍福利| 亚洲永久在线观看| 成人伊人精品色xxxx视频| 国产精品wwwwww| 欧美日韩综合视频| 狠狠色狠狠色综合日日小说| 日韩一区二区精品视频| 成人免费福利在线| 亚洲欧美综合精品久久成人| 91网站免费观看| 国产成人精品久久久| 成人免费视频a| 欧美日韩综合视频网址| 欧美激情视频给我| 国产91免费观看| 91探花福利精品国产自产在线| 日本三级韩国三级久久| 日韩电影大全免费观看2023年上| 中文字幕久热精品视频在线| 欧美性xxxxxxx| 亚州欧美日韩中文视频| 亚洲欧美日韩一区二区在线| 青草青草久热精品视频在线网站| 中文字幕亚洲图片| 亚洲欧美日韩爽爽影院| 91超碰中文字幕久久精品| 81精品国产乱码久久久久久| 91在线观看欧美日韩| 久久久最新网址| 精品国产欧美一区二区三区成人| 亚洲国产精品悠悠久久琪琪| 日韩激情视频在线| 国产一区香蕉久久| 91精品在线国产| 欧美天天综合色影久久精品| 国产日产亚洲精品| 欧美精品生活片| www.久久色.com| 欧美精品中文字幕一区| 亚洲美女av在线播放| 九九视频这里只有精品| 一区二区三区视频免费在线观看| 亚洲男人的天堂在线| 欧美人交a欧美精品| 久久精品电影一区二区| 日韩中文字幕在线视频| 国产精品一久久香蕉国产线看观看| 亚洲国产日韩欧美在线动漫| 在线播放精品一区二区三区| 91影视免费在线观看| 国产精品国语对白| 国产精品日韩av| 97久久精品人人澡人人爽缅北| 久久精品国产亚洲精品| 欧美大片免费观看在线观看网站推荐| 日韩亚洲第一页| 亚洲尤物视频网| 国产成人一区二区三区小说| 国自产精品手机在线观看视频| 91国内揄拍国内精品对白| 欧美日韩一区二区在线播放| 国产精品久久久久久影视| 在线观看日韩av| xvideos亚洲|