青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

小默

『轉』文件結構體struct file(Linux 2.6.23內核)

struct file結構體定義在/linux/include/linux/fs.h(Linux 2.6.11內核)中,其原型是:
struct file {
        /*
         * fu_list becomes invalid after file_free is called and queued via
         * fu_rcuhead for RCU freeing
         */
        union {
                struct list_head        fu_list;
                struct rcu_head         fu_rcuhead;
        } f_u;
        struct path             f_path;
#define f_dentry        f_path.dentry
#define f_vfsmnt        f_path.mnt
        const struct file_operations    *f_op;
        atomic_t                f_count;
        unsigned int            f_flags;
        mode_t                  f_mode;
        loff_t                  f_pos;
        struct fown_struct      f_owner;
        unsigned int            f_uid, f_gid;
        struct file_ra_state    f_ra;
        unsigned long           f_version;
#ifdef CONFIG_SECURITY
        void                    *f_security;
#endif
        /* needed for tty driver, and maybe others */
        void                    *private_data;
#ifdef CONFIG_EPOLL
        /* Used by fs/eventpoll.c to link all the hooks to this file */
        struct list_head        f_ep_links;
        spinlock_t              f_ep_lock;
#endif /* #ifdef CONFIG_EPOLL */
        struct address_space    *f_mapping;
};
文件結構體代表一個打開的文件,系統中的每個打開的文件在內核空間都有一個關聯的struct file。它由內核在打開文件時創建,并傳遞給在文件上進行操作的任何函數。在文件的所有實例都關閉后,內核釋放這個數據結構。在內核創建和驅動源碼中,struct file的指針通常被命名為file或filp。一下是對結構中的每個數據成員的解釋:
一、
union {
    struct list_head fu_list;
    struct rcu_head rcuhead;
}f_u;
其中的struct list_head定義在 linux/include/linux/list.h中,原型為:
struct list_head {
        struct list_head *next, *prev;
};
用于通用文件對象鏈表的指針。
struct rcu_head定義在linux/include/linux/rcupdate.h中,其原型為:
/**
* struct rcu_head - callback structure for use with RCU
* @next: next update requests in a list
* @func: actual update function to call after the grace period.
*/
struct rcu_head {
        struct rcu_head *next;
        void (*func)(struct rcu_head *head);
};
RCU(Read-Copy Update)是Linux 2.6內核中新的鎖機制,具體在這里有介紹:
http://www.ibm.com/developerworks/cn/linux/l-rcu/
二、
struct path             f_path;
被定義在linux/include/linux/namei.h中,其原型為:
struct path {
        struct vfsmount *mnt;
        struct dentry *dentry;
};
在早些版本的內核中并沒有此結構,而是直接將path的兩個數據成員作為struct file的數據成員,
struct vfsmount *mnt的作用是指出該文件的已安裝的文件系統,
struct dentry *dentry是與文件相關的目錄項對象。
三、
const struct file_operations    *f_op;
被定義在linux/include/linux/fs.h中,其中包含著與文件關聯的操作,如:
loff_t (*llseek) (struct file *, loff_t, int);
ssize_t (*read) (struct file *, char __user *, size_t, loff_t *);
ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *);
等。當打開一個文件時,內核就創建一個與該文件相關聯的struct file結構,其中的*f_op就指向的是
具體對該文件進行操作的函數。例如用戶調用系統調用read來讀取該文件的內容時,那么系統調用read最終會陷入內核調用sys_read函數,而sys_read最終會調用于該文件關聯的struct file結構中的f_op->read函數對文件內容進行讀取。
四、
atomic_t                f_count;
atomic_t被定義為:
typedef struct { volatile int counter; } atomic_t;
volatile修飾字段告訴gcc不要對該類型的數據做優化處理,對它的訪問都是對內存的訪問,而不是對寄存器的訪問。 
本質是int類型,之所以這樣寫是讓編譯器對基于該類型變量的操作進行嚴格的類型檢查。此處f_count的作用是記錄對文件對象的引用計數,也即當前有多少個進程在使用該文件。
五、
unsigned int            f_flags;
當打開文件時指定的標志,對應系統調用open的int flags參數。驅動程序為了支持非阻塞型操作需要檢查這個標志。
六、
mode_t                  f_mode;
對文件的讀寫模式,對應系統調用open的mod_t mode參數。如果驅動程序需要這個值,可以直接讀取這個字段。
mod_t被定義為:
typedef unsigned int __kernel_mode_t;
typedef __kernel_mode_t         mode_t;
七、
loff_t                  f_pos;
當前的文件指針位置,即文件的讀寫位置。
loff_t被定義為:
typedef long long       __kernel_loff_t;
typedef __kernel_loff_t         loff_t;
八、
struct fown_struct      f_owner;
struct fown_struct在linux/include/linux/fs.h被定義,原型為:
struct fown_struct {
        rwlock_t lock;          /* protects pid, uid, euid fields */
        struct pid *pid;        /* pid or -pgrp where SIGIO should be sent */
        enum pid_type pid_type; /* Kind of process group SIGIO should be sent to */
        uid_t uid, euid;        /* uid/euid of process setting the owner */
        int signum;             /* posix.1b rt signal to be delivered on IO */
};
該結構的作用是通過信號進行I/O時間通知的數據。
九、
unsigned int            f_uid, f_gid;
標識文件的所有者id,所有者所在組的id.
十、
struct file_ra_state    f_ra;
struct file_ra_state結構被定義在/linux/include/linux/fs.h中,原型為:
struct file_ra_state {
        pgoff_t start;                  /* where readahead started */
        unsigned long size;             /* # of readahead pages */
        unsigned long async_size;       /* do asynchronous readahead when
                                           there are only # of pages ahead */
                                           
