Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
223a2a38
Commit
223a2a38
authored
Mar 21, 2003
by
Alan Cox
Committed by
Linus Torvalds
Mar 21, 2003
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] update ide-disk to changes, remove all the driver ifs
parent
7d72e466
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
21 deletions
+29
-21
drivers/ide/ide-disk.c
drivers/ide/ide-disk.c
+29
-21
No files found.
drivers/ide/ide-disk.c
View file @
223a2a38
/*
/*
* linux/drivers/ide/ide-disk.c Version 1.1
6 April 7, 2002
* linux/drivers/ide/ide-disk.c Version 1.1
8 Mar 05, 2003
*
*
* Copyright (C) 1994-1998 Linus Torvalds & authors (see below)
* Copyright (C) 1998-2002 Linux ATA Developemt
* Copyright (C) 1998-2002 Linux ATA Developemt
* Andre Hedrick <andre@linux-ide.org>
* Andre Hedrick <andre@linux-ide.org>
*
* Copyright (C) 2003 Red Hat <alan@redhat.com>
*
* Copyright (C) 1994-1998 Linus Torvalds & authors (see below)
*/
*/
/*
/*
...
@@ -42,7 +41,7 @@
...
@@ -42,7 +41,7 @@
* fix wcache setup.
* fix wcache setup.
*/
*/
#define IDEDISK_VERSION "1.1
7
"
#define IDEDISK_VERSION "1.1
8
"
#undef REALLY_SLOW_IO
/* most systems can safely undef this */
#undef REALLY_SLOW_IO
/* most systems can safely undef this */
...
@@ -154,8 +153,6 @@ static ide_startstop_t read_intr (ide_drive_t *drive)
...
@@ -154,8 +153,6 @@ static ide_startstop_t read_intr (ide_drive_t *drive)
return
DRIVER
(
drive
)
->
error
(
drive
,
"read_intr"
,
stat
);
return
DRIVER
(
drive
)
->
error
(
drive
,
"read_intr"
,
stat
);
}
}
/* no data yet, so wait for another interrupt */
/* no data yet, so wait for another interrupt */
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
read_intr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
&
read_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
return
ide_started
;
}
}
...
@@ -189,8 +186,6 @@ static ide_startstop_t read_intr (ide_drive_t *drive)
...
@@ -189,8 +186,6 @@ static ide_startstop_t read_intr (ide_drive_t *drive)
if
(
i
>
0
)
{
if
(
i
>
0
)
{
if
(
msect
)
if
(
msect
)
goto
read_next
;
goto
read_next
;
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
read_intr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
&
read_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
return
ide_started
;
}
}
...
@@ -230,8 +225,6 @@ static ide_startstop_t write_intr (ide_drive_t *drive)
...
@@ -230,8 +225,6 @@ static ide_startstop_t write_intr (ide_drive_t *drive)
char
*
to
=
ide_map_buffer
(
rq
,
&
flags
);
char
*
to
=
ide_map_buffer
(
rq
,
&
flags
);
taskfile_output_data
(
drive
,
to
,
SECTOR_WORDS
);
taskfile_output_data
(
drive
,
to
,
SECTOR_WORDS
);
ide_unmap_buffer
(
rq
,
to
,
&
flags
);
ide_unmap_buffer
(
rq
,
to
,
&
flags
);
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
write_intr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
&
write_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
return
ide_started
;
}
}
...
@@ -332,8 +325,6 @@ static ide_startstop_t multwrite_intr (ide_drive_t *drive)
...
@@ -332,8 +325,6 @@ static ide_startstop_t multwrite_intr (ide_drive_t *drive)
if
(
rq
->
nr_sectors
)
{
if
(
rq
->
nr_sectors
)
{
if
(
ide_multwrite
(
drive
,
drive
->
mult_count
))
if
(
ide_multwrite
(
drive
,
drive
->
mult_count
))
return
ide_stopped
;
return
ide_stopped
;
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
multwrite_intr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
&
multwrite_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
return
ide_started
;
}
}
...
@@ -550,8 +541,6 @@ static ide_startstop_t do_rw_disk (ide_drive_t *drive, struct request *rq, secto
...
@@ -550,8 +541,6 @@ static ide_startstop_t do_rw_disk (ide_drive_t *drive, struct request *rq, secto
* MAJOR DATA INTEGRITY BUG !!! only if we error
* MAJOR DATA INTEGRITY BUG !!! only if we error
*/
*/
hwgroup
->
wrq
=
*
rq
;
/* scratchpad */
hwgroup
->
wrq
=
*
rq
;
/* scratchpad */
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
multwrite_intr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
&
multwrite_intr
,
WAIT_CMD
,
NULL
);
if
(
ide_multwrite
(
drive
,
drive
->
mult_count
))
{
if
(
ide_multwrite
(
drive
,
drive
->
mult_count
))
{
unsigned
long
flags
;
unsigned
long
flags
;
...
@@ -564,8 +553,6 @@ static ide_startstop_t do_rw_disk (ide_drive_t *drive, struct request *rq, secto
...
@@ -564,8 +553,6 @@ static ide_startstop_t do_rw_disk (ide_drive_t *drive, struct request *rq, secto
}
else
{
}
else
{
unsigned
long
flags
;
unsigned
long
flags
;
char
*
to
=
ide_map_buffer
(
rq
,
&
flags
);
char
*
to
=
ide_map_buffer
(
rq
,
&
flags
);
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
write_intr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
&
write_intr
,
WAIT_CMD
,
NULL
);
taskfile_output_data
(
drive
,
to
,
SECTOR_WORDS
);
taskfile_output_data
(
drive
,
to
,
SECTOR_WORDS
);
ide_unmap_buffer
(
rq
,
to
,
&
flags
);
ide_unmap_buffer
(
rq
,
to
,
&
flags
);
...
@@ -941,6 +928,26 @@ ide_startstop_t idedisk_error (ide_drive_t *drive, const char *msg, u8 stat)
...
@@ -941,6 +928,26 @@ ide_startstop_t idedisk_error (ide_drive_t *drive, const char *msg, u8 stat)
return
ide_stopped
;
return
ide_stopped
;
}
}
ide_startstop_t
idedisk_abort
(
ide_drive_t
*
drive
,
const
char
*
msg
)
{
ide_hwif_t
*
hwif
;
struct
request
*
rq
;
if
(
drive
==
NULL
||
(
rq
=
HWGROUP
(
drive
)
->
rq
)
==
NULL
)
return
ide_stopped
;
hwif
=
HWIF
(
drive
);
if
(
rq
->
flags
&
(
REQ_DRIVE_CMD
|
REQ_DRIVE_TASK
|
REQ_DRIVE_TASKFILE
))
{
rq
->
errors
=
1
;
ide_end_drive_cmd
(
drive
,
BUSY_STAT
,
0
);
return
ide_stopped
;
}
DRIVER
(
drive
)
->
end_request
(
drive
,
0
,
0
);
return
ide_stopped
;
}
/*
/*
* Queries for true maximum capacity of the drive.
* Queries for true maximum capacity of the drive.
* Returns maximum LBA address (> 0) of the drive, 0 if failed.
* Returns maximum LBA address (> 0) of the drive, 0 if failed.
...
@@ -1073,7 +1080,7 @@ static inline int idedisk_supports_host_protected_area(ide_drive_t *drive)
...
@@ -1073,7 +1080,7 @@ static inline int idedisk_supports_host_protected_area(ide_drive_t *drive)
{
{
int
flag
=
(
drive
->
id
->
cfs_enable_1
&
0x0400
)
?
1
:
0
;
int
flag
=
(
drive
->
id
->
cfs_enable_1
&
0x0400
)
?
1
:
0
;
if
(
flag
)
if
(
flag
)
printk
(
"%s: host protected area => %d
\n
"
,
drive
->
name
,
flag
);
printk
(
KERN_INFO
"%s: host protected area => %d
\n
"
,
drive
->
name
,
flag
);
return
flag
;
return
flag
;
}
}
...
@@ -1201,7 +1208,7 @@ static ide_startstop_t idedisk_special (ide_drive_t *drive)
...
@@ -1201,7 +1208,7 @@ static ide_startstop_t idedisk_special (ide_drive_t *drive)
}
}
}
else
if
(
s
->
b
.
set_multmode
)
{
}
else
if
(
s
->
b
.
set_multmode
)
{
s
->
b
.
set_multmode
=
0
;
s
->
b
.
set_multmode
=
0
;
if
(
drive
->
id
&&
drive
->
mult_req
>
drive
->
id
->
max_multsect
)
if
(
drive
->
mult_req
>
drive
->
id
->
max_multsect
)
drive
->
mult_req
=
drive
->
id
->
max_multsect
;
drive
->
mult_req
=
drive
->
id
->
max_multsect
;
if
(
!
IS_PDC4030_DRIVE
)
{
if
(
!
IS_PDC4030_DRIVE
)
{
ide_task_t
args
;
ide_task_t
args
;
...
@@ -1286,7 +1293,7 @@ static int proc_idedisk_read_cache
...
@@ -1286,7 +1293,7 @@ static int proc_idedisk_read_cache
char
*
out
=
page
;
char
*
out
=
page
;
int
len
;
int
len
;
if
(
drive
->
id
)
if
(
drive
->
id
_read
)
len
=
sprintf
(
out
,
"%i
\n
"
,
drive
->
id
->
buf_size
/
2
);
len
=
sprintf
(
out
,
"%i
\n
"
,
drive
->
id
->
buf_size
/
2
);
else
else
len
=
sprintf
(
out
,
"(none)
\n
"
);
len
=
sprintf
(
out
,
"(none)
\n
"
);
...
@@ -1549,7 +1556,7 @@ static void idedisk_setup (ide_drive_t *drive)
...
@@ -1549,7 +1556,7 @@ static void idedisk_setup (ide_drive_t *drive)
idedisk_add_settings
(
drive
);
idedisk_add_settings
(
drive
);
if
(
id
==
NULL
)
if
(
drive
->
id_read
==
0
)
return
;
return
;
/*
/*
...
@@ -1666,6 +1673,7 @@ static ide_driver_t idedisk_driver = {
...
@@ -1666,6 +1673,7 @@ static ide_driver_t idedisk_driver = {
.
do_request
=
do_rw_disk
,
.
do_request
=
do_rw_disk
,
.
sense
=
idedisk_dump_status
,
.
sense
=
idedisk_dump_status
,
.
error
=
idedisk_error
,
.
error
=
idedisk_error
,
.
abort
=
idedisk_abort
,
.
pre_reset
=
idedisk_pre_reset
,
.
pre_reset
=
idedisk_pre_reset
,
.
capacity
=
idedisk_capacity
,
.
capacity
=
idedisk_capacity
,
.
special
=
idedisk_special
,
.
special
=
idedisk_special
,
...
...
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