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

小默

『轉』文件結構體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>
            国产欧美日韩亚州综合| 国内精品久久久久久久影视蜜臀| 亚洲日本国产| 亚洲黄色高清| 欧美巨乳波霸| 亚洲尤物在线视频观看| 中日韩男男gay无套| 欧美性天天影院| 久久狠狠亚洲综合| 久久久精品欧美丰满| 在线观看欧美日韩国产| 亚洲人久久久| 国产精品日韩在线播放| 久久久青草青青国产亚洲免观| 久久精彩视频| 亚洲美女在线看| 亚洲欧美国产高清| 亚洲第一区在线| 99精品国产在热久久婷婷| 国产欧美一级| 亚洲欧洲精品一区二区三区| 欧美三级视频在线| 久久综合久色欧美综合狠狠| 免费观看亚洲视频大全| 亚洲尤物在线| 老司机aⅴ在线精品导航| 亚洲愉拍自拍另类高清精品| 久久久91精品国产一区二区精品| av成人国产| 久久精品一区二区三区不卡| 一区二区三区不卡视频在线观看 | 亚洲国产精品一区二区www| 亚洲欧洲在线一区| 国产亚洲激情在线| 亚洲另类黄色| 在线精品国精品国产尤物884a| 亚洲精品一二| 永久久久久久| 亚洲一区二区视频在线观看| 亚洲国产另类久久久精品极度| 亚洲一区二区三区免费在线观看| 最新日韩av| 久久久久久久999精品视频| 亚洲女同在线| 欧美日韩国内| 欧美激情第一页xxx| 黄色成人av在线| 亚洲永久视频| 亚洲午夜在线视频| 欧美日本中文字幕| 亚洲第一黄网| 在线不卡亚洲| 久久这里有精品视频| 久久久777| 国产日韩在线看片| 亚洲一区二区三区在线看| 一本色道久久综合狠狠躁篇的优点| 久久精品国产77777蜜臀| 欧美专区在线观看| 国产欧美日韩综合一区在线观看 | 欧美日韩喷水| 亚洲精品综合| 99v久久综合狠狠综合久久| 免费亚洲电影在线观看| 免费在线欧美视频| 亚洲国产精品视频| 欧美成人激情视频免费观看| 欧美黄色日本| 日韩午夜av电影| 欧美精品日韩三级| 99国产精品99久久久久久| 99天天综合性| 欧美天堂亚洲电影院在线观看| 亚洲精品日产精品乱码不卡| 99综合在线| 国产精品国产三级国产aⅴ入口| 亚洲素人一区二区| 欧美一二三区在线观看| 国产午夜精品美女视频明星a级| 性欧美大战久久久久久久久| 久久久久国色av免费看影院| 亚洲成人自拍视频| 欧美激情a∨在线视频播放| 亚洲精品一二三| 欧美亚洲一区二区在线| 国产一区二区三区四区三区四| 久久久久久9| 亚洲激情在线激情| 欧美一区二区三区另类| 韩国av一区| 欧美日韩国产一区精品一区 | 日韩香蕉视频| 久久精品九九| 亚洲第一狼人社区| 国产精品第一页第二页第三页| 亚洲女爱视频在线| 嫩草国产精品入口| 亚洲一区区二区| 黄色一区二区在线| 欧美日韩在线一区二区三区| 亚洲欧美日韩另类| 亚洲国产视频a| 久久精品成人一区二区三区 | 国产精品网站视频| 美女黄网久久| 亚洲欧美日本日韩| 亚洲国产精品一区二区第四页av| 亚洲自拍偷拍福利| 在线成人激情| 国产精品婷婷午夜在线观看| 久热精品视频在线| 午夜精品久久久99热福利| 亚洲国产精品久久久久秋霞影院| 欧美在线免费观看亚洲| 9国产精品视频| 激情欧美国产欧美| 国产精品一区一区三区| 欧美日韩hd| 欧美+亚洲+精品+三区| 香蕉尹人综合在线观看| 亚洲最黄网站| 亚洲黄色免费电影| 蜜臀av在线播放一区二区三区| 亚洲综合精品一区二区| 99re66热这里只有精品4| 一区免费观看视频| 国产夜色精品一区二区av| 欧美视频一区在线| 欧美日韩国产免费| 欧美成人午夜免费视在线看片| 欧美在线地址| 亚洲免费视频在线观看| 国产精品99久久99久久久二8| 亚洲日本成人网| 亚洲国产网站| 亚洲三级影院| 91久久亚洲| 亚洲精品欧美激情| 最新日韩中文字幕| 亚洲国产精品一区二区尤物区| 免费人成网站在线观看欧美高清 | 亚洲无线视频| 在线视频欧美日韩| 一区二区三区蜜桃网| 亚洲美女啪啪| 中日韩美女免费视频网址在线观看| 亚洲日本成人女熟在线观看| 91久久亚洲| 99亚洲精品| 亚洲尤物在线视频观看| 亚洲欧美另类国产| 午夜国产精品视频免费体验区| 亚洲午夜伦理| 性色av一区二区怡红| 久久久水蜜桃| 欧美激情在线免费观看| 亚洲欧洲另类国产综合| 99re6热只有精品免费观看| 夜夜狂射影院欧美极品| 亚洲私拍自拍| 久久国产精品网站| 麻豆91精品| 欧美日韩大片一区二区三区| 欧美午夜一区| 国产综合视频| 亚洲三级电影在线观看| 亚洲综合色丁香婷婷六月图片| 欧美一区二区三区啪啪| 欧美成人免费在线| 日韩午夜在线观看视频| 羞羞漫画18久久大片| 麻豆久久婷婷| 欧美视频在线一区二区三区| 国产在线精品成人一区二区三区| 在线成人亚洲| 亚洲主播在线播放| 你懂的成人av| 亚洲午夜一区二区三区| 久久午夜激情| 国产精品久久久久久久久久直播 | 欧美jjzz| 亚洲无限av看| 欧美jizz19性欧美| 国产欧美精品| 亚洲九九九在线观看| 久久九九全国免费精品观看| 亚洲国产一二三| 久久aⅴ国产欧美74aaa| 欧美日韩在线一区二区| 亚洲高清一区二| 久久se精品一区精品二区| 亚洲欧洲日本一区二区三区| 欧美一区二区三区四区视频| 欧美日韩国产区一| 影音先锋久久| 久久久国产精品一区| 中国日韩欧美久久久久久久久| 久久综合久久美利坚合众国| 国产日韩欧美另类| 午夜精品国产更新|