Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
680b3024
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看板
提交
680b3024
编写于
1月 25, 2015
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fold debugfs_mknod() into callers
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
3473cde5
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
31 addition
and
37 deletion
+31
-37
fs/debugfs/inode.c
fs/debugfs/inode.c
+31
-37
未找到文件。
fs/debugfs/inode.c
浏览文件 @
680b3024
...
@@ -69,21 +69,6 @@ static struct inode *debugfs_get_inode(struct super_block *sb, umode_t mode, dev
...
@@ -69,21 +69,6 @@ static struct inode *debugfs_get_inode(struct super_block *sb, umode_t mode, dev
return
inode
;
return
inode
;
}
}
/* SMP-safe */
static
int
debugfs_mknod
(
struct
dentry
*
dentry
,
umode_t
mode
,
void
*
data
,
const
struct
file_operations
*
fops
)
{
struct
inode
*
inode
;
inode
=
debugfs_get_inode
(
dentry
->
d_sb
,
mode
,
0
,
data
,
fops
);
if
(
unlikely
(
!
inode
))
return
-
EPERM
;
d_instantiate
(
dentry
,
inode
);
dget
(
dentry
);
return
0
;
}
static
inline
int
debugfs_positive
(
struct
dentry
*
dentry
)
static
inline
int
debugfs_positive
(
struct
dentry
*
dentry
)
{
{
return
dentry
->
d_inode
&&
!
d_unhashed
(
dentry
);
return
dentry
->
d_inode
&&
!
d_unhashed
(
dentry
);
...
@@ -339,7 +324,7 @@ struct dentry *debugfs_create_file(const char *name, umode_t mode,
...
@@ -339,7 +324,7 @@ struct dentry *debugfs_create_file(const char *name, umode_t mode,
const
struct
file_operations
*
fops
)
const
struct
file_operations
*
fops
)
{
{
struct
dentry
*
dentry
;
struct
dentry
*
dentry
;
int
error
;
struct
inode
*
inode
;
if
(
!
(
mode
&
S_IFMT
))
if
(
!
(
mode
&
S_IFMT
))
mode
|=
S_IFREG
;
mode
|=
S_IFREG
;
...
@@ -349,10 +334,14 @@ struct dentry *debugfs_create_file(const char *name, umode_t mode,
...
@@ -349,10 +334,14 @@ struct dentry *debugfs_create_file(const char *name, umode_t mode,
if
(
IS_ERR
(
dentry
))
if
(
IS_ERR
(
dentry
))
return
NULL
;
return
NULL
;
error
=
debugfs_mknod
(
dentry
,
mode
,
data
,
fops
);
inode
=
debugfs_get_inode
(
dentry
->
d_sb
,
mode
,
0
,
data
,
fops
);
if
(
!
error
)
if
(
unlikely
(
!
inode
))
fsnotify_create
(
dentry
->
d_parent
->
d_inode
,
dentry
);
return
end_creating
(
dentry
,
-
ENOMEM
);
return
end_creating
(
dentry
,
error
);
d_instantiate
(
dentry
,
inode
);
dget
(
dentry
);
fsnotify_create
(
dentry
->
d_parent
->
d_inode
,
dentry
);
return
end_creating
(
dentry
,
0
);
}
}
EXPORT_SYMBOL_GPL
(
debugfs_create_file
);
EXPORT_SYMBOL_GPL
(
debugfs_create_file
);
...
@@ -377,18 +366,22 @@ EXPORT_SYMBOL_GPL(debugfs_create_file);
...
@@ -377,18 +366,22 @@ EXPORT_SYMBOL_GPL(debugfs_create_file);
struct
dentry
*
debugfs_create_dir
(
const
char
*
name
,
struct
dentry
*
parent
)
struct
dentry
*
debugfs_create_dir
(
const
char
*
name
,
struct
dentry
*
parent
)
{
{
struct
dentry
*
dentry
=
start_creating
(
name
,
parent
);
struct
dentry
*
dentry
=
start_creating
(
name
,
parent
);
int
error
;
struct
inode
*
inode
;
if
(
IS_ERR
(
dentry
))
if
(
IS_ERR
(
dentry
))
return
NULL
;
return
NULL
;
error
=
debugfs_mknod
(
dentry
,
S_IFDIR
|
S_IRWXU
|
S_IRUGO
|
S_IXUGO
,
inode
=
debugfs_get_inode
(
dentry
->
d_sb
,
NULL
,
NULL
);
S_IFDIR
|
S_IRWXU
|
S_IRUGO
|
S_IXUGO
,
if
(
!
error
)
{
0
,
NULL
,
NULL
);
inc_nlink
(
dentry
->
d_parent
->
d_inode
);
if
(
unlikely
(
!
inode
))
fsnotify_mkdir
(
dentry
->
d_parent
->
d_inode
,
dentry
);
return
end_creating
(
dentry
,
-
ENOMEM
);
}
return
end_creating
(
dentry
,
error
);
d_instantiate
(
dentry
,
inode
);
dget
(
dentry
);
inc_nlink
(
dentry
->
d_parent
->
d_inode
);
fsnotify_mkdir
(
dentry
->
d_parent
->
d_inode
,
dentry
);
return
end_creating
(
dentry
,
0
);
}
}
EXPORT_SYMBOL_GPL
(
debugfs_create_dir
);
EXPORT_SYMBOL_GPL
(
debugfs_create_dir
);
...
@@ -419,25 +412,26 @@ struct dentry *debugfs_create_symlink(const char *name, struct dentry *parent,
...
@@ -419,25 +412,26 @@ struct dentry *debugfs_create_symlink(const char *name, struct dentry *parent,
const
char
*
target
)
const
char
*
target
)
{
{
struct
dentry
*
dentry
;
struct
dentry
*
dentry
;
char
*
link
;
struct
inode
*
inode
;
int
error
;
char
*
link
=
kstrdup
(
target
,
GFP_KERNEL
);
link
=
kstrdup
(
target
,
GFP_KERNEL
);
if
(
!
link
)
if
(
!
link
)
return
NULL
;
return
NULL
;
dentry
=
start_creating
(
name
,
parent
);
dentry
=
start_creating
(
name
,
parent
);
if
(
IS_ERR
(
dentry
))
{
if
(
IS_ERR
(
dentry
))
{
kfree
(
link
);
kfree
(
link
);
return
NULL
;
return
NULL
;
}
}
error
=
debugfs_mknod
(
dentry
,
S_IFLNK
|
S_IRWXUGO
,
link
,
NULL
);
inode
=
debugfs_get_inode
(
dentry
->
d_sb
,
S_IFLNK
|
S_IRWXUGO
,
0
,
if
(
error
)
link
,
NULL
);
if
(
unlikely
(
!
inode
))
{
kfree
(
link
);
kfree
(
link
);
return
end_creating
(
dentry
,
-
ENOMEM
);
return
end_creating
(
dentry
,
error
);
}
d_instantiate
(
dentry
,
inode
);
dget
(
dentry
);
return
end_creating
(
dentry
,
0
);
}
}
EXPORT_SYMBOL_GPL
(
debugfs_create_symlink
);
EXPORT_SYMBOL_GPL
(
debugfs_create_symlink
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录