        unsigned long ra_pages;         /* Maximum readahead window */
        unsigned long mmap_hit;         /* Cache hit stat for mmap accesses */
        unsigned long mmap_miss;        /* Cache miss stat for mmap accesses */
        unsigned long prev_index;       /* Cache last read() position */
        unsigned int prev_offset;       /* Offset where last read() ended in a page */
};
文件預讀狀態,文件預讀算法使用的主要數據結構,當打開一個文件時,f_ra中出了perv_page(默認為-1)和ra_apges(對該文件允許的最大預讀量)這兩個字段外,其他的所有西端都置為0。
十一、
unsigned long           f_version;
記錄文件的版本號,每次使用后都自動遞增。
十二、
#ifdef CONFIG_SECURITY
        void                    *f_security;
#endif
此處我的理解是如果在編譯內核時配置了安全措施,那么struct file結構中就會有void *f_security數據項,用來描述安全措施或者是記錄與安全有關的信息。
十三、
void *private_data;
系統在調用驅動程序的open方法前將這個指針置為NULL。驅動程序可以將這個字段用于任意目的,也可以忽略這個字段。驅動程序可以用這個字段指向已分配的數據,但是一定要在內核釋放file結構前的release方法中清除它。
十四、
#ifdef CONFIG_EPOLL
        /* Used by fs/eventpoll.c to link all the hooks to this file */
        struct list_head        f_ep_links;
        spinlock_t              f_ep_lock;
#endif /* #ifdef CONFIG_EPOLL */
被用在fs/eventpoll.c來鏈接所有鉤到這個文件上。其中f_ep_links是文件的事件輪詢等待者鏈表的頭,f_ep_lock是保護f_ep_links鏈表的自旋鎖。
十五、struct address_space    *f_mapping;
struct address_space被定義在/linux/include/linux/fs.h中,此處是指向文件地址空間的指針。
  在驅動開發中,文件讀/寫模式mode、標志f_flags都是設備驅動關心的內容,而私有數據指針private_data在折本驅動中被廣泛使用,大多被指向設備驅動自定義用于描述設備的結構體。 
驅動程序中常用如下類似的代碼來檢測用戶打開文件的讀寫方式:
if (file->f_mode & FMODE_WRITE) //用戶要求可寫
  {
  }
  if (file->f_mode & FMODE_READ) //用戶要求可讀
  {
  }
下面的代碼可用于判斷以阻塞還是非阻塞方式打開設備文件:
  if (file->f_flags & O_NONBLOCK) //非阻塞
      pr_debug("open:non-blocking\n");
  else //阻塞
      pr_debug("open:blocking\n");
參考:
Linux設備驅動開發詳解
深入理解linux內核

posted on 2010-06-17 23:14 小默 閱讀(332) 評論(0)  編輯 收藏 引用 所屬分類: Linux

導航

統計

留言簿(13)

隨筆分類(287)

隨筆檔案(289)

