Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
f6a56903
Commit
f6a56903
authored
Apr 12, 2012
by
Al Viro
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ocfs2: deal with __user misannotations
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
85158410
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
16 additions
and
21 deletions
+16
-21
fs/ocfs2/ioctl.c
fs/ocfs2/ioctl.c
+14
-17
fs/ocfs2/move_extents.c
fs/ocfs2/move_extents.c
+2
-4
No files found.
fs/ocfs2/ioctl.c
View file @
f6a56903
...
@@ -864,7 +864,7 @@ int ocfs2_info_handle(struct inode *inode, struct ocfs2_info *info,
...
@@ -864,7 +864,7 @@ int ocfs2_info_handle(struct inode *inode, struct ocfs2_info *info,
if
(
status
)
if
(
status
)
break
;
break
;
reqp
=
(
struct
ocfs2_info_request
*
)(
unsigned
long
)
req_addr
;
reqp
=
(
struct
ocfs2_info_request
__user
*
)(
unsigned
long
)
req_addr
;
if
(
!
reqp
)
{
if
(
!
reqp
)
{
status
=
-
EINVAL
;
status
=
-
EINVAL
;
goto
bail
;
goto
bail
;
...
@@ -888,9 +888,11 @@ long ocfs2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
...
@@ -888,9 +888,11 @@ long ocfs2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
struct
ocfs2_space_resv
sr
;
struct
ocfs2_space_resv
sr
;
struct
ocfs2_new_group_input
input
;
struct
ocfs2_new_group_input
input
;
struct
reflink_arguments
args
;
struct
reflink_arguments
args
;
const
char
*
old_path
,
*
new_path
;
const
char
__user
*
old_path
;
const
char
__user
*
new_path
;
bool
preserve
;
bool
preserve
;
struct
ocfs2_info
info
;
struct
ocfs2_info
info
;
void
__user
*
argp
=
(
void
__user
*
)
arg
;
switch
(
cmd
)
{
switch
(
cmd
)
{
case
OCFS2_IOC_GETFLAGS
:
case
OCFS2_IOC_GETFLAGS
:
...
@@ -937,17 +939,15 @@ long ocfs2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
...
@@ -937,17 +939,15 @@ long ocfs2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
return
ocfs2_group_add
(
inode
,
&
input
);
return
ocfs2_group_add
(
inode
,
&
input
);
case
OCFS2_IOC_REFLINK
:
case
OCFS2_IOC_REFLINK
:
if
(
copy_from_user
(
&
args
,
(
struct
reflink_arguments
*
)
arg
,
if
(
copy_from_user
(
&
args
,
argp
,
sizeof
(
args
)))
sizeof
(
args
)))
return
-
EFAULT
;
return
-
EFAULT
;
old_path
=
(
const
char
*
)(
unsigned
long
)
args
.
old_path
;
old_path
=
(
const
char
__user
*
)(
unsigned
long
)
args
.
old_path
;
new_path
=
(
const
char
*
)(
unsigned
long
)
args
.
new_path
;
new_path
=
(
const
char
__user
*
)(
unsigned
long
)
args
.
new_path
;
preserve
=
(
args
.
preserve
!=
0
);
preserve
=
(
args
.
preserve
!=
0
);
return
ocfs2_reflink_ioctl
(
inode
,
old_path
,
new_path
,
preserve
);
return
ocfs2_reflink_ioctl
(
inode
,
old_path
,
new_path
,
preserve
);
case
OCFS2_IOC_INFO
:
case
OCFS2_IOC_INFO
:
if
(
copy_from_user
(
&
info
,
(
struct
ocfs2_info
__user
*
)
arg
,
if
(
copy_from_user
(
&
info
,
argp
,
sizeof
(
struct
ocfs2_info
)))
sizeof
(
struct
ocfs2_info
)))
return
-
EFAULT
;
return
-
EFAULT
;
return
ocfs2_info_handle
(
inode
,
&
info
,
0
);
return
ocfs2_info_handle
(
inode
,
&
info
,
0
);
...
@@ -960,22 +960,20 @@ long ocfs2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
...
@@ -960,22 +960,20 @@ long ocfs2_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
if
(
!
capable
(
CAP_SYS_ADMIN
))
if
(
!
capable
(
CAP_SYS_ADMIN
))
return
-
EPERM
;
return
-
EPERM
;
if
(
copy_from_user
(
&
range
,
(
struct
fstrim_range
*
)
arg
,
if
(
copy_from_user
(
&
range
,
argp
,
sizeof
(
range
)))
sizeof
(
range
)))
return
-
EFAULT
;
return
-
EFAULT
;
ret
=
ocfs2_trim_fs
(
sb
,
&
range
);
ret
=
ocfs2_trim_fs
(
sb
,
&
range
);
if
(
ret
<
0
)
if
(
ret
<
0
)
return
ret
;
return
ret
;
if
(
copy_to_user
((
struct
fstrim_range
*
)
arg
,
&
range
,
if
(
copy_to_user
(
argp
,
&
range
,
sizeof
(
range
)))
sizeof
(
range
)))
return
-
EFAULT
;
return
-
EFAULT
;
return
0
;
return
0
;
}
}
case
OCFS2_IOC_MOVE_EXT
:
case
OCFS2_IOC_MOVE_EXT
:
return
ocfs2_ioctl_move_extents
(
filp
,
(
void
__user
*
)
arg
);
return
ocfs2_ioctl_move_extents
(
filp
,
argp
);
default:
default:
return
-
ENOTTY
;
return
-
ENOTTY
;
}
}
...
@@ -988,6 +986,7 @@ long ocfs2_compat_ioctl(struct file *file, unsigned cmd, unsigned long arg)
...
@@ -988,6 +986,7 @@ long ocfs2_compat_ioctl(struct file *file, unsigned cmd, unsigned long arg)
struct
reflink_arguments
args
;
struct
reflink_arguments
args
;
struct
inode
*
inode
=
file
->
f_path
.
dentry
->
d_inode
;
struct
inode
*
inode
=
file
->
f_path
.
dentry
->
d_inode
;
struct
ocfs2_info
info
;
struct
ocfs2_info
info
;
void
__user
*
argp
=
(
void
__user
*
)
arg
;
switch
(
cmd
)
{
switch
(
cmd
)
{
case
OCFS2_IOC32_GETFLAGS
:
case
OCFS2_IOC32_GETFLAGS
:
...
@@ -1006,16 +1005,14 @@ long ocfs2_compat_ioctl(struct file *file, unsigned cmd, unsigned long arg)
...
@@ -1006,16 +1005,14 @@ long ocfs2_compat_ioctl(struct file *file, unsigned cmd, unsigned long arg)
case
FITRIM
:
case
FITRIM
:
break
;
break
;
case
OCFS2_IOC_REFLINK
:
case
OCFS2_IOC_REFLINK
:
if
(
copy_from_user
(
&
args
,
(
struct
reflink_arguments
*
)
arg
,
if
(
copy_from_user
(
&
args
,
argp
,
sizeof
(
args
)))
sizeof
(
args
)))
return
-
EFAULT
;
return
-
EFAULT
;
preserve
=
(
args
.
preserve
!=
0
);
preserve
=
(
args
.
preserve
!=
0
);
return
ocfs2_reflink_ioctl
(
inode
,
compat_ptr
(
args
.
old_path
),
return
ocfs2_reflink_ioctl
(
inode
,
compat_ptr
(
args
.
old_path
),
compat_ptr
(
args
.
new_path
),
preserve
);
compat_ptr
(
args
.
new_path
),
preserve
);
case
OCFS2_IOC_INFO
:
case
OCFS2_IOC_INFO
:
if
(
copy_from_user
(
&
info
,
(
struct
ocfs2_info
__user
*
)
arg
,
if
(
copy_from_user
(
&
info
,
argp
,
sizeof
(
struct
ocfs2_info
)))
sizeof
(
struct
ocfs2_info
)))
return
-
EFAULT
;
return
-
EFAULT
;
return
ocfs2_info_handle
(
inode
,
&
info
,
1
);
return
ocfs2_info_handle
(
inode
,
&
info
,
1
);
...
...
fs/ocfs2/move_extents.c
View file @
f6a56903
...
@@ -1082,8 +1082,7 @@ int ocfs2_ioctl_move_extents(struct file *filp, void __user *argp)
...
@@ -1082,8 +1082,7 @@ int ocfs2_ioctl_move_extents(struct file *filp, void __user *argp)
context
->
file
=
filp
;
context
->
file
=
filp
;
if
(
argp
)
{
if
(
argp
)
{
if
(
copy_from_user
(
&
range
,
(
struct
ocfs2_move_extents
*
)
argp
,
if
(
copy_from_user
(
&
range
,
argp
,
sizeof
(
range
)))
{
sizeof
(
range
)))
{
status
=
-
EFAULT
;
status
=
-
EFAULT
;
goto
out
;
goto
out
;
}
}
...
@@ -1138,8 +1137,7 @@ int ocfs2_ioctl_move_extents(struct file *filp, void __user *argp)
...
@@ -1138,8 +1137,7 @@ int ocfs2_ioctl_move_extents(struct file *filp, void __user *argp)
* length and new_offset even if failure happens somewhere.
* length and new_offset even if failure happens somewhere.
*/
*/
if
(
argp
)
{
if
(
argp
)
{
if
(
copy_to_user
((
struct
ocfs2_move_extents
*
)
argp
,
&
range
,
if
(
copy_to_user
(
argp
,
&
range
,
sizeof
(
range
)))
sizeof
(
range
)))
status
=
-
EFAULT
;
status
=
-
EFAULT
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment