+ r-o-bind-mount-prepwork-inc_nlink-helper.patch added to -mm tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch titled

     r/o bind mount prepwork: inc_nlink() helper

has been added to the -mm tree.  Its filename is

     r-o-bind-mount-prepwork-inc_nlink-helper.patch

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: r/o bind mount prepwork: inc_nlink() helper
From: Dave Hansen <haveblue@xxxxxxxxxx>

This is mostly included for parity with dec_nlink(), where we will have some
more hooks.  This one should stay pretty darn straightforward for now.

Signed-off-by: Dave Hansen <haveblue@xxxxxxxxxx>
Acked-by: Christoph Hellwig <hch@xxxxxx>
Cc: Al Viro <viro@xxxxxxxxxxxxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxx>
---

 drivers/infiniband/hw/ipath/ipath_fs.c |    4 ++--
 drivers/usb/core/inode.c               |    4 ++--
 fs/9p/vfs_inode.c                      |    2 +-
 fs/autofs/root.c                       |    2 +-
 fs/autofs4/root.c                      |    2 +-
 fs/bfs/dir.c                           |    2 +-
 fs/cifs/inode.c                        |    2 +-
 fs/coda/dir.c                          |    2 +-
 fs/configfs/dir.c                      |    4 ++--
 fs/configfs/mount.c                    |    2 +-
 fs/debugfs/inode.c                     |    4 ++--
 fs/ext3/namei.c                        |    6 +++---
 fs/fuse/control.c                      |    2 +-
 fs/hfsplus/dir.c                       |    2 +-
 fs/hpfs/namei.c                        |    4 ++--
 fs/hugetlbfs/inode.c                   |    4 ++--
 fs/jffs2/dir.c                         |    6 +++---
 fs/jffs2/fs.c                          |    6 +++---
 fs/jfs/namei.c                         |    6 +++---
 fs/libfs.c                             |    4 ++--
 fs/msdos/namei.c                       |    4 ++--
 fs/ocfs2/dlm/dlmfs.c                   |    6 +++---
 fs/ocfs2/namei.c                       |    8 ++++----
 fs/ramfs/inode.c                       |    4 ++--
 fs/reiserfs/namei.c                    |    6 +++---
 fs/sysfs/dir.c                         |    4 ++--
 fs/sysfs/mount.c                       |    2 +-
 fs/udf/inode.c                         |    2 +-
 fs/udf/namei.c                         |    6 +++---
 fs/vfat/namei.c                        |    4 ++--
 include/linux/fs.h                     |    7 ++++++-
 ipc/mqueue.c                           |    2 +-
 kernel/cpuset.c                        |    8 ++++----
 mm/shmem.c                             |    8 ++++----
 net/sunrpc/rpc_pipe.c                  |    6 +++---
 security/inode.c                       |    4 ++--
 security/selinux/selinuxfs.c           |    4 ++--
 37 files changed, 80 insertions(+), 75 deletions(-)

diff -puN drivers/infiniband/hw/ipath/ipath_fs.c~r-o-bind-mount-prepwork-inc_nlink-helper drivers/infiniband/hw/ipath/ipath_fs.c
--- a/drivers/infiniband/hw/ipath/ipath_fs.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/drivers/infiniband/hw/ipath/ipath_fs.c
@@ -66,8 +66,8 @@ static int ipathfs_mknod(struct inode *d
 	inode->i_private = data;
 	if ((mode & S_IFMT) == S_IFDIR) {
 		inode->i_op = &simple_dir_inode_operations;
-		inode->i_nlink++;
-		dir->i_nlink++;
+		inc_nlink(inode);
+		inc_nlink(dir);
 	}
 
 	inode->i_fop = fops;
diff -puN drivers/usb/core/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper drivers/usb/core/inode.c
--- a/drivers/usb/core/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/drivers/usb/core/inode.c
@@ -263,7 +263,7 @@ static struct inode *usbfs_get_inode (st
 			inode->i_fop = &simple_dir_operations;
 
 			/* directory inodes start off with i_nlink == 2 (for "." entry) */
-			inode->i_nlink++;
+			inc_nlink(inode);
 			break;
 		}
 	}
@@ -295,7 +295,7 @@ static int usbfs_mkdir (struct inode *di
 	mode = (mode & (S_IRWXUGO | S_ISVTX)) | S_IFDIR;
 	res = usbfs_mknod (dir, dentry, mode, 0);
 	if (!res)
-		dir->i_nlink++;
+		inc_nlink(dir);
 	return res;
 }
 
