⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 iopen-misc-2.6.12.patch

📁 lustre 1.6.5 source code
💻 PATCH
字号:
Index: linux-2.6.16.46-0.14/Documentation/filesystems/ext2.txt===================================================================--- linux-2.6.16.46-0.14.orig/Documentation/filesystems/ext2.txt+++ linux-2.6.16.46-0.14/Documentation/filesystems/ext2.txt@@ -58,6 +58,22 @@ nobh				Do not attach buffer_heads to fi  xip				Use execute in place (no caching) if possible +iopen				Makes an invisible pseudo-directory called +				__iopen__ available in the root directory+				of the filesystem.  Allows open-by-inode-+				number.  i.e., inode 3145 can be accessed+				via /mntpt/__iopen__/3145++iopen_nopriv			This option makes the iopen directory be+				world-readable.  This may be safer since it+				allows daemons to run as an unprivileged user,+				however it significantly changes the security+				model of a Unix filesystem, since previously+				all files under a mode 700 directory were not+				generally avilable even if the+				permissions on the file itself is+				world-readable.+ grpquota,noquota,quota,usrquota	Quota options are silently ignored by ext2.  Index: linux-2.6.16.46-0.14/fs/dcache.c===================================================================--- linux-2.6.16.46-0.14.orig/fs/dcache.c+++ linux-2.6.16.46-0.14/fs/dcache.c@@ -1309,17 +1309,26 @@ static void __d_rehash(struct dentry * e  * Adds a dentry to the hash according to its name.  */  -void d_rehash(struct dentry * entry)+void d_rehash_cond(struct dentry * entry, int lock) { 	struct hlist_head *list = d_hash(entry->d_parent, entry->d_name.hash); -	spin_lock(&dcache_lock);+	if (lock)+		spin_lock(&dcache_lock); 	spin_lock(&entry->d_lock); 	__d_rehash(entry, list); 	spin_unlock(&entry->d_lock);-	spin_unlock(&dcache_lock);+	if (lock)+		spin_unlock(&dcache_lock); } +EXPORT_SYMBOL(d_rehash_cond);++void d_rehash(struct dentry * entry)+{+	d_rehash_cond(entry, 1);+ }+ #define do_switch(x,y) do { \ 	__typeof__ (x) __tmp = x; \ 	x = y; y = __tmp; } while (0)@@ -1392,14 +1401,13 @@ static void switch_names(struct dentry *  * dcache entries should not be moved in this way.  */ -void d_move(struct dentry * dentry, struct dentry * target)+void d_move_locked(struct dentry * dentry, struct dentry * target) { 	struct hlist_head *list;  	if (!dentry->d_inode) 		printk(KERN_WARNING "VFS: moving negative dcache entry\n"); -	spin_lock(&dcache_lock); 	write_seqlock(&rename_lock); 	/* 	 * XXXX: do we really need to take target->d_lock?@@ -1450,6 +1458,14 @@ already_unhashed: 	fsnotify_d_move(dentry); 	spin_unlock(&dentry->d_lock); 	write_sequnlock(&rename_lock);+}++EXPORT_SYMBOL(d_move_locked);++void d_move(struct dentry *dentry, struct dentry *target)+{+	spin_lock(&dcache_lock);+	d_move_locked(dentry, target); 	spin_unlock(&dcache_lock); } Index: linux-2.6.16.46-0.14/include/linux/dcache.h===================================================================--- linux-2.6.16.46-0.14.orig/include/linux/dcache.h+++ linux-2.6.16.46-0.14/include/linux/dcache.h@@ -236,6 +236,7 @@ extern int have_submounts(struct dentry   * This adds the entry to the hash queues.  */ extern void d_rehash(struct dentry *);+extern void d_rehash_cond(struct dentry *, int lock);  /**  * d_add - add dentry to hash queues@@ -271,6 +272,7 @@ static inline struct dentry *d_add_uniqu  /* used for rename() and baskets */ extern void d_move(struct dentry *, struct dentry *);+extern void d_move_locked(struct dentry *, struct dentry *);  /* appendix may either be NULL or be used for transname suffixes */ extern struct dentry * d_lookup(struct dentry *, struct qstr *);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -