Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
ae2a9762
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
ae2a9762
编写于
6月 03, 2017
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
compat statfs: switch to copy_to_user()
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
4d7edbc3
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
30 addition
and
28 deletion
+30
-28
fs/statfs.c
fs/statfs.c
+30
-28
未找到文件。
fs/statfs.c
浏览文件 @
ae2a9762
...
@@ -244,6 +244,7 @@ SYSCALL_DEFINE2(ustat, unsigned, dev, struct ustat __user *, ubuf)
...
@@ -244,6 +244,7 @@ SYSCALL_DEFINE2(ustat, unsigned, dev, struct ustat __user *, ubuf)
#ifdef CONFIG_COMPAT
#ifdef CONFIG_COMPAT
static
int
put_compat_statfs
(
struct
compat_statfs
__user
*
ubuf
,
struct
kstatfs
*
kbuf
)
static
int
put_compat_statfs
(
struct
compat_statfs
__user
*
ubuf
,
struct
kstatfs
*
kbuf
)
{
{
struct
compat_statfs
buf
;
if
(
sizeof
ubuf
->
f_blocks
==
4
)
{
if
(
sizeof
ubuf
->
f_blocks
==
4
)
{
if
((
kbuf
->
f_blocks
|
kbuf
->
f_bfree
|
kbuf
->
f_bavail
|
if
((
kbuf
->
f_blocks
|
kbuf
->
f_bfree
|
kbuf
->
f_bavail
|
kbuf
->
f_bsize
|
kbuf
->
f_frsize
)
&
0xffffffff00000000ULL
)
kbuf
->
f_bsize
|
kbuf
->
f_frsize
)
&
0xffffffff00000000ULL
)
...
@@ -257,20 +258,20 @@ static int put_compat_statfs(struct compat_statfs __user *ubuf, struct kstatfs *
...
@@ -257,20 +258,20 @@ static int put_compat_statfs(struct compat_statfs __user *ubuf, struct kstatfs *
&&
(
kbuf
->
f_ffree
&
0xffffffff00000000ULL
))
&&
(
kbuf
->
f_ffree
&
0xffffffff00000000ULL
))
return
-
EOVERFLOW
;
return
-
EOVERFLOW
;
}
}
if
(
!
access_ok
(
VERIFY_WRITE
,
ubuf
,
sizeof
(
*
ubuf
))
||
memset
(
&
buf
,
0
,
sizeof
(
struct
compat_statfs
));
__put_user
(
kbuf
->
f_type
,
&
ubuf
->
f_type
)
||
buf
.
f_type
=
kbuf
->
f_type
;
__put_user
(
kbuf
->
f_bsize
,
&
ubuf
->
f_bsize
)
||
buf
.
f_bsize
=
kbuf
->
f_bsize
;
__put_user
(
kbuf
->
f_blocks
,
&
ubuf
->
f_blocks
)
||
buf
.
f_blocks
=
kbuf
->
f_blocks
;
__put_user
(
kbuf
->
f_bfree
,
&
ubuf
->
f_bfree
)
||
buf
.
f_bfree
=
kbuf
->
f_bfree
;
__put_user
(
kbuf
->
f_bavail
,
&
ubuf
->
f_bavail
)
||
buf
.
f_bavail
=
kbuf
->
f_bavail
;
__put_user
(
kbuf
->
f_files
,
&
ubuf
->
f_files
)
||
buf
.
f_files
=
kbuf
->
f_files
;
__put_user
(
kbuf
->
f_ffree
,
&
ubuf
->
f_ffree
)
||
buf
.
f_ffree
=
kbuf
->
f_ffree
;
__put_user
(
kbuf
->
f_namelen
,
&
ubuf
->
f_namelen
)
||
buf
.
f_namelen
=
kbuf
->
f_namelen
;
__put_user
(
kbuf
->
f_fsid
.
val
[
0
],
&
ubuf
->
f_fsid
.
val
[
0
])
||
buf
.
f_fsid
.
val
[
0
]
=
kbuf
->
f_fsid
.
val
[
0
];
__put_user
(
kbuf
->
f_fsid
.
val
[
1
],
&
ubuf
->
f_fsid
.
val
[
1
])
||
buf
.
f_fsid
.
val
[
1
]
=
kbuf
->
f_fsid
.
val
[
1
];
__put_user
(
kbuf
->
f_frsize
,
&
ubuf
->
f_frsize
)
||
buf
.
f_frsize
=
kbuf
->
f_frsize
;
__put_user
(
kbuf
->
f_flags
,
&
ubuf
->
f_flags
)
||
buf
.
f_flags
=
kbuf
->
f_flags
;
__clear_user
(
ubuf
->
f_spare
,
sizeof
(
ubuf
->
f_spare
)))
if
(
copy_to_user
(
ubuf
,
&
buf
,
sizeof
(
struct
compat_statfs
)))
return
-
EFAULT
;
return
-
EFAULT
;
return
0
;
return
0
;
}
}
...
@@ -299,6 +300,7 @@ COMPAT_SYSCALL_DEFINE2(fstatfs, unsigned int, fd, struct compat_statfs __user *,
...
@@ -299,6 +300,7 @@ COMPAT_SYSCALL_DEFINE2(fstatfs, unsigned int, fd, struct compat_statfs __user *,
static
int
put_compat_statfs64
(
struct
compat_statfs64
__user
*
ubuf
,
struct
kstatfs
*
kbuf
)
static
int
put_compat_statfs64
(
struct
compat_statfs64
__user
*
ubuf
,
struct
kstatfs
*
kbuf
)
{
{
struct
compat_statfs64
buf
;
if
(
sizeof
(
ubuf
->
f_bsize
)
==
4
)
{
if
(
sizeof
(
ubuf
->
f_bsize
)
==
4
)
{
if
((
kbuf
->
f_type
|
kbuf
->
f_bsize
|
kbuf
->
f_namelen
|
if
((
kbuf
->
f_type
|
kbuf
->
f_bsize
|
kbuf
->
f_namelen
|
kbuf
->
f_frsize
|
kbuf
->
f_flags
)
&
0xffffffff00000000ULL
)
kbuf
->
f_frsize
|
kbuf
->
f_flags
)
&
0xffffffff00000000ULL
)
...
@@ -312,20 +314,20 @@ static int put_compat_statfs64(struct compat_statfs64 __user *ubuf, struct kstat
...
@@ -312,20 +314,20 @@ static int put_compat_statfs64(struct compat_statfs64 __user *ubuf, struct kstat
&&
(
kbuf
->
f_ffree
&
0xffffffff00000000ULL
))
&&
(
kbuf
->
f_ffree
&
0xffffffff00000000ULL
))
return
-
EOVERFLOW
;
return
-
EOVERFLOW
;
}
}
if
(
!
access_ok
(
VERIFY_WRITE
,
ubuf
,
sizeof
(
*
ubuf
))
||
memset
(
&
buf
,
0
,
sizeof
(
struct
compat_statfs64
));
__put_user
(
kbuf
->
f_type
,
&
ubuf
->
f_type
)
||
buf
.
f_type
=
kbuf
->
f_type
;
__put_user
(
kbuf
->
f_bsize
,
&
ubuf
->
f_bsize
)
||
buf
.
f_bsize
=
kbuf
->
f_bsize
;
__put_user
(
kbuf
->
f_blocks
,
&
ubuf
->
f_blocks
)
||
buf
.
f_blocks
=
kbuf
->
f_blocks
;
__put_user
(
kbuf
->
f_bfree
,
&
ubuf
->
f_bfree
)
||
buf
.
f_bfree
=
kbuf
->
f_bfree
;
__put_user
(
kbuf
->
f_bavail
,
&
ubuf
->
f_bavail
)
||
buf
.
f_bavail
=
kbuf
->
f_bavail
;
__put_user
(
kbuf
->
f_files
,
&
ubuf
->
f_files
)
||
buf
.
f_files
=
kbuf
->
f_files
;
__put_user
(
kbuf
->
f_ffree
,
&
ubuf
->
f_ffree
)
||
buf
.
f_ffree
=
kbuf
->
f_ffree
;
__put_user
(
kbuf
->
f_namelen
,
&
ubuf
->
f_namelen
)
||
buf
.
f_namelen
=
kbuf
->
f_namelen
;
__put_user
(
kbuf
->
f_fsid
.
val
[
0
],
&
ubuf
->
f_fsid
.
val
[
0
])
||
buf
.
f_fsid
.
val
[
0
]
=
kbuf
->
f_fsid
.
val
[
0
];
__put_user
(
kbuf
->
f_fsid
.
val
[
1
],
&
ubuf
->
f_fsid
.
val
[
1
])
||
buf
.
f_fsid
.
val
[
1
]
=
kbuf
->
f_fsid
.
val
[
1
];
__put_user
(
kbuf
->
f_frsize
,
&
ubuf
->
f_frsize
)
||
buf
.
f_frsize
=
kbuf
->
f_frsize
;
__put_user
(
kbuf
->
f_flags
,
&
ubuf
->
f_flags
)
||
buf
.
f_flags
=
kbuf
->
f_flags
;
__clear_user
(
ubuf
->
f_spare
,
sizeof
(
ubuf
->
f_spare
)))
if
(
copy_to_user
(
ubuf
,
&
buf
,
sizeof
(
struct
compat_statfs64
)))
return
-
EFAULT
;
return
-
EFAULT
;
return
0
;
return
0
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录