aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2010-10-26 20:58:44 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2010-10-26 20:58:44 -0400
commit426e1f5cec4821945642230218876b0e89aafab1 (patch)
tree2728ace018d0698886989da586210ef1543a7098 /kernel
parent9e5fca251f44832cb996961048ea977f80faf6ea (diff)
parent63997e98a3be68d7cec806d22bf9b02b2e1daabb (diff)
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6: (52 commits) split invalidate_inodes() fs: skip I_FREEING inodes in writeback_sb_inodes fs: fold invalidate_list into invalidate_inodes fs: do not drop inode_lock in dispose_list fs: inode split IO and LRU lists fs: switch bdev inode bdi's correctly fs: fix buffer invalidation in invalidate_list fsnotify: use dget_parent smbfs: use dget_parent exportfs: use dget_parent fs: use RCU read side protection in d_validate fs: clean up dentry lru modification fs: split __shrink_dcache_sb fs: improve DCACHE_REFERENCED usage fs: use percpu counter for nr_dentry and nr_dentry_unused fs: simplify __d_free fs: take dcache_lock inside __d_path fs: do not assign default i_ino in new_inode fs: introduce a per-cpu last_ino allocator new helper: ihold() ...
Diffstat (limited to 'kernel')
-rw-r--r--kernel/cgroup.c1
-rw-r--r--kernel/futex.c2
-rw-r--r--kernel/sysctl.c6
3 files changed, 5 insertions, 4 deletions
diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index 7b69b8d0313d..9270d532ec3c 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -777,6 +777,7 @@ static struct inode *cgroup_new_inode(mode_t mode, struct super_block *sb)
777 struct inode *inode = new_inode(sb); 777 struct inode *inode = new_inode(sb);
778 778
779 if (inode) { 779 if (inode) {
780 inode->i_ino = get_next_ino();
780 inode->i_mode = mode; 781 inode->i_mode = mode;
781 inode->i_uid = current_fsuid(); 782 inode->i_uid = current_fsuid();
782 inode->i_gid = current_fsgid(); 783 inode->i_gid = current_fsgid();
diff --git a/kernel/futex.c b/kernel/futex.c
index a118bf160e0b..6c683b37f2ce 100644
--- a/kernel/futex.c
+++ b/kernel/futex.c
@@ -169,7 +169,7 @@ static void get_futex_key_refs(union futex_key *key)
169 169
170 switch (key->both.offset & (FUT_OFF_INODE|FUT_OFF_MMSHARED)) { 170 switch (key->both.offset & (FUT_OFF_INODE|FUT_OFF_MMSHARED)) {
171 case FUT_OFF_INODE: 171 case FUT_OFF_INODE:
172 atomic_inc(&key->shared.inode->i_count); 172 ihold(key->shared.inode);
173 break; 173 break;
174 case FUT_OFF_MMSHARED: 174 case FUT_OFF_MMSHARED:
175 atomic_inc(&key->private.mm->mm_count); 175 atomic_inc(&key->private.mm->mm_count);
diff --git a/kernel/sysctl.c b/kernel/sysctl.c
index 48d9d689498f..c33a1edb799f 100644
--- a/kernel/sysctl.c
+++ b/kernel/sysctl.c
@@ -1338,14 +1338,14 @@ static struct ctl_table fs_table[] = {
1338 .data = &inodes_stat, 1338 .data = &inodes_stat,
1339 .maxlen = 2*sizeof(int), 1339 .maxlen = 2*sizeof(int),
1340 .mode = 0444, 1340 .mode = 0444,
1341 .proc_handler = proc_dointvec, 1341 .proc_handler = proc_nr_inodes,
1342 }, 1342 },
1343 { 1343 {
1344 .procname = "inode-state", 1344 .procname = "inode-state",
1345 .data = &inodes_stat, 1345 .data = &inodes_stat,
1346 .maxlen = 7*sizeof(int), 1346 .maxlen = 7*sizeof(int),
1347 .mode = 0444, 1347 .mode = 0444,
1348 .proc_handler = proc_dointvec, 1348 .proc_handler = proc_nr_inodes,
1349 }, 1349 },
1350 { 1350 {
1351 .procname = "file-nr", 1351 .procname = "file-nr",
@@ -1375,7 +1375,7 @@ static struct ctl_table fs_table[] = {
1375 .data = &dentry_stat, 1375 .data = &dentry_stat,
1376 .maxlen = 6*sizeof(int), 1376 .maxlen = 6*sizeof(int),
1377 .mode = 0444, 1377 .mode = 0444,
1378 .proc_handler = proc_dointvec, 1378 .proc_handler = proc_nr_dentry,
1379 }, 1379 },
1380 { 1380 {
1381 .procname = "overflowuid", 1381 .procname = "overflowuid",