diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2011-05-14 12:06:36 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2011-05-14 12:06:36 +0200 | 
| commit | a18f22a968de17b29f2310cdb7ba69163e65ec15 (patch) | |
| tree | a7d56d88fad5e444d7661484109758a2f436129e /fs/ecryptfs/dentry.c | |
| parent | a1c57e0fec53defe745e64417eacdbd3618c3e66 (diff) | |
| parent | 798778b8653f64b7b2162ac70eca10367cff6ce8 (diff) | |
Merge branch 'consolidate-clksrc-i8253' of master.kernel.org:~rmk/linux-2.6-arm into timers/clocksource
Conflicts:
	arch/ia64/kernel/cyclone.c
	arch/mips/kernel/i8253.c
	arch/x86/kernel/i8253.c
Reason: Resolve conflicts so further cleanups do not conflict further
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'fs/ecryptfs/dentry.c')
| -rw-r--r-- | fs/ecryptfs/dentry.c | 22 | 
1 files changed, 13 insertions, 9 deletions
diff --git a/fs/ecryptfs/dentry.c b/fs/ecryptfs/dentry.c index 6fc4f319b550..534c1d46e69e 100644 --- a/fs/ecryptfs/dentry.c +++ b/fs/ecryptfs/dentry.c @@ -46,24 +46,28 @@ static int ecryptfs_d_revalidate(struct dentry *dentry, struct nameidata *nd)  {  	struct dentry *lower_dentry;  	struct vfsmount *lower_mnt; -	struct dentry *dentry_save; -	struct vfsmount *vfsmount_save; +	struct dentry *dentry_save = NULL; +	struct vfsmount *vfsmount_save = NULL;  	int rc = 1; -	if (nd->flags & LOOKUP_RCU) +	if (nd && nd->flags & LOOKUP_RCU)  		return -ECHILD;  	lower_dentry = ecryptfs_dentry_to_lower(dentry);  	lower_mnt = ecryptfs_dentry_to_lower_mnt(dentry);  	if (!lower_dentry->d_op || !lower_dentry->d_op->d_revalidate)  		goto out; -	dentry_save = nd->path.dentry; -	vfsmount_save = nd->path.mnt; -	nd->path.dentry = lower_dentry; -	nd->path.mnt = lower_mnt; +	if (nd) { +		dentry_save = nd->path.dentry; +		vfsmount_save = nd->path.mnt; +		nd->path.dentry = lower_dentry; +		nd->path.mnt = lower_mnt; +	}  	rc = lower_dentry->d_op->d_revalidate(lower_dentry, nd); -	nd->path.dentry = dentry_save; -	nd->path.mnt = vfsmount_save; +	if (nd) { +		nd->path.dentry = dentry_save; +		nd->path.mnt = vfsmount_save; +	}  	if (dentry->d_inode) {  		struct inode *lower_inode =  			ecryptfs_inode_to_lower(dentry->d_inode);  | 
