Linux Headquarters
[ Register ]
[ About us ] [ Home Page ]

Advertisement
[ Kernel ] [ Documentation ] [ Links ] [ Books ]

Kernel v2.6.24 /fs/fuse/fuse_i.h

Filename:/fs/fuse/fuse_i.h
Lines Added:51
Lines Deleted:12
Also changed in: (Previous) 2.6.24-rc8  2.6.24-rc7  2.6.24-rc6  2.6.24-rc5  2.6.24-rc4  2.6.24-rc3-git7 
(Following) 2.6.24-git16  2.6.24-git17  2.6.24-git18  2.6.24-git19  2.6.24-git20  2.6.24-git21 

Location
[  2.6.24
  [  fs
    [  fuse
       o  fuse_i.h

Patch

diff --git a/fs/fuse/fuse_i.h b/fs/fuse/fuse_i.h
index 68ae87c..3ab8a30 100644
--- a/fs/fuse/fuse_i.h
+++ b/fs/fuse/fuse_i.h
@@ -20,7 +20,10 @@
 #define FUSE_MAX_PAGES_PER_REQ 32
 
 /** Maximum number of outstanding background requests */
-#define FUSE_MAX_BACKGROUND 10
+#define FUSE_MAX_BACKGROUND 12
+
+/** Congestion starts at 75% of maximum */
+#define FUSE_CONGESTION_THRESHOLD (FUSE_MAX_BACKGROUND * 75 / 100)
 
 /** It could be as large as PATH_MAX, but would that have any uses? */
 #define FUSE_NAME_MAX 1024
@@ -60,6 +63,16 @@ struct fuse_inode {
 
    /** Time in jiffies until the file attributes are valid */
    u64 i_time;
+
+   /** The sticky bit in inode->i_mode may have been removed, so
+       preserve the original mode */
+   mode_t orig_i_mode;
+
+   /** Version of last attribute change */
+   u64 attr_version;
+
+   /** Files usable in writepage.  Protected by fc->lock */
+   struct list_head write_files;
 };
 
 /** FUSE specific file data */
@@ -69,6 +82,12 @@ struct fuse_file {
 
    /** File handle used by userspace */
    u64 fh;
+
+   /** Refcount */
+   atomic_t count;
+
+   /** Entry on inode's write_files list */
+   struct list_head write_entry;
 };
 
 /** One input argument of a request */
@@ -200,6 +219,10 @@ struct fuse_req {
       struct fuse_init_in init_in;
       struct fuse_init_out init_out;
       struct fuse_read_in read_in;
+      struct {
+         struct fuse_write_in in;
+         struct fuse_write_out out;
+      } write;
       struct fuse_lk_in lk_in;
    } misc;
 
@@ -213,7 +236,7 @@ struct fuse_req {
    unsigned page_offset;
 
    /** File used in the request (or NULL) */
-   struct file *file;
+   struct fuse_file *ff;
 
    /** vfsmount used in release */
    struct vfsmount *vfsmount;
@@ -286,6 +309,9 @@ struct fuse_conn {
    /** waitq for blocked connection */
    wait_queue_head_t blocked_waitq;
 
+   /** waitq for reserved requests */
+   wait_queue_head_t reserved_req_waitq;
+
    /** The next unique request id */
    u64 reqctr;
 
@@ -304,6 +330,9 @@ struct fuse_conn {
    /** Do readpages asynchronously?  Only set in INIT */
    unsigned async_read : 1;
 
+   /** Do not send separate SETATTR request before open(O_TRUNC)  */
+   unsigned atomic_o_trunc : 1;
+
    /*
     * The following bitfields are only for optimization purposes
     * and hence races in setting them will not cause malfunction
@@ -374,6 +403,9 @@ struct fuse_conn {
 
    /** Reserved request for the DESTROY message */
    struct fuse_req *destroy_req;
+
+   /** Version counter for attribute changes */
+   u64 attr_version;
 };
 
 static inline struct fuse_conn *get_fuse_conn_super(struct super_block *sb)
@@ -403,7 +435,8 @@ extern const struct file_operations fuse_dev_operations;
  * Get a filled in inode
  */
 struct inode *fuse_iget(struct super_block *sb, unsigned long nodeid,
-         int generation, struct fuse_attr *attr);
+         int generation, struct fuse_attr *attr,
+         u64 attr_valid, u64 attr_version);
 
 /**
  * Send FORGET command
@@ -427,9 +460,9 @@ void fuse_file_free(struct fuse_file *ff);
 void fuse_finish_open(struct inode *inode, struct file *file,
             struct fuse_file *ff, struct fuse_open_out *outarg);
 
-/** */
-struct fuse_req *fuse_release_fill(struct fuse_file *ff, u64 nodeid, int flags,
-               int opcode);
+/** Fill in ff->reserved_req with a RELEASE request */
+void fuse_release_fill(struct fuse_file *ff, u64 nodeid, int flags, int opcode);
+
 /**
  * Send RELEASE or RELEASEDIR request
  */
@@ -464,7 +497,8 @@ void fuse_init_symlink(struct inode *inode);
 /**
  * Change attributes of an inode
  */
-void fuse_change_attributes(struct inode *inode, struct fuse_attr *attr);
+void fuse_change_attributes(struct inode *inode, struct fuse_attr *attr,
+             u64 attr_valid, u64 attr_version);
 
 /**
  * Initialize the client device
@@ -524,11 +558,6 @@ void request_send_background(struct fuse_conn *fc, struct fuse_req *req);
 void fuse_abort_conn(struct fuse_conn *fc);
 
 /**
- * Get the attributes of a file
- */
-int fuse_do_getattr(struct inode *inode);
-
-/**
  * Invalidate inode attributes
  */
 void fuse_invalidate_attr(struct inode *inode);
@@ -557,3 +586,13 @@ void fuse_ctl_remove_conn(struct fuse_conn *fc);
  * Is file type valid?
  */
 int fuse_valid_type(int m);
+
+/**
+ * Is task allowed to perform filesystem operation?
+ */
+int fuse_allow_task(struct fuse_conn *fc, struct task_struct *task);
+
+u64 fuse_lock_owner_id(struct fuse_conn *fc, fl_owner_t id);
+
+int fuse_update_attributes(struct inode *inode, struct kstat *stat,
+            struct file *file, bool *refreshed);


Comments: webmaster (at) linuxhq.com.
Advertising: banners (at) linuxhq.com.
Compilation ©1998-2008 Linux Headquarters, Inc.