Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
b3369c68
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看板
提交
b3369c68
编写于
5月 15, 2008
作者:
J
Jonathan Corbet
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
st: cdev lock_kernel() pushdown
Signed-off-by:
N
Jonathan Corbet
<
corbet@lwn.net
>
上级
d4514d1b
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
9 addition
and
2 deletion
+9
-2
drivers/scsi/st.c
drivers/scsi/st.c
+9
-2
未找到文件。
drivers/scsi/st.c
浏览文件 @
b3369c68
...
@@ -38,6 +38,7 @@ static const char *verstr = "20080224";
...
@@ -38,6 +38,7 @@ static const char *verstr = "20080224";
#include <linux/cdev.h>
#include <linux/cdev.h>
#include <linux/delay.h>
#include <linux/delay.h>
#include <linux/mutex.h>
#include <linux/mutex.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h>
#include <asm/uaccess.h>
#include <asm/dma.h>
#include <asm/dma.h>
...
@@ -1113,7 +1114,7 @@ static int check_tape(struct scsi_tape *STp, struct file *filp)
...
@@ -1113,7 +1114,7 @@ static int check_tape(struct scsi_tape *STp, struct file *filp)
}
}
/* Open the device. Needs to
be called with
BKL only because of incrementing the SCSI host
/* Open the device. Needs to
take the
BKL only because of incrementing the SCSI host
module count. */
module count. */
static
int
st_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
static
int
st_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
{
{
...
@@ -1123,6 +1124,7 @@ static int st_open(struct inode *inode, struct file *filp)
...
@@ -1123,6 +1124,7 @@ static int st_open(struct inode *inode, struct file *filp)
int
dev
=
TAPE_NR
(
inode
);
int
dev
=
TAPE_NR
(
inode
);
char
*
name
;
char
*
name
;
lock_kernel
();
/*
/*
* We really want to do nonseekable_open(inode, filp); here, but some
* We really want to do nonseekable_open(inode, filp); here, but some
* versions of tar incorrectly call lseek on tapes and bail out if that
* versions of tar incorrectly call lseek on tapes and bail out if that
...
@@ -1130,8 +1132,10 @@ static int st_open(struct inode *inode, struct file *filp)
...
@@ -1130,8 +1132,10 @@ static int st_open(struct inode *inode, struct file *filp)
*/
*/
filp
->
f_mode
&=
~
(
FMODE_PREAD
|
FMODE_PWRITE
);
filp
->
f_mode
&=
~
(
FMODE_PREAD
|
FMODE_PWRITE
);
if
(
!
(
STp
=
scsi_tape_get
(
dev
)))
if
(
!
(
STp
=
scsi_tape_get
(
dev
)))
{
unlock_kernel
();
return
-
ENXIO
;
return
-
ENXIO
;
}
write_lock
(
&
st_dev_arr_lock
);
write_lock
(
&
st_dev_arr_lock
);
filp
->
private_data
=
STp
;
filp
->
private_data
=
STp
;
...
@@ -1140,6 +1144,7 @@ static int st_open(struct inode *inode, struct file *filp)
...
@@ -1140,6 +1144,7 @@ static int st_open(struct inode *inode, struct file *filp)
if
(
STp
->
in_use
)
{
if
(
STp
->
in_use
)
{
write_unlock
(
&
st_dev_arr_lock
);
write_unlock
(
&
st_dev_arr_lock
);
scsi_tape_put
(
STp
);
scsi_tape_put
(
STp
);
unlock_kernel
();
DEB
(
printk
(
ST_DEB_MSG
"%s: Device already in use.
\n
"
,
name
);
)
DEB
(
printk
(
ST_DEB_MSG
"%s: Device already in use.
\n
"
,
name
);
)
return
(
-
EBUSY
);
return
(
-
EBUSY
);
}
}
...
@@ -1188,12 +1193,14 @@ static int st_open(struct inode *inode, struct file *filp)
...
@@ -1188,12 +1193,14 @@ static int st_open(struct inode *inode, struct file *filp)
retval
=
(
-
EIO
);
retval
=
(
-
EIO
);
goto
err_out
;
goto
err_out
;
}
}
unlock_kernel
();
return
0
;
return
0
;
err_out:
err_out:
normalize_buffer
(
STp
->
buffer
);
normalize_buffer
(
STp
->
buffer
);
STp
->
in_use
=
0
;
STp
->
in_use
=
0
;
scsi_tape_put
(
STp
);
scsi_tape_put
(
STp
);
unlock_kernel
();
return
retval
;
return
retval
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录