summaryrefslogtreecommitdiff
path: root/libre/aufs2-libre/aufs2-module-2.6.36.patch
diff options
context:
space:
mode:
authorNicolás Reynolds <apoyosis@correo.inta.gob.ar>2011-02-24 16:23:49 -0300
committerNicolás Reynolds <apoyosis@correo.inta.gob.ar>2011-02-24 16:23:49 -0300
commit7cfe51ddbaefd7fcb77f84742b8d082783ecb223 (patch)
tree3d01fb2b4c20a8fdd05718ba0dfa8cccf7775074 /libre/aufs2-libre/aufs2-module-2.6.36.patch
parent4de6c7d4c7de0733dd6a084ec7dbf085ea40d8af (diff)
downloadabslibre-7cfe51ddbaefd7fcb77f84742b8d082783ecb223.tar.gz
abslibre-7cfe51ddbaefd7fcb77f84742b8d082783ecb223.tar.bz2
abslibre-7cfe51ddbaefd7fcb77f84742b8d082783ecb223.zip
aufs2-libre-2.6.37_20110124-2
Diffstat (limited to 'libre/aufs2-libre/aufs2-module-2.6.36.patch')
-rw-r--r--libre/aufs2-libre/aufs2-module-2.6.36.patch47
1 files changed, 47 insertions, 0 deletions
diff --git a/libre/aufs2-libre/aufs2-module-2.6.36.patch b/libre/aufs2-libre/aufs2-module-2.6.36.patch
new file mode 100644
index 000000000..3b43f7aed
--- /dev/null
+++ b/libre/aufs2-libre/aufs2-module-2.6.36.patch
@@ -0,0 +1,47 @@
+diff --git a/ubuntu/aufs/branch.c b/ubuntu/aufs/branch.c
+index cd4463c..ff6b158 100644
+--- a/fs/aufs/branch.c
++++ b/fs/aufs/branch.c
+@@ -22,6 +22,8 @@
+
+ #include <linux/file.h>
+ #include <linux/statfs.h>
++#include <linux/lglock.h>
++#include <linux/percpu.h>
+ #include "aufs.h"
+
+ /*
+@@ -851,7 +853,8 @@ static int au_br_mod_files_ro(struct super_block *sb, aufs_bindex_t bindex)
+ goto out;
+
+ /* no need file_list_lock() since sbinfo is locked? defered? */
+- list_for_each_entry(file, &sb->s_files, f_u.fu_list) {
++ lg_global_lock(files_lglock);
++ do_file_list_for_each_entry(sb, file) {
+ if (special_file(file->f_dentry->d_inode->i_mode))
+ continue;
+
+@@ -861,6 +864,7 @@ static int au_br_mod_files_ro(struct super_block *sb, aufs_bindex_t bindex)
+ err = -EBUSY;
+ FiMustNoWaiters(file);
+ fi_read_unlock(file);
++ lg_global_unlock(files_lglock);
+ goto out_free;
+ }
+
+@@ -889,10 +893,13 @@ static int au_br_mod_files_ro(struct super_block *sb, aufs_bindex_t bindex)
+ if (p) {
+ a = p;
+ a[n++] = hf;
+- } else
++ } else {
++ lg_global_unlock(files_lglock);
+ goto out_free;
++ }
+ }
+- }
++ } while_file_list_for_each_entry;
++ lg_global_unlock(files_lglock);
+
+ err = 0;
+ if (n)