Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
36ac829e
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
36ac829e
编写于
9月 28, 2009
作者:
R
Ralf Baechle
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
MIPS: Sibyte: Get rid of BKL.
Signed-off-by:
N
Ralf Baechle
<
ralf@linux-mips.org
>
上级
553d6d5f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
18 deletion
+15
-18
arch/mips/sibyte/common/sb_tbprof.c
arch/mips/sibyte/common/sb_tbprof.c
+15
-18
未找到文件。
arch/mips/sibyte/common/sb_tbprof.c
浏览文件 @
36ac829e
...
...
@@ -403,36 +403,31 @@ static int sbprof_zbprof_stop(void)
static
int
sbprof_tb_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
{
int
minor
;
int
err
=
0
;
lock_kernel
();
minor
=
iminor
(
inode
);
if
(
minor
!=
0
)
{
err
=
-
ENODEV
;
goto
out
;
}
if
(
minor
!=
0
)
return
-
ENODEV
;
if
(
xchg
(
&
sbp
.
open
,
SB_OPENING
)
!=
SB_CLOSED
)
{
err
=
-
EBUSY
;
goto
out
;
}
if
(
xchg
(
&
sbp
.
open
,
SB_OPENING
)
!=
SB_CLOSED
)
return
-
EBUSY
;
memset
(
&
sbp
,
0
,
sizeof
(
struct
sbprof_tb
));
sbp
.
sbprof_tbbuf
=
vmalloc
(
MAX_TBSAMPLE_BYTES
);
if
(
!
sbp
.
sbprof_tbbuf
)
{
err
=
-
ENOMEM
;
goto
out
;
sbp
.
open
=
SB_CLOSED
;
wmb
();
return
-
ENOMEM
;
}
memset
(
sbp
.
sbprof_tbbuf
,
0
,
MAX_TBSAMPLE_BYTES
);
init_waitqueue_head
(
&
sbp
.
tb_sync
);
init_waitqueue_head
(
&
sbp
.
tb_read
);
mutex_init
(
&
sbp
.
lock
);
sbp
.
open
=
SB_OPEN
;
wmb
();
out:
unlock_kernel
();
return
err
;
return
0
;
}
static
int
sbprof_tb_release
(
struct
inode
*
inode
,
struct
file
*
filp
)
...
...
@@ -440,7 +435,7 @@ static int sbprof_tb_release(struct inode *inode, struct file *filp)
int
minor
;
minor
=
iminor
(
inode
);
if
(
minor
!=
0
||
!
sbp
.
open
)
if
(
minor
!=
0
||
sbp
.
open
!=
SB_CLOSED
)
return
-
ENODEV
;
mutex_lock
(
&
sbp
.
lock
);
...
...
@@ -449,7 +444,8 @@ static int sbprof_tb_release(struct inode *inode, struct file *filp)
sbprof_zbprof_stop
();
vfree
(
sbp
.
sbprof_tbbuf
);
sbp
.
open
=
0
;
sbp
.
open
=
SB_CLOSED
;
wmb
();
mutex_unlock
(
&
sbp
.
lock
);
...
...
@@ -583,7 +579,8 @@ static int __init sbprof_tb_init(void)
}
tb_dev
=
dev
;
sbp
.
open
=
0
;
sbp
.
open
=
SB_CLOSED
;
wmb
();
tb_period
=
zbbus_mhz
*
10000LL
;
pr_info
(
DEVNAME
": initialized - tb_period = %lld
\n
"
,
(
long
long
)
tb_period
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录