Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
fe251042
K
Kernel
项目概览
openeuler
/
Kernel
大约 1 年 前同步成功
通知
5
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
fe251042
编写于
10月 04, 2008
作者:
A
Alexey Dobriyan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
proc: move /proc/devices code to fs/proc/devices.c
Signed-off-by:
N
Alexey Dobriyan
<
adobriyan@gmail.com
>
上级
d8ba7a36
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
71 addition
and
60 deletion
+71
-60
fs/proc/Makefile
fs/proc/Makefile
+1
-0
fs/proc/devices.c
fs/proc/devices.c
+70
-0
fs/proc/proc_misc.c
fs/proc/proc_misc.c
+0
-60
未找到文件。
fs/proc/Makefile
浏览文件 @
fe251042
...
...
@@ -10,6 +10,7 @@ proc-$(CONFIG_MMU) := mmu.o task_mmu.o
proc-y
+=
inode.o root.o base.o generic.o array.o
\
proc_tty.o proc_misc.o
proc-y
+=
cmdline.o
proc-y
+=
devices.o
proc-y
+=
loadavg.o
proc-y
+=
meminfo.o
proc-y
+=
uptime.o
...
...
fs/proc/devices.c
0 → 100644
浏览文件 @
fe251042
#include <linux/fs.h>
#include <linux/init.h>
#include <linux/proc_fs.h>
#include <linux/seq_file.h>
static
int
devinfo_show
(
struct
seq_file
*
f
,
void
*
v
)
{
int
i
=
*
(
loff_t
*
)
v
;
if
(
i
<
CHRDEV_MAJOR_HASH_SIZE
)
{
if
(
i
==
0
)
seq_printf
(
f
,
"Character devices:
\n
"
);
chrdev_show
(
f
,
i
);
}
#ifdef CONFIG_BLOCK
else
{
i
-=
CHRDEV_MAJOR_HASH_SIZE
;
if
(
i
==
0
)
seq_printf
(
f
,
"
\n
Block devices:
\n
"
);
blkdev_show
(
f
,
i
);
}
#endif
return
0
;
}
static
void
*
devinfo_start
(
struct
seq_file
*
f
,
loff_t
*
pos
)
{
if
(
*
pos
<
(
BLKDEV_MAJOR_HASH_SIZE
+
CHRDEV_MAJOR_HASH_SIZE
))
return
pos
;
return
NULL
;
}
static
void
*
devinfo_next
(
struct
seq_file
*
f
,
void
*
v
,
loff_t
*
pos
)
{
(
*
pos
)
++
;
if
(
*
pos
>=
(
BLKDEV_MAJOR_HASH_SIZE
+
CHRDEV_MAJOR_HASH_SIZE
))
return
NULL
;
return
pos
;
}
static
void
devinfo_stop
(
struct
seq_file
*
f
,
void
*
v
)
{
/* Nothing to do */
}
static
const
struct
seq_operations
devinfo_ops
=
{
.
start
=
devinfo_start
,
.
next
=
devinfo_next
,
.
stop
=
devinfo_stop
,
.
show
=
devinfo_show
};
static
int
devinfo_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
{
return
seq_open
(
filp
,
&
devinfo_ops
);
}
static
const
struct
file_operations
proc_devinfo_operations
=
{
.
open
=
devinfo_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
seq_release
,
};
static
int
__init
proc_devices_init
(
void
)
{
proc_create
(
"devices"
,
0
,
NULL
,
&
proc_devinfo_operations
);
return
0
;
}
module_init
(
proc_devices_init
);
fs/proc/proc_misc.c
浏览文件 @
fe251042
...
...
@@ -107,65 +107,6 @@ static const struct file_operations proc_cpuinfo_operations = {
.
release
=
seq_release
,
};
static
int
devinfo_show
(
struct
seq_file
*
f
,
void
*
v
)
{
int
i
=
*
(
loff_t
*
)
v
;
if
(
i
<
CHRDEV_MAJOR_HASH_SIZE
)
{
if
(
i
==
0
)
seq_printf
(
f
,
"Character devices:
\n
"
);
chrdev_show
(
f
,
i
);
}
#ifdef CONFIG_BLOCK
else
{
i
-=
CHRDEV_MAJOR_HASH_SIZE
;
if
(
i
==
0
)
seq_printf
(
f
,
"
\n
Block devices:
\n
"
);
blkdev_show
(
f
,
i
);
}
#endif
return
0
;
}
static
void
*
devinfo_start
(
struct
seq_file
*
f
,
loff_t
*
pos
)
{
if
(
*
pos
<
(
BLKDEV_MAJOR_HASH_SIZE
+
CHRDEV_MAJOR_HASH_SIZE
))
return
pos
;
return
NULL
;
}
static
void
*
devinfo_next
(
struct
seq_file
*
f
,
void
*
v
,
loff_t
*
pos
)
{
(
*
pos
)
++
;
if
(
*
pos
>=
(
BLKDEV_MAJOR_HASH_SIZE
+
CHRDEV_MAJOR_HASH_SIZE
))
return
NULL
;
return
pos
;
}
static
void
devinfo_stop
(
struct
seq_file
*
f
,
void
*
v
)
{
/* Nothing to do */
}
static
const
struct
seq_operations
devinfo_ops
=
{
.
start
=
devinfo_start
,
.
next
=
devinfo_next
,
.
stop
=
devinfo_stop
,
.
show
=
devinfo_show
};
static
int
devinfo_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
{
return
seq_open
(
filp
,
&
devinfo_ops
);
}
static
const
struct
file_operations
proc_devinfo_operations
=
{
.
open
=
devinfo_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
seq_release
,
};
static
int
vmstat_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
return
seq_open
(
file
,
&
vmstat_op
);
...
...
@@ -591,7 +532,6 @@ void __init proc_misc_init(void)
proc_symlink
(
"mounts"
,
NULL
,
"self/mounts"
);
/* And now for trickier ones */
proc_create
(
"devices"
,
0
,
NULL
,
&
proc_devinfo_operations
);
proc_create
(
"cpuinfo"
,
0
,
NULL
,
&
proc_cpuinfo_operations
);
#ifdef CONFIG_BLOCK
proc_create
(
"partitions"
,
0
,
NULL
,
&
proc_partitions_operations
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录