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
4de1e874
Commit
4de1e874
authored
Sep 15, 2004
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://gkernel.bkbits.net/libata-2.6
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
28575fde
13251da1
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
57 additions
and
22 deletions
+57
-22
drivers/scsi/ata_piix.c
drivers/scsi/ata_piix.c
+2
-0
drivers/scsi/libata-core.c
drivers/scsi/libata-core.c
+41
-21
drivers/scsi/sata_nv.c
drivers/scsi/sata_nv.c
+1
-0
drivers/scsi/sata_promise.c
drivers/scsi/sata_promise.c
+1
-0
drivers/scsi/sata_sil.c
drivers/scsi/sata_sil.c
+1
-0
drivers/scsi/sata_sis.c
drivers/scsi/sata_sis.c
+1
-0
drivers/scsi/sata_svw.c
drivers/scsi/sata_svw.c
+1
-0
drivers/scsi/sata_sx4.c
drivers/scsi/sata_sx4.c
+2
-1
drivers/scsi/sata_via.c
drivers/scsi/sata_via.c
+1
-0
drivers/scsi/sata_vsc.c
drivers/scsi/sata_vsc.c
+1
-0
include/linux/libata.h
include/linux/libata.h
+5
-0
No files found.
drivers/scsi/ata_piix.c
View file @
4de1e874
...
@@ -129,6 +129,7 @@ static struct ata_port_operations piix_pata_ops = {
...
@@ -129,6 +129,7 @@ static struct ata_port_operations piix_pata_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
piix_pata_phy_reset
,
.
phy_reset
=
piix_pata_phy_reset
,
...
@@ -153,6 +154,7 @@ static struct ata_port_operations piix_sata_ops = {
...
@@ -153,6 +154,7 @@ static struct ata_port_operations piix_sata_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
piix_sata_phy_reset
,
.
phy_reset
=
piix_sata_phy_reset
,
...
...
drivers/scsi/libata-core.c
View file @
4de1e874
...
@@ -50,7 +50,6 @@
...
@@ -50,7 +50,6 @@
static
unsigned
int
ata_busy_sleep
(
struct
ata_port
*
ap
,
static
unsigned
int
ata_busy_sleep
(
struct
ata_port
*
ap
,
unsigned
long
tmout_pat
,
unsigned
long
tmout_pat
,
unsigned
long
tmout
);
unsigned
long
tmout
);
static
void
__ata_dev_select
(
struct
ata_port
*
ap
,
unsigned
int
device
);
static
void
ata_set_mode
(
struct
ata_port
*
ap
);
static
void
ata_set_mode
(
struct
ata_port
*
ap
);
static
void
ata_dev_set_xfermode
(
struct
ata_port
*
ap
,
struct
ata_device
*
dev
);
static
void
ata_dev_set_xfermode
(
struct
ata_port
*
ap
,
struct
ata_device
*
dev
);
static
unsigned
int
ata_get_mode_mask
(
struct
ata_port
*
ap
,
int
shift
);
static
unsigned
int
ata_get_mode_mask
(
struct
ata_port
*
ap
,
int
shift
);
...
@@ -637,7 +636,7 @@ static unsigned int ata_pio_devchk(struct ata_port *ap,
...
@@ -637,7 +636,7 @@ static unsigned int ata_pio_devchk(struct ata_port *ap,
struct
ata_ioports
*
ioaddr
=
&
ap
->
ioaddr
;
struct
ata_ioports
*
ioaddr
=
&
ap
->
ioaddr
;
u8
nsect
,
lbal
;
u8
nsect
,
lbal
;
__ata_
dev_select
(
ap
,
device
);
ap
->
ops
->
dev_select
(
ap
,
device
);
outb
(
0x55
,
ioaddr
->
nsect_addr
);
outb
(
0x55
,
ioaddr
->
nsect_addr
);
outb
(
0xaa
,
ioaddr
->
lbal_addr
);
outb
(
0xaa
,
ioaddr
->
lbal_addr
);
...
@@ -681,7 +680,7 @@ static unsigned int ata_mmio_devchk(struct ata_port *ap,
...
@@ -681,7 +680,7 @@ static unsigned int ata_mmio_devchk(struct ata_port *ap,
struct
ata_ioports
*
ioaddr
=
&
ap
->
ioaddr
;
struct
ata_ioports
*
ioaddr
=
&
ap
->
ioaddr
;
u8
nsect
,
lbal
;
u8
nsect
,
lbal
;
__ata_
dev_select
(
ap
,
device
);
ap
->
ops
->
dev_select
(
ap
,
device
);
writeb
(
0x55
,
(
void
__iomem
*
)
ioaddr
->
nsect_addr
);
writeb
(
0x55
,
(
void
__iomem
*
)
ioaddr
->
nsect_addr
);
writeb
(
0xaa
,
(
void
__iomem
*
)
ioaddr
->
lbal_addr
);
writeb
(
0xaa
,
(
void
__iomem
*
)
ioaddr
->
lbal_addr
);
...
@@ -738,7 +737,7 @@ static unsigned int ata_devchk(struct ata_port *ap,
...
@@ -738,7 +737,7 @@ static unsigned int ata_devchk(struct ata_port *ap,
* the event of failure.
* the event of failure.
*/
*/
static
unsigned
int
ata_dev_classify
(
struct
ata_taskfile
*
tf
)
unsigned
int
ata_dev_classify
(
struct
ata_taskfile
*
tf
)
{
{
/* Apple's open source Darwin code hints that some devices only
/* Apple's open source Darwin code hints that some devices only
* put a proper signature into the LBA mid/high registers,
* put a proper signature into the LBA mid/high registers,
...
@@ -786,7 +785,7 @@ static u8 ata_dev_try_classify(struct ata_port *ap, unsigned int device)
...
@@ -786,7 +785,7 @@ static u8 ata_dev_try_classify(struct ata_port *ap, unsigned int device)
unsigned
int
class
;
unsigned
int
class
;
u8
err
;
u8
err
;
__ata_
dev_select
(
ap
,
device
);
ap
->
ops
->
dev_select
(
ap
,
device
);
memset
(
&
tf
,
0
,
sizeof
(
tf
));
memset
(
&
tf
,
0
,
sizeof
(
tf
));
...
@@ -849,8 +848,12 @@ void ata_dev_id_string(struct ata_device *dev, unsigned char *s,
...
@@ -849,8 +848,12 @@ void ata_dev_id_string(struct ata_device *dev, unsigned char *s,
}
}
}
}
void
ata_noop_dev_select
(
struct
ata_port
*
ap
,
unsigned
int
device
)
{
}
/**
/**
*
__ata
_dev_select - Select device 0/1 on ATA bus
*
ata_std
_dev_select - Select device 0/1 on ATA bus
* @ap: ATA channel to manipulate
* @ap: ATA channel to manipulate
* @device: ATA device (numbered from zero) to select
* @device: ATA device (numbered from zero) to select
*
*
...
@@ -862,7 +865,7 @@ void ata_dev_id_string(struct ata_device *dev, unsigned char *s,
...
@@ -862,7 +865,7 @@ void ata_dev_id_string(struct ata_device *dev, unsigned char *s,
* caller.
* caller.
*/
*/
static
void
__ata
_dev_select
(
struct
ata_port
*
ap
,
unsigned
int
device
)
void
ata_std
_dev_select
(
struct
ata_port
*
ap
,
unsigned
int
device
)
{
{
u8
tmp
;
u8
tmp
;
...
@@ -890,7 +893,7 @@ static void __ata_dev_select (struct ata_port *ap, unsigned int device)
...
@@ -890,7 +893,7 @@ static void __ata_dev_select (struct ata_port *ap, unsigned int device)
* make either device 0, or device 1, active on the
* make either device 0, or device 1, active on the
* ATA channel.
* ATA channel.
*
*
* This is a high-level version of
__ata
_dev_select(),
* This is a high-level version of
ata_std
_dev_select(),
* which additionally provides the services of inserting
* which additionally provides the services of inserting
* the proper pauses and status polling, where needed.
* the proper pauses and status polling, where needed.
*
*
...
@@ -907,7 +910,7 @@ void ata_dev_select(struct ata_port *ap, unsigned int device,
...
@@ -907,7 +910,7 @@ void ata_dev_select(struct ata_port *ap, unsigned int device,
if
(
wait
)
if
(
wait
)
ata_wait_idle
(
ap
);
ata_wait_idle
(
ap
);
__ata_
dev_select
(
ap
,
device
);
ap
->
ops
->
dev_select
(
ap
,
device
);
if
(
wait
)
{
if
(
wait
)
{
if
(
can_sleep
&&
ap
->
device
[
device
].
class
==
ATA_DEV_ATAPI
)
if
(
can_sleep
&&
ap
->
device
[
device
].
class
==
ATA_DEV_ATAPI
)
...
@@ -1214,13 +1217,13 @@ void ata_port_probe(struct ata_port *ap)
...
@@ -1214,13 +1217,13 @@ void ata_port_probe(struct ata_port *ap)
}
}
/**
/**
* sata_phy_reset -
*
__
sata_phy_reset -
* @ap:
* @ap:
*
*
* LOCKING:
* LOCKING:
*
*
*/
*/
void
sata_phy_reset
(
struct
ata_port
*
ap
)
void
__
sata_phy_reset
(
struct
ata_port
*
ap
)
{
{
u32
sstatus
;
u32
sstatus
;
unsigned
long
timeout
=
jiffies
+
(
HZ
*
5
);
unsigned
long
timeout
=
jiffies
+
(
HZ
*
5
);
...
@@ -1258,6 +1261,21 @@ void sata_phy_reset(struct ata_port *ap)
...
@@ -1258,6 +1261,21 @@ void sata_phy_reset(struct ata_port *ap)
return
;
return
;
}
}
ap
->
cbl
=
ATA_CBL_SATA
;
}
/**
* __sata_phy_reset -
* @ap:
*
* LOCKING:
*
*/
void
sata_phy_reset
(
struct
ata_port
*
ap
)
{
__sata_phy_reset
(
ap
);
if
(
ap
->
flags
&
ATA_FLAG_PORT_DISABLED
)
return
;
ata_bus_reset
(
ap
);
ata_bus_reset
(
ap
);
}
}
...
@@ -1483,7 +1501,7 @@ static void ata_bus_post_reset(struct ata_port *ap, unsigned int devmask)
...
@@ -1483,7 +1501,7 @@ static void ata_bus_post_reset(struct ata_port *ap, unsigned int devmask)
while
(
dev1
)
{
while
(
dev1
)
{
u8
nsect
,
lbal
;
u8
nsect
,
lbal
;
__ata_
dev_select
(
ap
,
1
);
ap
->
ops
->
dev_select
(
ap
,
1
);
if
(
ap
->
flags
&
ATA_FLAG_MMIO
)
{
if
(
ap
->
flags
&
ATA_FLAG_MMIO
)
{
nsect
=
readb
((
void
__iomem
*
)
ioaddr
->
nsect_addr
);
nsect
=
readb
((
void
__iomem
*
)
ioaddr
->
nsect_addr
);
lbal
=
readb
((
void
__iomem
*
)
ioaddr
->
lbal_addr
);
lbal
=
readb
((
void
__iomem
*
)
ioaddr
->
lbal_addr
);
...
@@ -1503,11 +1521,11 @@ static void ata_bus_post_reset(struct ata_port *ap, unsigned int devmask)
...
@@ -1503,11 +1521,11 @@ static void ata_bus_post_reset(struct ata_port *ap, unsigned int devmask)
ata_busy_sleep
(
ap
,
ATA_TMOUT_BOOT_QUICK
,
ATA_TMOUT_BOOT
);
ata_busy_sleep
(
ap
,
ATA_TMOUT_BOOT_QUICK
,
ATA_TMOUT_BOOT
);
/* is all this really necessary? */
/* is all this really necessary? */
__ata_
dev_select
(
ap
,
0
);
ap
->
ops
->
dev_select
(
ap
,
0
);
if
(
dev1
)
if
(
dev1
)
__ata_
dev_select
(
ap
,
1
);
ap
->
ops
->
dev_select
(
ap
,
1
);
if
(
dev0
)
if
(
dev0
)
__ata_
dev_select
(
ap
,
0
);
ap
->
ops
->
dev_select
(
ap
,
0
);
}
}
/**
/**
...
@@ -1622,7 +1640,7 @@ void ata_bus_reset(struct ata_port *ap)
...
@@ -1622,7 +1640,7 @@ void ata_bus_reset(struct ata_port *ap)
devmask
|=
(
1
<<
1
);
devmask
|=
(
1
<<
1
);
/* select device 0 again */
/* select device 0 again */
__ata_
dev_select
(
ap
,
0
);
ap
->
ops
->
dev_select
(
ap
,
0
);
/* issue bus reset */
/* issue bus reset */
if
(
ap
->
flags
&
ATA_FLAG_SRST
)
if
(
ap
->
flags
&
ATA_FLAG_SRST
)
...
@@ -1651,9 +1669,9 @@ void ata_bus_reset(struct ata_port *ap)
...
@@ -1651,9 +1669,9 @@ void ata_bus_reset(struct ata_port *ap)
/* is double-select really necessary? */
/* is double-select really necessary? */
if
(
ap
->
device
[
1
].
class
!=
ATA_DEV_NONE
)
if
(
ap
->
device
[
1
].
class
!=
ATA_DEV_NONE
)
__ata_
dev_select
(
ap
,
1
);
ap
->
ops
->
dev_select
(
ap
,
1
);
if
(
ap
->
device
[
0
].
class
!=
ATA_DEV_NONE
)
if
(
ap
->
device
[
0
].
class
!=
ATA_DEV_NONE
)
__ata_
dev_select
(
ap
,
0
);
ap
->
ops
->
dev_select
(
ap
,
0
);
/* if no devices were detected, disable this port */
/* if no devices were detected, disable this port */
if
((
ap
->
device
[
0
].
class
==
ATA_DEV_NONE
)
&&
if
((
ap
->
device
[
0
].
class
==
ATA_DEV_NONE
)
&&
...
@@ -2166,9 +2184,7 @@ static void ata_pio_sector(struct ata_queued_cmd *qc)
...
@@ -2166,9 +2184,7 @@ static void ata_pio_sector(struct ata_queued_cmd *qc)
qc
->
cursg_ofs
=
0
;
qc
->
cursg_ofs
=
0
;
}
}
DPRINTK
(
"data %s, drv_stat 0x%X
\n
"
,
DPRINTK
(
"data %s
\n
"
,
qc
->
tf
.
flags
&
ATA_TFLAG_WRITE
?
"write"
:
"read"
);
qc
->
tf
.
flags
&
ATA_TFLAG_WRITE
?
"write"
:
"read"
,
status
);
/* do the actual data transfer */
/* do the actual data transfer */
do_write
=
(
qc
->
tf
.
flags
&
ATA_TFLAG_WRITE
);
do_write
=
(
qc
->
tf
.
flags
&
ATA_TFLAG_WRITE
);
...
@@ -3609,6 +3625,8 @@ EXPORT_SYMBOL_GPL(ata_qc_issue_prot);
...
@@ -3609,6 +3625,8 @@ EXPORT_SYMBOL_GPL(ata_qc_issue_prot);
EXPORT_SYMBOL_GPL
(
ata_eng_timeout
);
EXPORT_SYMBOL_GPL
(
ata_eng_timeout
);
EXPORT_SYMBOL_GPL
(
ata_tf_load
);
EXPORT_SYMBOL_GPL
(
ata_tf_load
);
EXPORT_SYMBOL_GPL
(
ata_tf_read
);
EXPORT_SYMBOL_GPL
(
ata_tf_read
);
EXPORT_SYMBOL_GPL
(
ata_noop_dev_select
);
EXPORT_SYMBOL_GPL
(
ata_std_dev_select
);
EXPORT_SYMBOL_GPL
(
ata_tf_to_fis
);
EXPORT_SYMBOL_GPL
(
ata_tf_to_fis
);
EXPORT_SYMBOL_GPL
(
ata_tf_from_fis
);
EXPORT_SYMBOL_GPL
(
ata_tf_from_fis
);
EXPORT_SYMBOL_GPL
(
ata_pci_init_legacy_mode
);
EXPORT_SYMBOL_GPL
(
ata_pci_init_legacy_mode
);
...
@@ -3624,6 +3642,7 @@ EXPORT_SYMBOL_GPL(ata_bmdma_start);
...
@@ -3624,6 +3642,7 @@ EXPORT_SYMBOL_GPL(ata_bmdma_start);
EXPORT_SYMBOL_GPL
(
ata_bmdma_irq_clear
);
EXPORT_SYMBOL_GPL
(
ata_bmdma_irq_clear
);
EXPORT_SYMBOL_GPL
(
ata_port_probe
);
EXPORT_SYMBOL_GPL
(
ata_port_probe
);
EXPORT_SYMBOL_GPL
(
sata_phy_reset
);
EXPORT_SYMBOL_GPL
(
sata_phy_reset
);
EXPORT_SYMBOL_GPL
(
__sata_phy_reset
);
EXPORT_SYMBOL_GPL
(
ata_bus_reset
);
EXPORT_SYMBOL_GPL
(
ata_bus_reset
);
EXPORT_SYMBOL_GPL
(
ata_port_disable
);
EXPORT_SYMBOL_GPL
(
ata_port_disable
);
EXPORT_SYMBOL_GPL
(
ata_pci_init_one
);
EXPORT_SYMBOL_GPL
(
ata_pci_init_one
);
...
@@ -3634,4 +3653,5 @@ EXPORT_SYMBOL_GPL(ata_scsi_error);
...
@@ -3634,4 +3653,5 @@ EXPORT_SYMBOL_GPL(ata_scsi_error);
EXPORT_SYMBOL_GPL
(
ata_scsi_slave_config
);
EXPORT_SYMBOL_GPL
(
ata_scsi_slave_config
);
EXPORT_SYMBOL_GPL
(
ata_scsi_release
);
EXPORT_SYMBOL_GPL
(
ata_scsi_release
);
EXPORT_SYMBOL_GPL
(
ata_host_intr
);
EXPORT_SYMBOL_GPL
(
ata_host_intr
);
EXPORT_SYMBOL_GPL
(
ata_dev_classify
);
EXPORT_SYMBOL_GPL
(
ata_dev_id_string
);
EXPORT_SYMBOL_GPL
(
ata_dev_id_string
);
drivers/scsi/sata_nv.c
View file @
4de1e874
...
@@ -202,6 +202,7 @@ static struct ata_port_operations nv_ops = {
...
@@ -202,6 +202,7 @@ static struct ata_port_operations nv_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
sata_phy_reset
,
.
phy_reset
=
sata_phy_reset
,
.
bmdma_setup
=
ata_bmdma_setup
,
.
bmdma_setup
=
ata_bmdma_setup
,
.
bmdma_start
=
ata_bmdma_start
,
.
bmdma_start
=
ata_bmdma_start
,
...
...
drivers/scsi/sata_promise.c
View file @
4de1e874
...
@@ -110,6 +110,7 @@ static struct ata_port_operations pdc_sata_ops = {
...
@@ -110,6 +110,7 @@ static struct ata_port_operations pdc_sata_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
exec_command
=
pdc_exec_command_mmio
,
.
exec_command
=
pdc_exec_command_mmio
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
pdc_phy_reset
,
.
phy_reset
=
pdc_phy_reset
,
.
qc_prep
=
pdc_qc_prep
,
.
qc_prep
=
pdc_qc_prep
,
.
qc_issue
=
pdc_qc_issue_prot
,
.
qc_issue
=
pdc_qc_issue_prot
,
...
...
drivers/scsi/sata_sil.c
View file @
4de1e874
...
@@ -129,6 +129,7 @@ static struct ata_port_operations sil_ops = {
...
@@ -129,6 +129,7 @@ static struct ata_port_operations sil_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
sata_phy_reset
,
.
phy_reset
=
sata_phy_reset
,
.
post_set_mode
=
sil_post_set_mode
,
.
post_set_mode
=
sil_post_set_mode
,
.
bmdma_setup
=
ata_bmdma_setup
,
.
bmdma_setup
=
ata_bmdma_setup
,
...
...
drivers/scsi/sata_sis.c
View file @
4de1e874
...
@@ -98,6 +98,7 @@ static struct ata_port_operations sis_ops = {
...
@@ -98,6 +98,7 @@ static struct ata_port_operations sis_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
sata_phy_reset
,
.
phy_reset
=
sata_phy_reset
,
.
bmdma_setup
=
ata_bmdma_setup
,
.
bmdma_setup
=
ata_bmdma_setup
,
.
bmdma_start
=
ata_bmdma_start
,
.
bmdma_start
=
ata_bmdma_start
,
...
...
drivers/scsi/sata_svw.c
View file @
4de1e874
...
@@ -297,6 +297,7 @@ static struct ata_port_operations k2_sata_ops = {
...
@@ -297,6 +297,7 @@ static struct ata_port_operations k2_sata_ops = {
.
tf_read
=
k2_sata_tf_read
,
.
tf_read
=
k2_sata_tf_read
,
.
check_status
=
k2_stat_check_status
,
.
check_status
=
k2_stat_check_status
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
sata_phy_reset
,
.
phy_reset
=
sata_phy_reset
,
.
bmdma_setup
=
k2_bmdma_setup_mmio
,
.
bmdma_setup
=
k2_bmdma_setup_mmio
,
.
bmdma_start
=
k2_bmdma_start_mmio
,
.
bmdma_start
=
k2_bmdma_start_mmio
,
...
...
drivers/scsi/sata_sx4.c
View file @
4de1e874
...
@@ -196,6 +196,7 @@ static struct ata_port_operations pdc_20621_ops = {
...
@@ -196,6 +196,7 @@ static struct ata_port_operations pdc_20621_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
exec_command
=
pdc_exec_command_mmio
,
.
exec_command
=
pdc_exec_command_mmio
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
pdc_20621_phy_reset
,
.
phy_reset
=
pdc_20621_phy_reset
,
.
qc_prep
=
pdc20621_qc_prep
,
.
qc_prep
=
pdc20621_qc_prep
,
.
qc_issue
=
pdc20621_qc_issue_prot
,
.
qc_issue
=
pdc20621_qc_issue_prot
,
...
@@ -533,7 +534,7 @@ static void pdc20621_nodata_prep(struct ata_queued_cmd *qc)
...
@@ -533,7 +534,7 @@ static void pdc20621_nodata_prep(struct ata_queued_cmd *qc)
readl
(
dimm_mmio
);
/* MMIO PCI posting flush */
readl
(
dimm_mmio
);
/* MMIO PCI posting flush */
VPRINTK
(
"ata pkt buf ofs %u,
prd size %u, mmio copied
\n
"
,
i
,
sgt_len
);
VPRINTK
(
"ata pkt buf ofs %u,
mmio copied
\n
"
,
i
);
}
}
static
void
pdc20621_qc_prep
(
struct
ata_queued_cmd
*
qc
)
static
void
pdc20621_qc_prep
(
struct
ata_queued_cmd
*
qc
)
...
...
drivers/scsi/sata_via.c
View file @
4de1e874
...
@@ -104,6 +104,7 @@ static struct ata_port_operations svia_sata_ops = {
...
@@ -104,6 +104,7 @@ static struct ata_port_operations svia_sata_ops = {
.
tf_read
=
ata_tf_read
,
.
tf_read
=
ata_tf_read
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
sata_phy_reset
,
.
phy_reset
=
sata_phy_reset
,
...
...
drivers/scsi/sata_vsc.c
View file @
4de1e874
...
@@ -213,6 +213,7 @@ static struct ata_port_operations vsc_sata_ops = {
...
@@ -213,6 +213,7 @@ static struct ata_port_operations vsc_sata_ops = {
.
tf_read
=
vsc_sata_tf_read
,
.
tf_read
=
vsc_sata_tf_read
,
.
exec_command
=
ata_exec_command
,
.
exec_command
=
ata_exec_command
,
.
check_status
=
ata_check_status
,
.
check_status
=
ata_check_status
,
.
dev_select
=
ata_std_dev_select
,
.
phy_reset
=
sata_phy_reset
,
.
phy_reset
=
sata_phy_reset
,
.
bmdma_setup
=
ata_bmdma_setup
,
.
bmdma_setup
=
ata_bmdma_setup
,
.
bmdma_start
=
ata_bmdma_start
,
.
bmdma_start
=
ata_bmdma_start
,
...
...
include/linux/libata.h
View file @
4de1e874
...
@@ -320,6 +320,7 @@ struct ata_port_operations {
...
@@ -320,6 +320,7 @@ struct ata_port_operations {
void
(
*
exec_command
)(
struct
ata_port
*
ap
,
struct
ata_taskfile
*
tf
);
void
(
*
exec_command
)(
struct
ata_port
*
ap
,
struct
ata_taskfile
*
tf
);
u8
(
*
check_status
)(
struct
ata_port
*
ap
);
u8
(
*
check_status
)(
struct
ata_port
*
ap
);
void
(
*
dev_select
)(
struct
ata_port
*
ap
,
unsigned
int
device
);
void
(
*
phy_reset
)
(
struct
ata_port
*
ap
);
void
(
*
phy_reset
)
(
struct
ata_port
*
ap
);
void
(
*
post_set_mode
)
(
struct
ata_port
*
ap
);
void
(
*
post_set_mode
)
(
struct
ata_port
*
ap
);
...
@@ -362,6 +363,7 @@ struct pci_bits {
...
@@ -362,6 +363,7 @@ struct pci_bits {
};
};
extern
void
ata_port_probe
(
struct
ata_port
*
);
extern
void
ata_port_probe
(
struct
ata_port
*
);
extern
void
__sata_phy_reset
(
struct
ata_port
*
ap
);
extern
void
sata_phy_reset
(
struct
ata_port
*
ap
);
extern
void
sata_phy_reset
(
struct
ata_port
*
ap
);
extern
void
ata_bus_reset
(
struct
ata_port
*
ap
);
extern
void
ata_bus_reset
(
struct
ata_port
*
ap
);
extern
void
ata_port_disable
(
struct
ata_port
*
);
extern
void
ata_port_disable
(
struct
ata_port
*
);
...
@@ -383,6 +385,8 @@ extern void ata_tf_load(struct ata_port *ap, struct ata_taskfile *tf);
...
@@ -383,6 +385,8 @@ extern void ata_tf_load(struct ata_port *ap, struct ata_taskfile *tf);
extern
void
ata_tf_read
(
struct
ata_port
*
ap
,
struct
ata_taskfile
*
tf
);
extern
void
ata_tf_read
(
struct
ata_port
*
ap
,
struct
ata_taskfile
*
tf
);
extern
void
ata_tf_to_fis
(
struct
ata_taskfile
*
tf
,
u8
*
fis
,
u8
pmp
);
extern
void
ata_tf_to_fis
(
struct
ata_taskfile
*
tf
,
u8
*
fis
,
u8
pmp
);
extern
void
ata_tf_from_fis
(
u8
*
fis
,
struct
ata_taskfile
*
tf
);
extern
void
ata_tf_from_fis
(
u8
*
fis
,
struct
ata_taskfile
*
tf
);
extern
void
ata_noop_dev_select
(
struct
ata_port
*
ap
,
unsigned
int
device
);
extern
void
ata_std_dev_select
(
struct
ata_port
*
ap
,
unsigned
int
device
);
extern
u8
ata_check_status
(
struct
ata_port
*
ap
);
extern
u8
ata_check_status
(
struct
ata_port
*
ap
);
extern
void
ata_exec_command
(
struct
ata_port
*
ap
,
struct
ata_taskfile
*
tf
);
extern
void
ata_exec_command
(
struct
ata_port
*
ap
,
struct
ata_taskfile
*
tf
);
extern
int
ata_port_start
(
struct
ata_port
*
ap
);
extern
int
ata_port_start
(
struct
ata_port
*
ap
);
...
@@ -398,6 +402,7 @@ extern void ata_sg_init_one(struct ata_queued_cmd *qc, void *buf,
...
@@ -398,6 +402,7 @@ extern void ata_sg_init_one(struct ata_queued_cmd *qc, void *buf,
unsigned
int
buflen
);
unsigned
int
buflen
);
extern
void
ata_sg_init
(
struct
ata_queued_cmd
*
qc
,
struct
scatterlist
*
sg
,
extern
void
ata_sg_init
(
struct
ata_queued_cmd
*
qc
,
struct
scatterlist
*
sg
,
unsigned
int
n_elem
);
unsigned
int
n_elem
);
extern
unsigned
int
ata_dev_classify
(
struct
ata_taskfile
*
tf
);
extern
void
ata_dev_id_string
(
struct
ata_device
*
dev
,
unsigned
char
*
s
,
extern
void
ata_dev_id_string
(
struct
ata_device
*
dev
,
unsigned
char
*
s
,
unsigned
int
ofs
,
unsigned
int
len
);
unsigned
int
ofs
,
unsigned
int
len
);
extern
void
ata_bmdma_setup
(
struct
ata_queued_cmd
*
qc
);
extern
void
ata_bmdma_setup
(
struct
ata_queued_cmd
*
qc
);
...
...
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