Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
60ad2340
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 接近 4 年
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
60ad2340
编写于
3月 02, 2008
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[PATCH] switch ataflop
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
94562c17
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
20 addition
and
21 deletion
+20
-21
drivers/block/ataflop.c
drivers/block/ataflop.c
+20
-21
未找到文件。
drivers/block/ataflop.c
浏览文件 @
60ad2340
...
...
@@ -361,13 +361,13 @@ static void finish_fdc( void );
static
void
finish_fdc_done
(
int
dummy
);
static
void
setup_req_params
(
int
drive
);
static
void
redo_fd_request
(
void
);
static
int
fd_ioctl
(
struct
inode
*
inode
,
struct
file
*
filp
,
unsigned
int
static
int
fd_ioctl
(
struct
block_device
*
bdev
,
fmode_t
mode
,
unsigned
int
cmd
,
unsigned
long
param
);
static
void
fd_probe
(
int
drive
);
static
int
fd_test_drive_present
(
int
drive
);
static
void
config_types
(
void
);
static
int
floppy_open
(
struct
inode
*
inode
,
struct
file
*
filp
);
static
int
floppy_release
(
struct
inode
*
inode
,
struct
file
*
filp
);
static
int
floppy_open
(
struct
block_device
*
bdev
,
fmode_t
mode
);
static
int
floppy_release
(
struct
gendisk
*
disk
,
fmode_t
mode
);
/************************* End of Prototypes **************************/
...
...
@@ -1483,10 +1483,10 @@ void do_fd_request(struct request_queue * q)
atari_enable_irq
(
IRQ_MFP_FDC
);
}
static
int
fd_ioctl
(
struct
inode
*
inode
,
struct
file
*
filp
,
static
int
fd_ioctl
(
struct
block_device
*
bdev
,
fmode_t
mode
,
unsigned
int
cmd
,
unsigned
long
param
)
{
struct
gendisk
*
disk
=
inode
->
i_
bdev
->
bd_disk
;
struct
gendisk
*
disk
=
bdev
->
bd_disk
;
struct
atari_floppy_struct
*
floppy
=
disk
->
private_data
;
int
drive
=
floppy
-
unit
;
int
type
=
floppy
->
type
;
...
...
@@ -1661,7 +1661,7 @@ static int fd_ioctl(struct inode *inode, struct file *filp,
/* invalidate the buffer track to force a reread */
BufferDrive
=
-
1
;
set_bit
(
drive
,
&
fake_change
);
check_disk_change
(
inode
->
i_
bdev
);
check_disk_change
(
bdev
);
return
0
;
default:
return
-
EINVAL
;
...
...
@@ -1804,37 +1804,36 @@ static void __init config_types( void )
* drive with different device numbers.
*/
static
int
floppy_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
static
int
floppy_open
(
struct
block_device
*
bdev
,
fmode_t
mode
)
{
struct
atari_floppy_struct
*
p
=
inode
->
i_
bdev
->
bd_disk
->
private_data
;
int
type
=
iminor
(
inode
)
>>
2
;
struct
atari_floppy_struct
*
p
=
bdev
->
bd_disk
->
private_data
;
int
type
=
MINOR
(
bdev
->
bd_dev
)
>>
2
;
DPRINT
((
"fd_open: type=%d
\n
"
,
type
));
if
(
p
->
ref
&&
p
->
type
!=
type
)
return
-
EBUSY
;
if
(
p
->
ref
==
-
1
||
(
p
->
ref
&&
filp
->
f_
mode
&
FMODE_EXCL
))
if
(
p
->
ref
==
-
1
||
(
p
->
ref
&&
mode
&
FMODE_EXCL
))
return
-
EBUSY
;
if
(
filp
->
f_
mode
&
FMODE_EXCL
)
if
(
mode
&
FMODE_EXCL
)
p
->
ref
=
-
1
;
else
p
->
ref
++
;
p
->
type
=
type
;
if
(
filp
->
f_
mode
&
FMODE_NDELAY
)
if
(
mode
&
FMODE_NDELAY
)
return
0
;
if
(
filp
->
f_
mode
&
(
FMODE_READ
|
FMODE_WRITE
))
{
check_disk_change
(
inode
->
i_
bdev
);
if
(
filp
->
f_
mode
&
FMODE_WRITE
)
{
if
(
mode
&
(
FMODE_READ
|
FMODE_WRITE
))
{
check_disk_change
(
bdev
);
if
(
mode
&
FMODE_WRITE
)
{
if
(
p
->
wpstat
)
{
if
(
p
->
ref
<
0
)
p
->
ref
=
0
;
else
p
->
ref
--
;
floppy_release
(
inode
,
filp
);
return
-
EROFS
;
}
}
...
...
@@ -1843,9 +1842,9 @@ static int floppy_open( struct inode *inode, struct file *filp )
}
static
int
floppy_release
(
struct
inode
*
inode
,
struct
file
*
filp
)
static
int
floppy_release
(
struct
gendisk
*
disk
,
fmode_t
mode
)
{
struct
atari_floppy_struct
*
p
=
inode
->
i_bdev
->
bd_
disk
->
private_data
;
struct
atari_floppy_struct
*
p
=
disk
->
private_data
;
if
(
p
->
ref
<
0
)
p
->
ref
=
0
;
else
if
(
!
p
->
ref
--
)
{
...
...
@@ -1857,9 +1856,9 @@ static int floppy_release( struct inode * inode, struct file * filp )
static
struct
block_device_operations
floppy_fops
=
{
.
owner
=
THIS_MODULE
,
.
__
open
=
floppy_open
,
.
__
release
=
floppy_release
,
.
__ioctl
=
fd_ioctl
,
.
open
=
floppy_open
,
.
release
=
floppy_release
,
.
locked_ioctl
=
fd_ioctl
,
.
media_changed
=
check_floppy_change
,
.
revalidate_disk
=
floppy_revalidate
,
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录