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

小默

『轉』文件結構體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>
            久久久91精品国产| 亚洲一区二区视频在线观看| 久久久久久久97| 亚洲国产精品久久| 日韩一级黄色大片| 久久亚洲美女| 国产午夜精品全部视频在线播放| 在线视频日韩| 亚洲国产视频一区| 美女视频黄a大片欧美| 国产在线精品自拍| 久久99在线观看| 亚洲欧美亚洲| 国产精品视频最多的网站| 亚洲麻豆一区| 亚洲精品久久久蜜桃| 久久婷婷国产麻豆91天堂| 国产欧美一区二区三区在线老狼 | 亚洲精品日本| 免费成人在线视频网站| 在线播放一区| 欧美激情国产高清| 免费中文字幕日韩欧美| 99re国产精品| 在线亚洲精品| 国产亚洲欧洲| 欧美黄色影院| 欧美日韩精品综合| 亚洲一区日韩在线| 亚洲一区二区av电影| 国产精品福利片| 性久久久久久久久| 久久久久久网| 在线综合+亚洲+欧美中文字幕| 99日韩精品| 国产亚洲精品一区二555| 乱人伦精品视频在线观看| 噜噜噜91成人网| 亚洲视频一区在线| 亚洲欧美在线视频观看| 激情婷婷欧美| 亚洲欧洲日韩女同| 国产精品美女久久久久av超清| 久久精品99国产精品| 久久亚洲一区| 一本久道久久综合中文字幕 | 好看的日韩av电影| 欧美韩日一区二区| 欧美另类69精品久久久久9999| 午夜精品久久久久久99热| 久久久精品视频成人| 亚洲精品中文字幕女同| 亚洲伊人伊色伊影伊综合网| 毛片精品免费在线观看| 亚洲欧美日本国产有色| 黄色亚洲网站| 亚洲精品永久免费精品| 国产亚洲精久久久久久| 亚洲欧洲另类国产综合| 国产女优一区| 亚洲精品一区久久久久久| 国产亚洲成精品久久| 亚洲成人资源网| 国产一级揄自揄精品视频| 亚洲激情视频| 精品电影在线观看| 亚洲在线观看免费| 在线一区二区三区做爰视频网站| 快播亚洲色图| 久久成人精品| 国产精品久久久久久久免费软件| 亚洲第一级黄色片| 合欧美一区二区三区| 亚洲男人影院| 亚洲视屏在线播放| 欧美成人资源网| 免费不卡中文字幕视频| 国产日产欧美a一级在线| 99精品久久久| 一本色道久久综合亚洲91| 久久久亚洲一区| 久久久综合免费视频| 国产日韩在线一区| 亚洲欧美久久久| 欧美亚洲系列| 国产精品久久久久久久一区探花| 亚洲第一网站免费视频| 国语精品中文字幕| 亚洲一区美女视频在线观看免费| 在线综合视频| 欧美日韩一区二区高清| 亚洲精品在线观看免费| 亚洲经典自拍| 欧美国产综合视频| 亚洲日本成人网| 亚洲免费高清| 欧美大片免费| 日韩视频在线你懂得| 亚洲四色影视在线观看| 欧美性开放视频| 亚洲欧美变态国产另类| 欧美亚洲日本国产| 国产人妖伪娘一区91| 欧美一区二区三区四区在线| 久久精品亚洲精品国产欧美kt∨| 国产有码在线一区二区视频| 久久视频在线视频| 亚洲高清av| 一本到高清视频免费精品| 国产精品国产成人国产三级| 性欧美大战久久久久久久免费观看 | 久久九九热免费视频| 国内精品久久久久伊人av| 久久精品视频免费| 欧美国产一区二区在线观看| 日韩午夜精品| 久久久久久尹人网香蕉| 国产色综合久久| 欧美一区二区三区在线观看视频 | 欧美一级片一区| 韩国在线一区| 欧美承认网站| 一区二区三区高清在线观看| 新片速递亚洲合集欧美合集| 在线精品视频免费观看| 欧美国产亚洲视频| 一本色道久久综合亚洲精品不 | 欧美亚洲尤物久久| 欧美激情亚洲一区| 亚洲午夜久久久久久久久电影院 | 午夜在线a亚洲v天堂网2018| 国产一区二区丝袜高跟鞋图片| 免费h精品视频在线播放| 夜夜嗨av一区二区三区| 欧美91福利在线观看| 亚洲一区二区三区四区中文| 精品不卡一区二区三区| 欧美三级网址| 免费av成人在线| 欧美一区在线直播| 亚洲免费大片| 免费亚洲婷婷| 亚洲欧美在线免费| 夜夜爽夜夜爽精品视频| 亚洲国产视频一区| 国产中文一区二区| 国产精品无码永久免费888| 欧美黄网免费在线观看| 久久精品欧美| 亚洲一区精彩视频| 亚洲精品一区二区三区婷婷月| 欧美高清视频| 蜜臀av国产精品久久久久| 欧美一二三视频| 妖精成人www高清在线观看| 亚洲第一精品夜夜躁人人躁| 国产乱理伦片在线观看夜一区| 欧美激情中文字幕一区二区| 性欧美xxxx视频在线观看| 夜夜嗨av一区二区三区| 亚洲美女av网站| 亚洲国产高清一区| 免费成人av在线看| 久久福利影视| 欧美综合二区| 久久riav二区三区| 欧美伊人影院| 欧美一级视频一区二区| 亚洲午夜一区| 亚洲午夜视频| 亚洲午夜影视影院在线观看| 99精品视频免费在线观看| 亚洲日本成人网| 亚洲精品日产精品乱码不卡| 亚洲福利一区| 亚洲人成免费| 亚洲激情专区| 亚洲精品视频在线观看免费| 亚洲韩国一区二区三区| 亚洲精品日本| 一本色道久久综合亚洲精品不卡| 亚洲精品欧洲| 在线一区二区三区四区| 亚洲伊人第一页| 午夜久久影院| 久久久久一区二区三区| 久久久之久亚州精品露出| 国产婷婷色一区二区三区| 香蕉久久精品日日躁夜夜躁| 亚洲欧美日韩专区| 久久国产日韩| 欧美fxxxxxx另类| 欧美精品乱人伦久久久久久| 欧美日韩精品久久| 国产精品视频自拍| 狠狠色狠狠色综合人人| 91久久在线视频| 亚洲一区二区三区视频| 欧美与黑人午夜性猛交久久久| 久久久久88色偷偷免费|