漏洞

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产日韩欧美综合在线| 国产亚洲一区二区三区在线播放 | 中文欧美在线视频| 国产精品video| 性亚洲最疯狂xxxx高清| 久久国产精彩视频| 在线激情影院一区| 91久久午夜| 欧美日韩在线观看一区二区三区| 亚洲一区二区视频在线观看| 亚洲一二三区精品| 好看的亚洲午夜视频在线| 欧美成人性生活| 欧美日韩三区| 久久国产日韩欧美| 欧美国内亚洲| 久久国产精品久久久久久| 久久免费视频观看| 亚洲午夜精品网| 欧美在线一级视频| 一区二区欧美国产| 西西裸体人体做爰大胆久久久| 亚洲成人直播| 亚洲深爱激情| 亚洲国产精品久久久久久女王 | 欧美中文字幕在线观看| 老牛国产精品一区的观看方式| 一区二区日韩免费看| 午夜精品福利电影| 亚洲精品国产精品国自产观看浪潮| 艳妇臀荡乳欲伦亚洲一区| 狠狠色丁香婷综合久久| 99视频超级精品| 精品动漫3d一区二区三区免费版| 亚洲精品四区| 狠狠入ady亚洲精品| 中文在线资源观看视频网站免费不卡| 一区二区在线免费观看| 亚洲永久精品大片| 日韩视频免费在线| 久久久噜噜噜久久| 欧美亚洲一区| 国产精品video| 91久久精品国产91久久| 伊人色综合久久天天五月婷| 亚洲免费在线看| 亚洲淫性视频| 欧美色偷偷大香| 亚洲日本aⅴ片在线观看香蕉| 在线观看福利一区| 欧美一区二区视频在线观看| 亚洲欧美视频一区| 欧美色网在线| 一本久道综合久久精品| 日韩午夜电影av| 欧美激情久久久久| 亚洲电影免费观看高清| 亚洲国产欧美日韩精品| 久久天天狠狠| 免费h精品视频在线播放| 国产一区二区三区免费不卡 | 99re在线精品| 99精品久久久| 欧美激情一区二区三区全黄| 欧美国产丝袜视频| 91久久久亚洲精品| 免费在线欧美视频| 亚洲高清毛片| 一本色道综合亚洲| 国产精品v日韩精品| 在线亚洲精品福利网址导航| 亚洲欧美精品在线| 国产精品一区二区在线观看不卡| 亚洲欧美另类综合偷拍| 欧美在线视频二区| 在线观看一区视频| 欧美成人午夜剧场免费观看| 亚洲精品欧美| 香蕉久久久久久久av网站| 国产精品日韩在线一区| 欧美一区二区三区四区夜夜大片| 久久视频免费观看| 亚洲激情二区| 国产精品国产三级国产普通话99| 亚洲综合精品自拍| 久久亚洲精品视频| 一本色道婷婷久久欧美| 国产精品视频精品视频| 久久久久在线观看| 亚洲精品在线免费| 久久精品久久99精品久久| 亚洲激情视频在线播放| 欧美精品亚洲| 欧美亚洲一区在线| 亚洲区在线播放| 欧美中文字幕在线| 亚洲伦理在线观看| 国产日韩在线看片| 欧美激情一区二区久久久| 亚洲一级免费视频| 亚洲福利视频二区| 久久久精品网| 亚洲一区二区三区激情| 一区在线免费| 国产精品女人网站| 免费不卡在线观看av| 亚洲香蕉视频| 亚洲人www| 久久综合国产精品台湾中文娱乐网| 日韩视频免费大全中文字幕| 好吊妞这里只有精品| 欧美日韩亚洲一区二区三区在线| 欧美在线视频播放| 亚洲性线免费观看视频成熟| 亚洲国产精品www| 久久久久久欧美| 午夜在线a亚洲v天堂网2018| 亚洲毛片一区| 在线观看国产精品网站| 国产日韩av在线播放| 欧美日韩国产专区| 美女视频黄免费的久久| 久久国产精品亚洲va麻豆| 一区二区三区视频观看| 亚洲精品久久久久中文字幕欢迎你 | 国产精品黄视频| 欧美巨乳在线观看| 久热精品在线| 久久久亚洲高清| 久久精品人人做人人综合| 亚洲免费小视频| 亚洲性视频网站| 亚洲一区二区三区精品视频 | 久久国产精彩视频| 亚洲欧美美女| 午夜精品一区二区三区电影天堂| 一区二区三区国产盗摄| 99精品热视频| 一本久久a久久精品亚洲| 亚洲精品一区二区三区樱花| 亚洲国产精彩中文乱码av在线播放| 国产又爽又黄的激情精品视频| 国产精品久久久久久久久久久久久| 欧美日韩精品一区二区| 欧美日韩免费在线视频| 欧美日韩精品一区视频 | 欧美在线地址| 久久国产乱子精品免费女 | av成人免费在线| 一区二区三区高清| 中国av一区| 亚洲欧美日韩视频二区| 欧美中文字幕在线视频| 久久久99爱| 免费亚洲电影在线观看| 欧美人体xx| 国产精品久久婷婷六月丁香| 国产农村妇女精品一区二区| 国产日韩欧美高清免费| 激情视频一区二区| 最新国产成人av网站网址麻豆| 亚洲精品一区二区三区四区高清 | 亚洲一区在线观看视频| 性欧美在线看片a免费观看| 久久久久九九九| 欧美福利网址| 亚洲视频每日更新| 欧美一区二区三区久久精品茉莉花| 久久久久久日产精品| 欧美国产另类| 国产精品资源| 亚洲精品一区在线| 午夜在线观看免费一区| 欧美成人精品| 国产精品99久久久久久久女警| 欧美综合激情网| 欧美日韩视频第一区| 国产欧美一区二区精品婷婷| 亚洲欧洲综合另类| 午夜综合激情| 亚洲激情午夜| 欧美一区二区三区日韩视频| 欧美华人在线视频| 国产日韩欧美亚洲| 日韩一区二区精品葵司在线| 久久大逼视频| 亚洲美女色禁图| 久久久久久91香蕉国产| 国产精品久久99| 亚洲老板91色精品久久| 久久久久99| 亚洲一区欧美| 欧美日韩直播| 亚洲国产视频直播| 久久一区二区三区av| 亚洲视频在线免费观看| 欧美精品在线播放| 亚洲国产成人午夜在线一区| 性久久久久久久久久久久| 亚洲伦理自拍|