diff -puN fs/9p/vfs_inode.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/9p/vfs_inode.c
--- a/fs/9p/vfs_inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/9p/vfs_inode.c
@@ -233,7 +233,7 @@ struct inode *v9fs_get_inode(struct supe
 			inode->i_op = &v9fs_symlink_inode_operations;
 			break;
 		case S_IFDIR:
-			inode->i_nlink++;
+			inc_nlink(inode);
 			if(v9ses->extended)
 				inode->i_op = &v9fs_dir_inode_operations_ext;
 			else
diff -puN fs/autofs/root.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/autofs/root.c
--- a/fs/autofs/root.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/autofs/root.c
@@ -466,7 +466,7 @@ static int autofs_root_mkdir(struct inod
 	ent->dentry = dentry;
 	autofs_hash_insert(dh,ent);
 
-	dir->i_nlink++;
+	inc_nlink(dir);
 	d_instantiate(dentry, iget(dir->i_sb,ino));
 	unlock_kernel();
 
diff -puN fs/autofs4/root.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/autofs4/root.c
--- a/fs/autofs4/root.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/autofs4/root.c
@@ -713,7 +713,7 @@ static int autofs4_dir_mkdir(struct inod
 	if (p_ino && dentry->d_parent != dentry)
 		atomic_inc(&p_ino->count);
 	ino->inode = inode;
-	dir->i_nlink++;
+	inc_nlink(dir);
 	dir->i_mtime = CURRENT_TIME;
 
 	return 0;
diff -puN fs/bfs/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/bfs/dir.c
--- a/fs/bfs/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/bfs/dir.c
@@ -163,7 +163,7 @@ static int bfs_link(struct dentry * old,
 		unlock_kernel();
 		return err;
 	}
-	inode->i_nlink++;
+	inc_nlink(inode);
 	inode->i_ctime = CURRENT_TIME_SEC;
 	mark_inode_dirty(inode);
 	atomic_inc(&inode->i_count);
diff -puN fs/cifs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/cifs/inode.c
--- a/fs/cifs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/cifs/inode.c
@@ -736,7 +736,7 @@ int cifs_mkdir(struct inode *inode, stru
 		cFYI(1, ("cifs_mkdir returned 0x%x", rc));
 		d_drop(direntry);
 	} else {
-		inode->i_nlink++;
+		inc_nlink(inode);
 		if (pTcon->ses->capabilities & CAP_UNIX)
 			rc = cifs_get_inode_info_unix(&newinode, full_path,
 						      inode->i_sb,xid);
diff -puN fs/coda/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/coda/dir.c
--- a/fs/coda/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/coda/dir.c
@@ -304,7 +304,7 @@ static int coda_link(struct dentry *sour
 	coda_dir_changed(dir_inode, 0);
 	atomic_inc(&inode->i_count);
 	d_instantiate(de, inode);
-	inode->i_nlink++;
+	inc_nlink(inode);
         
 out:
 	unlock_kernel();
diff -puN fs/configfs/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/configfs/dir.c
--- a/fs/configfs/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/configfs/dir.c
@@ -113,7 +113,7 @@ static int init_dir(struct inode * inode
 	inode->i_fop = &configfs_dir_operations;
 
 	/* directory inodes start off with i_nlink == 2 (for "." entry) */
-	inode->i_nlink++;
+	inc_nlink(inode);
 	return 0;
 }
 
@@ -141,7 +141,7 @@ static int create_dir(struct config_item
 	if (!error) {
 		error = configfs_create(d, mode, init_dir);
 		if (!error) {
-			p->d_inode->i_nlink++;
+			inc_nlink(p->d_inode);
 			(d)->d_op = &configfs_dentry_ops;
 		} else {
 			struct configfs_dirent *sd = d->d_fsdata;
diff -puN fs/configfs/mount.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/configfs/mount.c
--- a/fs/configfs/mount.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/configfs/mount.c
@@ -84,7 +84,7 @@ static int configfs_fill_super(struct su
 		inode->i_op = &configfs_dir_inode_operations;
 		inode->i_fop = &configfs_dir_operations;
 		/* directory inodes start off with i_nlink == 2 (for "." entry) */
-		inode->i_nlink++;
+		inc_nlink(inode);
 	} else {
 		pr_debug("configfs: could not get root inode\n");
 		return -ENOMEM;
diff -puN fs/debugfs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/debugfs/inode.c
--- a/fs/debugfs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/debugfs/inode.c
@@ -54,7 +54,7 @@ static struct inode *debugfs_get_inode(s
 			inode->i_fop = &simple_dir_operations;
 
 			/* directory inodes start off with i_nlink == 2 (for "." entry) */
-			inode->i_nlink++;
+			inc_nlink(inode);
 			break;
 		}
 	}
@@ -87,7 +87,7 @@ static int debugfs_mkdir(struct inode *d
 	mode = (mode & (S_IRWXUGO | S_ISVTX)) | S_IFDIR;
 	res = debugfs_mknod(dir, dentry, mode, 0);
 	if (!res)
-		dir->i_nlink++;
+		inc_nlink(dir);
 	return res;
 }
 
diff -puN fs/ext3/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/ext3/namei.c
--- a/fs/ext3/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/ext3/namei.c
@@ -1616,7 +1616,7 @@ static int ext3_delete_entry (handle_t *
  */
 static inline void ext3_inc_count(handle_t *handle, struct inode *inode)
 {
-	inode->i_nlink++;
+	inc_nlink(inode);
 }
 
 static inline void ext3_dec_count(handle_t *handle, struct inode *inode)
@@ -1775,7 +1775,7 @@ retry:
 		iput (inode);
 		goto out_stop;
 	}
-	dir->i_nlink++;
+	inc_nlink(dir);
 	ext3_update_dx_flag(dir);
 	ext3_mark_inode_dirty(handle, dir);
 	d_instantiate(dentry, inode);
@@ -2341,7 +2341,7 @@ static int ext3_rename (struct inode * o
 		if (new_inode) {
 			drop_nlink(new_inode);
 		} else {
-			new_dir->i_nlink++;
+			inc_nlink(new_dir);
 			ext3_update_dx_flag(new_dir);
 			ext3_mark_inode_dirty(handle, new_dir);
 		}
diff -puN fs/fuse/control.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/fuse/control.c
--- a/fs/fuse/control.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/fuse/control.c
@@ -116,7 +116,7 @@ int fuse_ctl_add_conn(struct fuse_conn *
 		return 0;
 
 	parent = fuse_control_sb->s_root;
-	parent->d_inode->i_nlink++;
+	inc_nlink(parent->d_inode);
 	sprintf(name, "%llu", (unsigned long long) fc->id);
 	parent = fuse_ctl_add_dentry(parent, fc, name, S_IFDIR | 0500, 2,
 				     &simple_dir_inode_operations,
diff -puN fs/hfsplus/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/hfsplus/dir.c
--- a/fs/hfsplus/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/hfsplus/dir.c
@@ -298,7 +298,7 @@ static int hfsplus_link(struct dentry *s
 	if (res)
 		return res;
 
-	inode->i_nlink++;
+	inc_nlink(inode);
 	hfsplus_instantiate(dst_dentry, inode, cnid);
 	atomic_inc(&inode->i_count);
 	inode->i_ctime = CURRENT_TIME_SEC;
diff -puN fs/hpfs/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/hpfs/namei.c
--- a/fs/hpfs/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/hpfs/namei.c
@@ -89,7 +89,7 @@ static int hpfs_mkdir(struct inode *dir,
 	brelse(bh);
 	hpfs_mark_4buffers_dirty(&qbh0);
 	hpfs_brelse4(&qbh0);
-	dir->i_nlink++;
+	inc_nlink(dir);
 	insert_inode_hash(result);
 
 	if (result->i_uid != current->fsuid ||
@@ -635,7 +635,7 @@ static int hpfs_rename(struct inode *old
 	end:
 	hpfs_i(i)->i_parent_dir = new_dir->i_ino;
 	if (S_ISDIR(i->i_mode)) {
-		new_dir->i_nlink++;
+		inc_nlink(new_dir);
 		drop_nlink(old_dir);
 	}
 	if ((fnode = hpfs_map_fnode(i->i_sb, i->i_ino, &bh))) {
diff -puN fs/hugetlbfs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/hugetlbfs/inode.c
--- a/fs/hugetlbfs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/hugetlbfs/inode.c
@@ -377,7 +377,7 @@ static struct inode *hugetlbfs_get_inode
 			inode->i_fop = &simple_dir_operations;
 
 			/* directory inodes start off with i_nlink == 2 (for "." entry) */
-			inode->i_nlink++;
+			inc_nlink(inode);
 			break;
 		case S_IFLNK:
 			inode->i_op = &page_symlink_inode_operations;
@@ -418,7 +418,7 @@ static int hugetlbfs_mkdir(struct inode 
 {
 	int retval = hugetlbfs_mknod(dir, dentry, mode | S_IFDIR, 0);
 	if (!retval)
-		dir->i_nlink++;
+		inc_nlink(dir);
 	return retval;
 }
 
diff -puN fs/jffs2/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/jffs2/dir.c
--- a/fs/jffs2/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/jffs2/dir.c
@@ -588,7 +588,7 @@ static int jffs2_mkdir (struct inode *di
 	}
 
 	dir_i->i_mtime = dir_i->i_ctime = ITIME(je32_to_cpu(rd->mctime));
-	dir_i->i_nlink++;
+	inc_nlink(dir_i);
 
 	jffs2_free_raw_dirent(rd);
 
@@ -836,7 +836,7 @@ static int jffs2_rename (struct inode *o
 	/* If it was a directory we moved, and there was no victim,
 	   increase i_nlink on its new parent */
 	if (S_ISDIR(old_dentry->d_inode->i_mode) && !victim_f)
-		new_dir_i->i_nlink++;
+		inc_nlink(new_dir_i);
 
 	/* Unlink the original */
 	ret = jffs2_do_unlink(c, JFFS2_INODE_INFO(old_dir_i),
@@ -848,7 +848,7 @@ static int jffs2_rename (struct inode *o
 		/* Oh shit. We really ought to make a single node which can do both atomically */
 		struct jffs2_inode_info *f = JFFS2_INODE_INFO(old_dentry->d_inode);
 		down(&f->sem);
-		old_dentry->d_inode->i_nlink++;
+		inc_nlink(old_dentry->d_inode);
 		if (f->inocache)
 			f->inocache->nlink++;
 		up(&f->sem);
diff -puN fs/jffs2/fs.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/jffs2/fs.c
--- a/fs/jffs2/fs.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/jffs2/fs.c
@@ -277,13 +277,13 @@ void jffs2_read_inode (struct inode *ino
 
 		for (fd=f->dents; fd; fd = fd->next) {
 			if (fd->type == DT_DIR && fd->ino)
-				inode->i_nlink++;
+				inc_nlink(inode);
 		}
 		/* and '..' */
-		inode->i_nlink++;
+		inc_nlink(inode);
 		/* Root dir gets i_nlink 3 for some reason */
 		if (inode->i_ino == 1)
-			inode->i_nlink++;
+			inc_nlink(inode);
 
 		inode->i_op = &jffs2_dir_inode_operations;
 		inode->i_fop = &jffs2_dir_operations;
diff -puN fs/jfs/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/jfs/namei.c
--- a/fs/jfs/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/jfs/namei.c
@@ -292,7 +292,7 @@ static int jfs_mkdir(struct inode *dip, 
 	mark_inode_dirty(ip);
 
 	/* update parent directory inode */
-	dip->i_nlink++;		/* for '..' from child directory */
+	inc_nlink(dip);		/* for '..' from child directory */
 	dip->i_ctime = dip->i_mtime = CURRENT_TIME;
 	mark_inode_dirty(dip);
 
@@ -822,7 +822,7 @@ static int jfs_link(struct dentry *old_d
 		goto free_dname;
 
 	/* update object inode */
-	ip->i_nlink++;		/* for new link */
+	inc_nlink(ip);		/* for new link */
 	ip->i_ctime = CURRENT_TIME;
 	dir->i_ctime = dir->i_mtime = CURRENT_TIME;
 	mark_inode_dirty(dir);
@@ -1206,7 +1206,7 @@ static int jfs_rename(struct inode *old_
 			goto out4;
 		}
 		if (S_ISDIR(old_ip->i_mode))
-			new_dir->i_nlink++;
+			inc_nlink(new_dir);
 	}
 	/*
 	 * Remove old directory entry
diff -puN fs/libfs.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/libfs.c
--- a/fs/libfs.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/libfs.c
@@ -243,7 +243,7 @@ int simple_link(struct dentry *old_dentr
 	struct inode *inode = old_dentry->d_inode;
 
 	inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME;
-	inode->i_nlink++;
+	inc_nlink(inode);
 	atomic_inc(&inode->i_count);
 	dget(dentry);
 	d_instantiate(dentry, inode);
@@ -306,7 +306,7 @@ int simple_rename(struct inode *old_dir,
 			drop_nlink(old_dir);
 	} else if (they_are_dirs) {
 		drop_nlink(old_dir);
-		new_dir->i_nlink++;
+		inc_nlink(new_dir);
 	}
 
 	old_dir->i_ctime = old_dir->i_mtime = new_dir->i_ctime =
diff -puN fs/msdos/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/msdos/namei.c
--- a/fs/msdos/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/msdos/namei.c
@@ -389,7 +389,7 @@ static int msdos_mkdir(struct inode *dir
 	err = msdos_add_entry(dir, msdos_name, 1, is_hid, cluster, &ts, &sinfo);
 	if (err)
 		goto out_free;
-	dir->i_nlink++;
+	inc_nlink(dir);
 
 	inode = fat_build_inode(sb, sinfo.de, sinfo.i_pos);
 	brelse(sinfo.bh);
@@ -551,7 +551,7 @@ static int do_msdos_rename(struct inode 
 		}
 		drop_nlink(old_dir);
 		if (!new_inode)
-			new_dir->i_nlink++;
+			inc_nlink(new_dir);
 	}
 
 	err = fat_remove_entries(old_dir, &old_sinfo);	/* and releases bh */
diff -puN fs/ocfs2/dlm/dlmfs.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/ocfs2/dlm/dlmfs.c
--- a/fs/ocfs2/dlm/dlmfs.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/ocfs2/dlm/dlmfs.c
@@ -338,7 +338,7 @@ static struct inode *dlmfs_get_root_inod
 		inode->i_blocks = 0;
 		inode->i_mapping->backing_dev_info = &dlmfs_backing_dev_info;
 		inode->i_atime = inode->i_mtime = inode->i_ctime = CURRENT_TIME;
-		inode->i_nlink++;
+		inc_nlink(inode);
 
 		inode->i_fop = &simple_dir_operations;
 		inode->i_op = &dlmfs_root_inode_operations;
@@ -395,7 +395,7 @@ static struct inode *dlmfs_get_inode(str
 
 		/* directory inodes start off with i_nlink ==
 		 * 2 (for "." entry) */
-		inode->i_nlink++;
+		inc_nlink(inode);
 		break;
 	}
 
@@ -449,7 +449,7 @@ static int dlmfs_mkdir(struct inode * di
 	}
 	ip->ip_dlm = dlm;
 
-	dir->i_nlink++;
+	inc_nlink(dir);
 	d_instantiate(dentry, inode);
 	dget(dentry);	/* Extra count - pin the dentry in core */
 
diff -puN fs/ocfs2/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/ocfs2/namei.c
--- a/fs/ocfs2/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/ocfs2/namei.c
@@ -408,7 +408,7 @@ static int ocfs2_mknod(struct inode *dir
 			mlog_errno(status);
 			goto leave;
 		}
-		dir->i_nlink++;
+		inc_nlink(dir);
 	}
 
 	status = ocfs2_add_entry(handle, dentry, inode,
@@ -702,7 +702,7 @@ static int ocfs2_link(struct dentry *old
 		goto bail;
 	}
 
-	inode->i_nlink++;
+	inc_nlink(inode);
 	inode->i_ctime = CURRENT_TIME;
 	fe->i_links_count = cpu_to_le16(inode->i_nlink);
 	fe->i_ctime = cpu_to_le64(inode->i_ctime.tv_sec);
@@ -902,7 +902,7 @@ static int ocfs2_unlink(struct inode *di
 						parent_node_bh);
 		if (status < 0) {
 			mlog_errno(status);
-			dir->i_nlink++;
+			inc_nlink(dir);
 		}
 	}
 
@@ -1344,7 +1344,7 @@ static int ocfs2_rename(struct inode *ol
 		if (new_inode) {
 			new_inode->i_nlink--;
 		} else {
-			new_dir->i_nlink++;
+			inc_nlink(new_dir);
 			mark_inode_dirty(new_dir);
 		}
 	}
diff -puN fs/ramfs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/ramfs/inode.c
--- a/fs/ramfs/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/ramfs/inode.c
@@ -75,7 +75,7 @@ struct inode *ramfs_get_inode(struct sup
 			inode->i_fop = &simple_dir_operations;
 
 			/* directory inodes start off with i_nlink == 2 (for "." entry) */
-			inode->i_nlink++;
+			inc_nlink(inode);
 			break;
 		case S_IFLNK:
 			inode->i_op = &page_symlink_inode_operations;
@@ -113,7 +113,7 @@ static int ramfs_mkdir(struct inode * di
 {
 	int retval = ramfs_mknod(dir, dentry, mode | S_IFDIR, 0);
 	if (!retval)
-		dir->i_nlink++;
+		inc_nlink(dir);
 	return retval;
 }
 
diff -puN fs/reiserfs/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/reiserfs/namei.c
--- a/fs/reiserfs/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/reiserfs/namei.c
@@ -19,7 +19,7 @@
 #include <linux/smp_lock.h>
 #include <linux/quotaops.h>
 
-#define INC_DIR_INODE_NLINK(i) if (i->i_nlink != 1) { i->i_nlink++; if (i->i_nlink >= REISERFS_LINK_MAX) i->i_nlink=1; }
+#define INC_DIR_INODE_NLINK(i) if (i->i_nlink != 1) { inc_nlink(i); if (i->i_nlink >= REISERFS_LINK_MAX) i->i_nlink=1; }
 #define DEC_DIR_INODE_NLINK(i) if (i->i_nlink != 1) drop_nlink(i);
 
 // directory item contains array of entry headers. This performs
@@ -1006,7 +1006,7 @@ static int reiserfs_unlink(struct inode 
 	    reiserfs_cut_from_item(&th, &path, &(de.de_entry_key), dir, NULL,
 				   0);
 	if (retval < 0) {
-		inode->i_nlink++;
+		inc_nlink(inode);
 		goto end_unlink;
 	}
 	inode->i_ctime = CURRENT_TIME_SEC;
@@ -1143,7 +1143,7 @@ static int reiserfs_link(struct dentry *
 	}
 
 	/* inc before scheduling so reiserfs_unlink knows we are here */
-	inode->i_nlink++;
+	inc_nlink(inode);
 
 	retval = journal_begin(&th, dir->i_sb, jbegin_count);
 	if (retval) {
diff -puN fs/sysfs/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/sysfs/dir.c
--- a/fs/sysfs/dir.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/sysfs/dir.c
@@ -103,7 +103,7 @@ static int init_dir(struct inode * inode
 	inode->i_fop = &sysfs_dir_operations;
 
 	/* directory inodes start off with i_nlink == 2 (for "." entry) */
-	inode->i_nlink++;
+	inc_nlink(inode);
 	return 0;
 }
 
@@ -137,7 +137,7 @@ static int create_dir(struct kobject * k
 		if (!error) {
 			error = sysfs_create(*d, mode, init_dir);
 			if (!error) {
-				p->d_inode->i_nlink++;
+				inc_nlink(p->d_inode);
 				(*d)->d_op = &sysfs_dentry_ops;
 				d_rehash(*d);
 			}
diff -puN fs/sysfs/mount.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/sysfs/mount.c
--- a/fs/sysfs/mount.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/sysfs/mount.c
@@ -49,7 +49,7 @@ static int sysfs_fill_super(struct super
 		inode->i_op = &sysfs_dir_inode_operations;
 		inode->i_fop = &sysfs_dir_operations;
 		/* directory inodes start off with i_nlink == 2 (for "." entry) */
-		inode->i_nlink++;	
+		inc_nlink(inode);
 	} else {
 		pr_debug("sysfs: could not get root inode\n");
 		return -ENOMEM;
diff -puN fs/udf/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/udf/inode.c
--- a/fs/udf/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/udf/inode.c
@@ -1165,7 +1165,7 @@ static void udf_fill_inode(struct inode 
 			inode->i_op = &udf_dir_inode_operations;
 			inode->i_fop = &udf_dir_operations;
 			inode->i_mode |= S_IFDIR;
-			inode->i_nlink ++;
+			inc_nlink(inode);
 			break;
 		}
 		case ICBTAG_FILE_TYPE_REALTIME:
diff -puN fs/udf/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/udf/namei.c
--- a/fs/udf/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/udf/namei.c
@@ -762,7 +762,7 @@ static int udf_mkdir(struct inode * dir,
 		cpu_to_le32(UDF_I_UNIQUE(inode) & 0x00000000FFFFFFFFUL);
 	cfi.fileCharacteristics |= FID_FILE_CHAR_DIRECTORY;
 	udf_write_fi(dir, &cfi, fi, &fibh, NULL, NULL);
-	dir->i_nlink++;
+	inc_nlink(dir);
 	mark_inode_dirty(dir);
 	d_instantiate(dentry, inode);
 	if (fibh.sbh != fibh.ebh)
@@ -1147,7 +1147,7 @@ static int udf_link(struct dentry * old_
 	if (fibh.sbh != fibh.ebh)
 		udf_release_data(fibh.ebh);
 	udf_release_data(fibh.sbh);
-	inode->i_nlink ++;
+	inc_nlink(inode);
 	inode->i_ctime = current_fs_time(inode->i_sb);
 	mark_inode_dirty(inode);
 	atomic_inc(&inode->i_count);
@@ -1282,7 +1282,7 @@ static int udf_rename (struct inode * ol
 		}
 		else
 		{
-			new_dir->i_nlink ++;
+			inc_nlink(new_dir);
 			mark_inode_dirty(new_dir);
 		}
 	}
diff -puN fs/vfat/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper fs/vfat/namei.c
--- a/fs/vfat/namei.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/fs/vfat/namei.c
@@ -837,7 +837,7 @@ static int vfat_mkdir(struct inode *dir,
 	if (err)
 		goto out_free;
 	dir->i_version++;
-	dir->i_nlink++;
+	inc_nlink(dir);
 
 	inode = fat_build_inode(sb, sinfo.de, sinfo.i_pos);
 	brelse(sinfo.bh);
@@ -932,7 +932,7 @@ static int vfat_rename(struct inode *old
 		}
 		drop_nlink(old_dir);
 		if (!new_inode)
- 			new_dir->i_nlink++;
+ 			inc_nlink(new_dir);
 	}
 
 	err = fat_remove_entries(old_dir, &old_sinfo);	/* and releases bh */
diff -puN include/linux/fs.h~r-o-bind-mount-prepwork-inc_nlink-helper include/linux/fs.h
--- a/include/linux/fs.h~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/include/linux/fs.h
@@ -1202,9 +1202,14 @@ static inline void mark_inode_dirty_sync
 	__mark_inode_dirty(inode, I_DIRTY_SYNC);
 }
 
-static inline void inode_inc_link_count(struct inode *inode)
+static inline void inc_nlink(struct inode *inode)
 {
 	inode->i_nlink++;
+}
+
+static inline void inode_inc_link_count(struct inode *inode)
+{
+	inc_nlink(inode);
 	mark_inode_dirty(inode);
 }
 
diff -puN ipc/mqueue.c~r-o-bind-mount-prepwork-inc_nlink-helper ipc/mqueue.c
--- a/ipc/mqueue.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/ipc/mqueue.c
@@ -168,7 +168,7 @@ static struct inode *mqueue_get_inode(st
 			/* all is ok */
 			info->user = get_uid(u);
 		} else if (S_ISDIR(mode)) {
-			inode->i_nlink++;
+			inc_nlink(inode);
 			/* Some things misbehave if size == 0 on a directory */
 			inode->i_size = 2 * DIRENT_SIZE;
 			inode->i_op = &mqueue_dir_inode_operations;
diff -puN kernel/cpuset.c~r-o-bind-mount-prepwork-inc_nlink-helper kernel/cpuset.c
--- a/kernel/cpuset.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/kernel/cpuset.c
@@ -377,7 +377,7 @@ static int cpuset_fill_super(struct supe
 		inode->i_op = &simple_dir_inode_operations;
 		inode->i_fop = &simple_dir_operations;
 		/* directories start off with i_nlink == 2 (for "." entry) */
-		inode->i_nlink++;
+		inc_nlink(inode);
 	} else {
 		return -ENOMEM;
 	}
@@ -1552,7 +1552,7 @@ static int cpuset_create_file(struct den
 		inode->i_fop = &simple_dir_operations;
 
 		/* start off with i_nlink == 2 (for "." entry) */
-		inode->i_nlink++;
+		inc_nlink(inode);
 	} else if (S_ISREG(mode)) {
 		inode->i_size = 0;
 		inode->i_fop = &cpuset_file_operations;
@@ -1585,7 +1585,7 @@ static int cpuset_create_dir(struct cpus
 	error = cpuset_create_file(dentry, S_IFDIR | mode);
 	if (!error) {
 		dentry->d_fsdata = cs;
-		parent->d_inode->i_nlink++;
+		inc_nlink(parent->d_inode);
 		cs->dentry = dentry;
 	}
 	dput(dentry);
@@ -2020,7 +2020,7 @@ int __init cpuset_init(void)
 	}
 	root = cpuset_mount->mnt_sb->s_root;
 	root->d_fsdata = &top_cpuset;
-	root->d_inode->i_nlink++;
+	inc_nlink(root->d_inode);
 	top_cpuset.dentry = root;
 	root->d_inode->i_op = &cpuset_dir_inode_operations;
 	number_of_cpusets = 1;
diff -puN mm/shmem.c~r-o-bind-mount-prepwork-inc_nlink-helper mm/shmem.c
--- a/mm/shmem.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/mm/shmem.c
@@ -1371,7 +1371,7 @@ shmem_get_inode(struct super_block *sb, 
 							&sbinfo->policy_nodes);
 			break;
 		case S_IFDIR:
-			inode->i_nlink++;
+			inc_nlink(inode);
 			/* Some things misbehave if size == 0 on a directory */
 			inode->i_size = 2 * BOGO_DIRENT_SIZE;
 			inode->i_op = &shmem_dir_inode_operations;
@@ -1703,7 +1703,7 @@ static int shmem_mkdir(struct inode *dir
 
 	if ((error = shmem_mknod(dir, dentry, mode | S_IFDIR, 0)))
 		return error;
-	dir->i_nlink++;
+	inc_nlink(dir);
 	return 0;
 }
 
@@ -1738,7 +1738,7 @@ static int shmem_link(struct dentry *old
 
 	dir->i_size += BOGO_DIRENT_SIZE;
 	inode->i_ctime = dir->i_ctime = dir->i_mtime = CURRENT_TIME;
-	inode->i_nlink++;
+	inc_nlink(inode);
 	atomic_inc(&inode->i_count);	/* New dentry reference */
 	dget(dentry);		/* Extra pinning count for the created dentry */
 	d_instantiate(dentry, inode);
@@ -1795,7 +1795,7 @@ static int shmem_rename(struct inode *ol
 			drop_nlink(old_dir);
 	} else if (they_are_dirs) {
 		drop_nlink(old_dir);
-		new_dir->i_nlink++;
+		inc_nlink(new_dir);
 	}
 
 	old_dir->i_size -= BOGO_DIRENT_SIZE;
diff -puN net/sunrpc/rpc_pipe.c~r-o-bind-mount-prepwork-inc_nlink-helper net/sunrpc/rpc_pipe.c
--- a/net/sunrpc/rpc_pipe.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/net/sunrpc/rpc_pipe.c
@@ -496,7 +496,7 @@ rpc_get_inode(struct super_block *sb, in
 		case S_IFDIR:
 			inode->i_fop = &simple_dir_operations;
 			inode->i_op = &simple_dir_inode_operations;
-			inode->i_nlink++;
+			inc_nlink(inode);
 		default:
 			break;
 	}
@@ -572,7 +572,7 @@ rpc_populate(struct dentry *parent,
 		if (private)
 			rpc_inode_setowner(inode, private);
 		if (S_ISDIR(mode))
-			dir->i_nlink++;
+			inc_nlink(dir);
 		d_add(dentry, inode);
 	}
 	mutex_unlock(&dir->i_mutex);
@@ -594,7 +594,7 @@ __rpc_mkdir(struct inode *dir, struct de
 		goto out_err;
 	inode->i_ino = iunique(dir->i_sb, 100);
 	d_instantiate(dentry, inode);
-	dir->i_nlink++;
+	inc_nlink(dir);
 	inode_dir_notify(dir, DN_CREATE);
 	return 0;
 out_err:
diff -puN security/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper security/inode.c
--- a/security/inode.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/security/inode.c
@@ -78,7 +78,7 @@ static struct inode *get_inode(struct su
 			inode->i_fop = &simple_dir_operations;
 
 			/* directory inodes start off with i_nlink == 2 (for "." entry) */
-			inode->i_nlink++;
+			inc_nlink(inode);
 			break;
 		}
 	}
@@ -111,7 +111,7 @@ static int mkdir(struct inode *dir, stru
 	mode = (mode & (S_IRWXUGO | S_ISVTX)) | S_IFDIR;
 	res = mknod(dir, dentry, mode, 0);
 	if (!res)
-		dir->i_nlink++;
+		inc_nlink(dir);
 	return res;
 }
 
diff -puN security/selinux/selinuxfs.c~r-o-bind-mount-prepwork-inc_nlink-helper security/selinux/selinuxfs.c
--- a/security/selinux/selinuxfs.c~r-o-bind-mount-prepwork-inc_nlink-helper
+++ a/security/selinux/selinuxfs.c
@@ -1253,10 +1253,10 @@ static int sel_make_dir(struct inode *di
 	inode->i_op = &simple_dir_inode_operations;
 	inode->i_fop = &simple_dir_operations;
 	/* directory inodes start off with i_nlink == 2 (for "." entry) */
-	inode->i_nlink++;
+	inc_nlink(inode);
 	d_add(dentry, inode);
 	/* bump link count on parent directory, too */
-	dir->i_nlink++;
+	inc_nlink(dir);
 out:
 	return ret;
 }
_

Patches currently in -mm which might be from haveblue@xxxxxxxxxx are

sys_getppid-oopses-on-debug-kernel-v2.patch
bootmem-remove-useless-__init-in-header-file.patch
bootmem-mark-link_bootmem-as-part-of-the-__init-section.patch
bootmem-remove-useless-parentheses-in-bootmem-header.patch
bootmem-limit-to-80-columns-width.patch
bootmem-remove-useless-headers-inclusions.patch
bootmem-use-pfn-page-conversion-macros.patch
bootmem-miscellaneous-coding-style-fixes.patch
avr32-kill-config_discontigmem-support-completely.patch
x86-enable-vmsplit-for-highmem-kernels.patch
kthread-drivers-base-firmware_classc.patch
pidspace-is_init.patch
fs-cache-make-kafs-use-fs-cache-fix.patch
r-o-bind-mount-prepare-for-write-access-checks-collapse-if.patch
r-o-bind-mount-prepwork-move-open_nameis-vfs_create.patch
r-o-bind-mount-unlink-monitor-i_nlink.patch
r-o-bind-mount-prepwork-inc_nlink-helper.patch
r-o-bind-mount-clean-up-ocfs2-nlink-handling.patch
r-o-bind-mount-monitor-zeroing-of-i_nlink.patch
page-owner-tracking-leak-detector.patch
x86-e820-debugging.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux