Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
51a776fa
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
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看板
提交
51a776fa
编写于
5月 15, 2008
作者:
J
Jonathan Corbet
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rtc: cdev lock_kernel() pushdown
Signed-off-by:
N
Jonathan Corbet
<
corbet@lwn.net
>
上级
0bec0bba
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
9 addition
and
3 deletion
+9
-3
drivers/rtc/rtc-dev.c
drivers/rtc/rtc-dev.c
+9
-3
未找到文件。
drivers/rtc/rtc-dev.c
浏览文件 @
51a776fa
...
...
@@ -13,6 +13,7 @@
#include <linux/module.h>
#include <linux/rtc.h>
#include <linux/smp_lock.h>
#include "rtc-core.h"
static
dev_t
rtc_devt
;
...
...
@@ -26,8 +27,11 @@ static int rtc_dev_open(struct inode *inode, struct file *file)
struct
rtc_device
,
char_dev
);
const
struct
rtc_class_ops
*
ops
=
rtc
->
ops
;
if
(
test_and_set_bit_lock
(
RTC_DEV_BUSY
,
&
rtc
->
flags
))
return
-
EBUSY
;
lock_kernel
();
if
(
test_and_set_bit_lock
(
RTC_DEV_BUSY
,
&
rtc
->
flags
))
{
err
=
-
EBUSY
;
goto
out
;
}
file
->
private_data
=
rtc
;
...
...
@@ -37,11 +41,13 @@ static int rtc_dev_open(struct inode *inode, struct file *file)
rtc
->
irq_data
=
0
;
spin_unlock_irq
(
&
rtc
->
irq_lock
);
return
0
;
goto
out
;
}
/* something has gone wrong */
clear_bit_unlock
(
RTC_DEV_BUSY
,
&
rtc
->
flags
);
out:
unlock_kernel
();
return
err
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录