diff options
| author | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
|---|---|---|
| committer | Mark Brown <broonie@kernel.org> | 2016-02-09 21:20:39 +0300 | 
| commit | fcdcc79628a1919bde9acf239e364f65bab6327c (patch) | |
| tree | 5499be387cf3028c90ac083b1cf866ebed7bf7e0 /fs/xfs/xfs_iops.c | |
| parent | 7a8d44bc89e5cddcd5c0704a11a90484d36ba6ba (diff) | |
| parent | a0a90718f18264dc904d34a580f332006f5561e9 (diff) | |
| download | linux-fcdcc79628a1919bde9acf239e364f65bab6327c.tar.xz | |
Merge branch 'topic/acpi' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi into spi-pxa2xx
Diffstat (limited to 'fs/xfs/xfs_iops.c')
| -rw-r--r-- | fs/xfs/xfs_iops.c | 18 | 
1 files changed, 11 insertions, 7 deletions
| diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c index 245268a0cdf0..76b71a1c6c32 100644 --- a/fs/xfs/xfs_iops.c +++ b/fs/xfs/xfs_iops.c @@ -414,13 +414,17 @@ xfs_vn_rename(   * uio is kmalloced for this reason...   */  STATIC const char * -xfs_vn_follow_link( +xfs_vn_get_link(  	struct dentry		*dentry, -	void			**cookie) +	struct inode		*inode, +	struct delayed_call	*done)  {  	char			*link;  	int			error = -ENOMEM; +	if (!dentry) +		return ERR_PTR(-ECHILD); +  	link = kmalloc(MAXPATHLEN+1, GFP_KERNEL);  	if (!link)  		goto out_err; @@ -429,7 +433,8 @@ xfs_vn_follow_link(  	if (unlikely(error))  		goto out_kfree; -	return *cookie = link; +	set_delayed_call(done, kfree_link, link); +	return link;   out_kfree:  	kfree(link); @@ -1172,8 +1177,7 @@ static const struct inode_operations xfs_dir_ci_inode_operations = {  static const struct inode_operations xfs_symlink_inode_operations = {  	.readlink		= generic_readlink, -	.follow_link		= xfs_vn_follow_link, -	.put_link		= kfree_put_link, +	.get_link		= xfs_vn_get_link,  	.getattr		= xfs_vn_getattr,  	.setattr		= xfs_vn_setattr,  	.setxattr		= generic_setxattr, @@ -1201,8 +1205,8 @@ xfs_diflags_to_iflags(  		inode->i_flags |= S_SYNC;  	if (flags & XFS_DIFLAG_NOATIME)  		inode->i_flags |= S_NOATIME; -	/* XXX: Also needs an on-disk per inode flag! */ -	if (ip->i_mount->m_flags & XFS_MOUNT_DAX) +	if (ip->i_mount->m_flags & XFS_MOUNT_DAX || +	    ip->i_d.di_flags2 & XFS_DIFLAG2_DAX)  		inode->i_flags |= S_DAX;  } | 
