Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
b2f21e05
Commit
b2f21e05
authored
Oct 16, 2008
by
Al Viro
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] switch ide-gd
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
488ca606
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
13 deletions
+11
-13
drivers/ide/ide-gd.c
drivers/ide/ide-gd.c
+11
-13
No files found.
drivers/ide/ide-gd.c
View file @
b2f21e05
...
@@ -169,9 +169,9 @@ static ide_driver_t ide_gd_driver = {
...
@@ -169,9 +169,9 @@ static ide_driver_t ide_gd_driver = {
#endif
#endif
};
};
static
int
ide_gd_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
static
int
ide_gd_open
(
struct
block_device
*
bdev
,
fmode_t
mode
)
{
{
struct
gendisk
*
disk
=
inode
->
i_
bdev
->
bd_disk
;
struct
gendisk
*
disk
=
bdev
->
bd_disk
;
struct
ide_disk_obj
*
idkp
;
struct
ide_disk_obj
*
idkp
;
ide_drive_t
*
drive
;
ide_drive_t
*
drive
;
int
ret
=
0
;
int
ret
=
0
;
...
@@ -197,12 +197,12 @@ static int ide_gd_open(struct inode *inode, struct file *filp)
...
@@ -197,12 +197,12 @@ static int ide_gd_open(struct inode *inode, struct file *filp)
* unreadable disk, so that we can get the format capacity
* unreadable disk, so that we can get the format capacity
* of the drive or begin the format - Sam
* of the drive or begin the format - Sam
*/
*/
if
(
ret
&&
(
filp
->
f_
mode
&
FMODE_NDELAY
)
==
0
)
{
if
(
ret
&&
(
mode
&
FMODE_NDELAY
)
==
0
)
{
ret
=
-
EIO
;
ret
=
-
EIO
;
goto
out_put_idkp
;
goto
out_put_idkp
;
}
}
if
((
drive
->
dev_flags
&
IDE_DFLAG_WP
)
&&
(
filp
->
f_
mode
&
FMODE_WRITE
))
{
if
((
drive
->
dev_flags
&
IDE_DFLAG_WP
)
&&
(
mode
&
FMODE_WRITE
))
{
ret
=
-
EROFS
;
ret
=
-
EROFS
;
goto
out_put_idkp
;
goto
out_put_idkp
;
}
}
...
@@ -214,7 +214,7 @@ static int ide_gd_open(struct inode *inode, struct file *filp)
...
@@ -214,7 +214,7 @@ static int ide_gd_open(struct inode *inode, struct file *filp)
*/
*/
drive
->
disk_ops
->
set_doorlock
(
drive
,
disk
,
1
);
drive
->
disk_ops
->
set_doorlock
(
drive
,
disk
,
1
);
drive
->
dev_flags
|=
IDE_DFLAG_MEDIA_CHANGED
;
drive
->
dev_flags
|=
IDE_DFLAG_MEDIA_CHANGED
;
check_disk_change
(
inode
->
i_
bdev
);
check_disk_change
(
bdev
);
}
else
if
(
drive
->
dev_flags
&
IDE_DFLAG_FORMAT_IN_PROGRESS
)
{
}
else
if
(
drive
->
dev_flags
&
IDE_DFLAG_FORMAT_IN_PROGRESS
)
{
ret
=
-
EBUSY
;
ret
=
-
EBUSY
;
goto
out_put_idkp
;
goto
out_put_idkp
;
...
@@ -227,9 +227,8 @@ out_put_idkp:
...
@@ -227,9 +227,8 @@ out_put_idkp:
return
ret
;
return
ret
;
}
}
static
int
ide_gd_release
(
struct
inode
*
inode
,
struct
file
*
filp
)
static
int
ide_gd_release
(
struct
gendisk
*
disk
,
fmode_t
mode
)
{
{
struct
gendisk
*
disk
=
inode
->
i_bdev
->
bd_disk
;
struct
ide_disk_obj
*
idkp
=
ide_drv_g
(
disk
,
ide_disk_obj
);
struct
ide_disk_obj
*
idkp
=
ide_drv_g
(
disk
,
ide_disk_obj
);
ide_drive_t
*
drive
=
idkp
->
drive
;
ide_drive_t
*
drive
=
idkp
->
drive
;
...
@@ -286,21 +285,20 @@ static int ide_gd_revalidate_disk(struct gendisk *disk)
...
@@ -286,21 +285,20 @@ static int ide_gd_revalidate_disk(struct gendisk *disk)
return
0
;
return
0
;
}
}
static
int
ide_gd_ioctl
(
struct
inode
*
inode
,
struct
file
*
fil
e
,
static
int
ide_gd_ioctl
(
struct
block_device
*
bdev
,
fmode_t
mod
e
,
unsigned
int
cmd
,
unsigned
long
arg
)
unsigned
int
cmd
,
unsigned
long
arg
)
{
{
struct
block_device
*
bdev
=
inode
->
i_bdev
;
struct
ide_disk_obj
*
idkp
=
ide_drv_g
(
bdev
->
bd_disk
,
ide_disk_obj
);
struct
ide_disk_obj
*
idkp
=
ide_drv_g
(
bdev
->
bd_disk
,
ide_disk_obj
);
ide_drive_t
*
drive
=
idkp
->
drive
;
ide_drive_t
*
drive
=
idkp
->
drive
;
return
drive
->
disk_ops
->
ioctl
(
drive
,
bdev
,
file
?
file
->
f_mode
:
0
,
cmd
,
arg
);
return
drive
->
disk_ops
->
ioctl
(
drive
,
bdev
,
mode
,
cmd
,
arg
);
}
}
static
struct
block_device_operations
ide_gd_ops
=
{
static
struct
block_device_operations
ide_gd_ops
=
{
.
owner
=
THIS_MODULE
,
.
owner
=
THIS_MODULE
,
.
__
open
=
ide_gd_open
,
.
open
=
ide_gd_open
,
.
__
release
=
ide_gd_release
,
.
release
=
ide_gd_release
,
.
__ioctl
=
ide_gd_ioctl
,
.
locked_ioctl
=
ide_gd_ioctl
,
.
getgeo
=
ide_gd_getgeo
,
.
getgeo
=
ide_gd_getgeo
,
.
media_changed
=
ide_gd_media_changed
,
.
media_changed
=
ide_gd_media_changed
,
.
revalidate_disk
=
ide_gd_revalidate_disk
.
revalidate_disk
=
ide_gd_revalidate_disk
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment