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

小默

『轉』文件結構體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 小默 閱讀(330) 評論(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>
            久久综合狠狠综合久久综合88| 极品中文字幕一区| 亚洲一区免费视频| 中文亚洲视频在线| 艳女tv在线观看国产一区| 一本久道久久综合婷婷鲸鱼| 日韩手机在线导航| 亚洲一区亚洲二区| 欧美在线视频一区二区| 欧美一区午夜精品| 久久久久青草大香线综合精品| 久久久精品午夜少妇| 鲁大师影院一区二区三区| 欧美成人中文| 国产精品视频网站| 精品不卡一区| 日韩亚洲一区二区| 亚洲欧洲av一区二区| 久久天天躁夜夜躁狠狠躁2022 | 亚洲一区二区影院| 欧美一区二区黄色| 免费av成人在线| 欧美性大战久久久久久久| 国产欧美日韩伦理| 日韩一级成人av| 久久久久久久一区二区| 亚洲欧洲另类国产综合| 亚洲性xxxx| 久久天堂成人| 国产精品夫妻自拍| 欧美在线电影| 欧美成人官网二区| 国产精品乱码人人做人人爱| 亚洲国产裸拍裸体视频在线观看乱了| 99在线精品免费视频九九视| 欧美一级网站| 亚洲免费福利视频| 另类尿喷潮videofree| 国产精品久久波多野结衣| 亚洲国产精品久久91精品| 性高湖久久久久久久久| 亚洲精品午夜精品| 久久综合五月天婷婷伊人| 国产免费成人在线视频| 宅男精品导航| 亚洲国产第一| 久久亚洲精品网站| 狠狠色丁香婷综合久久| 亚洲欧美中文字幕| 日韩手机在线导航| 欧美另类极品videosbest最新版本 | 卡通动漫国产精品| 韩国福利一区| 久久久精品国产免费观看同学| 亚洲免费高清视频| 欧美日韩天天操| 日韩午夜在线| 亚洲国产综合视频在线观看 | 国产欧美一区二区精品婷婷| 亚洲永久在线| 亚洲视频一区在线观看| 欧美视频在线视频| 亚洲男人第一av网站| 亚洲精品视频在线| 欧美偷拍一区二区| 亚洲一区二区三区四区视频| 夜夜嗨一区二区| 国产精品videosex极品| 亚洲综合激情| 午夜视频一区在线观看| 国产一区二区看久久| 久久这里有精品15一区二区三区 | 久久久久久一区二区| 在线精品观看| 亚洲国产精品成人精品 | 黄色成人在线网站| 久久久久久久一区| 久久婷婷国产麻豆91天堂| 亚洲高清在线视频| 91久久线看在观草草青青| 欧美日韩一卡二卡| 香蕉成人伊视频在线观看| 欧美中文日韩| 亚洲美女色禁图| 中文在线不卡| 亚洲欧美一区二区三区极速播放| 国产视频一区二区在线观看| 老色鬼精品视频在线观看播放 | 欧美视频观看一区| 亚洲欧美在线视频观看| 欧美一区二区三区在线观看视频| 在线播放亚洲| 亚洲精品一二三| 国产无遮挡一区二区三区毛片日本| 免费日韩成人| 欧美色123| 久久久五月婷婷| 欧美人成在线视频| 久久久999精品免费| 欧美成年人视频网站| 亚洲欧美日韩国产中文 | 国产伪娘ts一区| 亚洲国产女人aaa毛片在线| 国产精品系列在线播放| 欧美激情久久久久| 国产日本欧美在线观看| 欧美国产日韩一区二区三区| 国产精品久久久久7777婷婷| 牛人盗摄一区二区三区视频| 国产精品高潮呻吟久久av黑人| 老色批av在线精品| 国产精品日日做人人爱| 亚洲第一区在线观看| 国产欧美日韩一区二区三区在线| 亚洲精品久久久久| 亚洲国产精品久久久久婷婷老年| 亚洲欧美bt| 亚洲综合激情| 欧美日韩国产大片| 欧美国产精品日韩| 黄网动漫久久久| 性欧美激情精品| 午夜国产精品视频| 国产精品乱码妇女bbbb| 亚洲精品久久| 亚洲另类一区二区| 蜜桃av综合| 美女主播视频一区| 国产最新精品精品你懂的| 亚洲一区在线播放| 香蕉成人久久| 国产精品日韩| 亚洲综合视频在线| 欧美一区二区三区免费在线看| 欧美性猛交xxxx乱大交蜜桃| 99re8这里有精品热视频免费| 91久久在线| 蜜月aⅴ免费一区二区三区 | 亚洲国内精品在线| 亚洲国产精品一区二区第四页av| 亚洲免费人成在线视频观看| 亚洲一级二级| 国产精品嫩草久久久久| 在线视频中文亚洲| 亚洲男女自偷自拍| 国产精品推荐精品| 欧美中文字幕在线播放| 韩国av一区二区三区四区| 亚洲欧美视频一区| 久久精品国产77777蜜臀| 国产视频一区在线观看一区免费| 欧美一区二区三区免费在线看 | 欧美精品在欧美一区二区少妇| 亚洲国产一区二区精品专区| 亚洲精品一二区| 欧美日韩一二三区| 亚洲综合不卡| 久热精品在线视频| 亚洲三级免费| 国产精品久久国产精品99gif| 亚洲欧美春色| 每日更新成人在线视频| 亚洲国产日韩欧美在线99| 欧美成人一区二区在线 | 欧美不卡激情三级在线观看| 亚洲国产成人精品久久久国产成人一区| 久久久久成人精品免费播放动漫| 欧美顶级少妇做爰| 亚洲线精品一区二区三区八戒| 国产精品无人区| 免费成人网www| 亚洲一区二区视频在线观看| 久久亚洲一区二区三区四区| 日韩亚洲欧美中文三级| 国产日韩亚洲欧美| 欧美国产日本在线| 亚洲欧美日韩国产中文在线| 免费中文日韩| 羞羞视频在线观看欧美| 亚洲国产裸拍裸体视频在线观看乱了| 欧美日韩午夜剧场| 久久国产66| 中文一区在线| 欧美激情一区二区三区不卡| 亚洲一区二区在线免费观看| 亚洲国产另类精品专区| 国产区精品在线观看| 欧美精品1区| 久久久久久久波多野高潮日日| 99re8这里有精品热视频免费| 麻豆精品精品国产自在97香蕉| 亚洲视频在线观看一区| 亚洲国产小视频在线观看| 国产精品影音先锋| 欧美三级午夜理伦三级中文幕 | 久久久久久婷| 亚洲伊人一本大道中文字幕| 亚洲乱码久久| 亚洲激情二区| 在线免费观看日本欧美|