diff options
author | Christoph Hellwig <hch@lst.de> | 2019-08-16 02:41:06 -0400 |
---|---|---|
committer | Darrick J. Wong <darrick.wong@oracle.com> | 2019-08-16 21:42:59 -0400 |
commit | 4529e6d7a6ab727aa85b1dd3cbfa9e82f10f730d (patch) | |
tree | 1b226edd697266ddb56894ee7fcc95e49f34624e /fs/xfs | |
parent | 314e01a6d7ddf04608440beb087b21d8aa32f03f (diff) |
xfs: compat_ioctl: use compat_ptr()
For 31-bit s390 user space, we have to pass pointer arguments through
compat_ptr() in the compat_ioctl handler.
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Eric Sandeen <sandeen@redhat.com>
Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Diffstat (limited to 'fs/xfs')
-rw-r--r-- | fs/xfs/xfs_ioctl32.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/xfs/xfs_ioctl32.c b/fs/xfs/xfs_ioctl32.c index bae08ef92ac3..7bd7534f5051 100644 --- a/fs/xfs/xfs_ioctl32.c +++ b/fs/xfs/xfs_ioctl32.c | |||
@@ -547,7 +547,7 @@ xfs_file_compat_ioctl( | |||
547 | struct inode *inode = file_inode(filp); | 547 | struct inode *inode = file_inode(filp); |
548 | struct xfs_inode *ip = XFS_I(inode); | 548 | struct xfs_inode *ip = XFS_I(inode); |
549 | struct xfs_mount *mp = ip->i_mount; | 549 | struct xfs_mount *mp = ip->i_mount; |
550 | void __user *arg = (void __user *)p; | 550 | void __user *arg = compat_ptr(p); |
551 | int error; | 551 | int error; |
552 | 552 | ||
553 | trace_xfs_file_compat_ioctl(ip); | 553 | trace_xfs_file_compat_ioctl(ip); |
@@ -655,6 +655,6 @@ xfs_file_compat_ioctl( | |||
655 | return xfs_compat_fssetdm_by_handle(filp, arg); | 655 | return xfs_compat_fssetdm_by_handle(filp, arg); |
656 | default: | 656 | default: |
657 | /* try the native version */ | 657 | /* try the native version */ |
658 | return xfs_file_ioctl(filp, cmd, p); | 658 | return xfs_file_ioctl(filp, cmd, (unsigned long)arg); |
659 | } | 659 | } |
660 | } | 660 | } |