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
Kirill Smelkov
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
* Andre Hedrick <andre@linux-ide.org>
*
*
* Copyright (C) 1994-1998 Linus Torvalds & authors (see below)
* Copyright (C) 2003 Red Hat <alan@redhat.com>
*/
/*
...
...
@@ -42,7 +41,7 @@
* 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 */
...
...
@@ -154,8 +153,6 @@ static ide_startstop_t read_intr (ide_drive_t *drive)
return
DRIVER
(
drive
)
->
error
(
drive
,
"read_intr"
,
stat
);
}
/* no data yet, so wait for another interrupt */
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
read_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
}
...
...
@@ -189,8 +186,6 @@ static ide_startstop_t read_intr (ide_drive_t *drive)
if
(
i
>
0
)
{
if
(
msect
)
goto
read_next
;
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
read_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
}
...
...
@@ -230,8 +225,6 @@ static ide_startstop_t write_intr (ide_drive_t *drive)
char
*
to
=
ide_map_buffer
(
rq
,
&
flags
);
taskfile_output_data
(
drive
,
to
,
SECTOR_WORDS
);
ide_unmap_buffer
(
rq
,
to
,
&
flags
);
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
write_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
}
...
...
@@ -332,8 +325,6 @@ static ide_startstop_t multwrite_intr (ide_drive_t *drive)
if
(
rq
->
nr_sectors
)
{
if
(
ide_multwrite
(
drive
,
drive
->
mult_count
))
return
ide_stopped
;
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
multwrite_intr
,
WAIT_CMD
,
NULL
);
return
ide_started
;
}
...
...
@@ -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
*/
hwgroup
->
wrq
=
*
rq
;
/* scratchpad */
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
multwrite_intr
,
WAIT_CMD
,
NULL
);
if
(
ide_multwrite
(
drive
,
drive
->
mult_count
))
{
unsigned
long
flags
;
...
...
@@ -564,8 +553,6 @@ static ide_startstop_t do_rw_disk (ide_drive_t *drive, struct request *rq, secto
}
else
{
unsigned
long
flags
;
char
*
to
=
ide_map_buffer
(
rq
,
&
flags
);
if
(
HWGROUP
(
drive
)
->
handler
!=
NULL
)
BUG
();
ide_set_handler
(
drive
,
&
write_intr
,
WAIT_CMD
,
NULL
);
taskfile_output_data
(
drive
,
to
,
SECTOR_WORDS
);
ide_unmap_buffer
(
rq
,
to
,
&
flags
);
...
...
@@ -941,6 +928,26 @@ ide_startstop_t idedisk_error (ide_drive_t *drive, const char *msg, u8 stat)
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.
* 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)
{
int
flag
=
(
drive
->
id
->
cfs_enable_1
&
0x0400
)
?
1
:
0
;
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
;
}
...
...
@@ -1201,7 +1208,7 @@ static ide_startstop_t idedisk_special (ide_drive_t *drive)
}
}
else
if
(
s
->
b
.
set_multmode
)
{
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
;
if
(
!
IS_PDC4030_DRIVE
)
{
ide_task_t
args
;
...
...
@@ -1286,7 +1293,7 @@ static int proc_idedisk_read_cache
char
*
out
=
page
;
int
len
;
if
(
drive
->
id
)
if
(
drive
->
id
_read
)
len
=
sprintf
(
out
,
"%i
\n
"
,
drive
->
id
->
buf_size
/
2
);
else
len
=
sprintf
(
out
,
"(none)
\n
"
);
...
...
@@ -1549,7 +1556,7 @@ static void idedisk_setup (ide_drive_t *drive)
idedisk_add_settings
(
drive
);
if
(
id
==
NULL
)
if
(
drive
->
id_read
==
0
)
return
;
/*
...
...
@@ -1666,6 +1673,7 @@ static ide_driver_t idedisk_driver = {
.
do_request
=
do_rw_disk
,
.
sense
=
idedisk_dump_status
,
.
error
=
idedisk_error
,
.
abort
=
idedisk_abort
,
.
pre_reset
=
idedisk_pre_reset
,
.
capacity
=
idedisk_capacity
,
.
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