Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
30524472
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
30524472
编写于
7月 22, 2008
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[PATCH] take noexec checks to very few callers that care
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
e56b6a5d
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
17 addition
and
9 deletion
+17
-9
fs/exec.c
fs/exec.c
+7
-0
fs/namei.c
fs/namei.c
+0
-9
fs/open.c
fs/open.c
+10
-0
未找到文件。
fs/exec.c
浏览文件 @
30524472
...
...
@@ -118,6 +118,10 @@ asmlinkage long sys_uselib(const char __user * library)
if
(
!
S_ISREG
(
nd
.
path
.
dentry
->
d_inode
->
i_mode
))
goto
exit
;
error
=
-
EACCES
;
if
(
nd
.
path
.
mnt
->
mnt_flags
&
MNT_NOEXEC
)
goto
exit
;
error
=
vfs_permission
(
&
nd
,
MAY_READ
|
MAY_EXEC
|
MAY_OPEN
);
if
(
error
)
goto
exit
;
...
...
@@ -668,6 +672,9 @@ struct file *open_exec(const char *name)
if
(
!
S_ISREG
(
nd
.
path
.
dentry
->
d_inode
->
i_mode
))
goto
out_path_put
;
if
(
nd
.
path
.
mnt
->
mnt_flags
&
MNT_NOEXEC
)
goto
out_path_put
;
err
=
vfs_permission
(
&
nd
,
MAY_EXEC
|
MAY_OPEN
);
if
(
err
)
goto
out_path_put
;
...
...
fs/namei.c
浏览文件 @
30524472
...
...
@@ -252,15 +252,6 @@ int permission(struct inode *inode, int mask, struct nameidata *nd)
return
-
EACCES
;
}
if
((
mask
&
MAY_EXEC
)
&&
S_ISREG
(
inode
->
i_mode
))
{
/*
* MAY_EXEC on regular files is denied if the fs is mounted
* with the "noexec" flag.
*/
if
(
mnt
&&
(
mnt
->
mnt_flags
&
MNT_NOEXEC
))
return
-
EACCES
;
}
/* Ordinary permission routines do not understand MAY_APPEND. */
if
(
inode
->
i_op
&&
inode
->
i_op
->
permission
)
{
retval
=
inode
->
i_op
->
permission
(
inode
,
mask
);
...
...
fs/open.c
浏览文件 @
30524472
...
...
@@ -461,6 +461,16 @@ asmlinkage long sys_faccessat(int dfd, const char __user *filename, int mode)
if
(
res
)
goto
out
;
if
((
mode
&
MAY_EXEC
)
&&
S_ISREG
(
nd
.
path
.
dentry
->
d_inode
->
i_mode
))
{
/*
* MAY_EXEC on regular files is denied if the fs is mounted
* with the "noexec" flag.
*/
res
=
-
EACCES
;
if
(
nd
.
path
.
mnt
->
mnt_flags
&
MNT_NOEXEC
)
goto
out_path_release
;
}
res
=
vfs_permission
(
&
nd
,
mode
|
MAY_ACCESS
);
/* SuS v2 requires we report a read only fs too */
if
(
res
||
!
(
mode
&
S_IWOTH
)
||
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录