2019-05-19 13:51:48 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-16 22:20:36 +00:00
|
|
|
/*
|
2005-08-29 00:18:39 +00:00
|
|
|
* libata.h - helper library for ATA
|
|
|
|
*
|
|
|
|
* Copyright 2003-2004 Red Hat, Inc. All rights reserved.
|
|
|
|
* Copyright 2003-2004 Jeff Garzik
|
|
|
|
*
|
|
|
|
* libata documentation is available via 'make {ps|pdf}docs',
|
2017-05-16 12:16:37 +00:00
|
|
|
* as Documentation/driver-api/libata.rst
|
2005-04-16 22:20:36 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __LIBATA_H__
|
|
|
|
#define __LIBATA_H__
|
|
|
|
|
|
|
|
#define DRV_NAME "libata"
|
2007-09-23 04:19:54 +00:00
|
|
|
#define DRV_VERSION "3.00" /* must be exactly four chars */
|
2005-04-16 22:20:36 +00:00
|
|
|
|
|
|
|
/* libata-core.c */
|
2006-11-10 09:08:10 +00:00
|
|
|
enum {
|
|
|
|
/* flags for ata_dev_read_id() */
|
|
|
|
ATA_READID_POSTRESET = (1 << 0), /* reading ID after reset */
|
2007-02-02 07:22:30 +00:00
|
|
|
|
|
|
|
/* selector for ata_down_xfermask_limit() */
|
|
|
|
ATA_DNXFER_PIO = 0, /* speed down PIO */
|
|
|
|
ATA_DNXFER_DMA = 1, /* speed down DMA */
|
|
|
|
ATA_DNXFER_40C = 2, /* apply 40c cable limit */
|
|
|
|
ATA_DNXFER_FORCE_PIO = 3, /* force PIO */
|
|
|
|
ATA_DNXFER_FORCE_PIO0 = 4, /* force PIO0 */
|
|
|
|
|
|
|
|
ATA_DNXFER_QUIET = (1 << 31),
|
2006-11-10 09:08:10 +00:00
|
|
|
};
|
|
|
|
|
2023-09-08 11:04:52 +00:00
|
|
|
#define ATA_PORT_TYPE_NAME "ata_port"
|
|
|
|
|
2012-03-11 07:28:46 +00:00
|
|
|
extern atomic_t ata_print_id;
|
2007-08-07 16:08:45 +00:00
|
|
|
extern int atapi_passthru16;
|
2006-02-28 03:31:19 +00:00
|
|
|
extern int libata_fua;
|
2007-03-28 05:57:37 +00:00
|
|
|
extern int libata_noacpi;
|
2007-11-05 03:05:49 +00:00
|
|
|
extern int libata_allow_tpm;
|
2017-09-30 16:40:40 +00:00
|
|
|
extern const struct device_type ata_port_type;
|
libata: implement slave_link
Explanation taken from the comment of ata_slave_link_init().
In libata, a port contains links and a link contains devices. There
is single host link but if a PMP is attached to it, there can be
multiple fan-out links. On SATA, there's usually a single device
connected to a link but PATA and SATA controllers emulating TF based
interface can have two - master and slave.
However, there are a few controllers which don't fit into this
abstraction too well - SATA controllers which emulate TF interface
with both master and slave devices but also have separate SCR
register sets for each device. These controllers need separate links
for physical link handling (e.g. onlineness, link speed) but should
be treated like a traditional M/S controller for everything else
(e.g. command issue, softreset).
slave_link is libata's way of handling this class of controllers
without impacting core layer too much. For anything other than
physical link handling, the default host link is used for both master
and slave. For physical link handling, separate @ap->slave_link is
used. All dirty details are implemented inside libata core layer.
From LLD's POV, the only difference is that prereset, hardreset and
postreset are called once more for the slave link, so the reset
sequence looks like the following.
prereset(M) -> prereset(S) -> hardreset(M) -> hardreset(S) ->
softreset(M) -> postreset(M) -> postreset(S)
Note that softreset is called only for the master. Softreset resets
both M/S by definition, so SRST on master should handle both (the
standard method will work just fine).
As slave_link excludes PMP support and only code paths which deal with
the attributes of physical link are affected, all the changes are
localized to libata.h, libata-core.c and libata-eh.c.
* ata_is_host_link() updated so that slave_link is considered as host
link too.
* iterator extended to iterate over the slave_link when using the
underbarred version.
* force param handling updated such that devno 16 is mapped to the
slave link/device.
* ata_link_on/offline() updated to return the combined result from
master and slave link. ata_phys_link_on/offline() are the direct
versions.
* EH autopsy and report are performed separately for master slave
links. Reset is udpated to implement the above described reset
sequence.
Except for reset update, most changes are minor, many of them just
modifying dev->link to ata_dev_phys_link(dev) or using phys online
test instead.
After this update, LLDs can take full advantage of per-dev SCR
registers by simply turning on slave link.
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
2008-07-31 08:02:43 +00:00
|
|
|
extern struct ata_link *ata_dev_phys_link(struct ata_device *dev);
|
2020-03-26 15:58:22 +00:00
|
|
|
#ifdef CONFIG_ATA_FORCE
|
2008-02-13 00:15:09 +00:00
|
|
|
extern void ata_force_cbl(struct ata_port *ap);
|
2020-03-26 15:58:22 +00:00
|
|
|
#else
|
|
|
|
static inline void ata_force_cbl(struct ata_port *ap) { }
|
|
|
|
#endif
|
2008-03-27 10:14:23 +00:00
|
|
|
extern u64 ata_tf_to_lba(const struct ata_taskfile *tf);
|
|
|
|
extern u64 ata_tf_to_lba48(const struct ata_taskfile *tf);
|
2022-07-25 01:01:27 +00:00
|
|
|
extern int ata_build_rw_tf(struct ata_queued_cmd *qc, u64 block, u32 n_block,
|
2023-05-11 01:13:51 +00:00
|
|
|
unsigned int tf_flags, int dld, int class);
|
2016-04-04 09:43:57 +00:00
|
|
|
extern u64 ata_tf_read_block(const struct ata_taskfile *tf,
|
|
|
|
struct ata_device *dev);
|
2024-04-02 05:59:52 +00:00
|
|
|
unsigned int ata_exec_internal(struct ata_device *dev, struct ata_taskfile *tf,
|
|
|
|
const u8 *cdb, enum dma_data_direction dma_dir,
|
|
|
|
void *buf, unsigned int buflen,
|
|
|
|
unsigned int timeout);
|
2008-04-07 13:47:19 +00:00
|
|
|
extern int ata_wait_ready(struct ata_link *link, unsigned long deadline,
|
|
|
|
int (*check_ready)(struct ata_link *link));
|
2006-05-31 09:27:44 +00:00
|
|
|
extern int ata_dev_read_id(struct ata_device *dev, unsigned int *p_class,
|
2006-11-10 09:08:10 +00:00
|
|
|
unsigned int flags, u16 *id);
|
2007-05-14 18:28:15 +00:00
|
|
|
extern int ata_dev_reread_id(struct ata_device *dev, unsigned int readid_flags);
|
2007-09-23 04:14:12 +00:00
|
|
|
extern int ata_dev_revalidate(struct ata_device *dev, unsigned int new_class,
|
|
|
|
unsigned int readid_flags);
|
2006-11-01 09:38:52 +00:00
|
|
|
extern int ata_dev_configure(struct ata_device *dev);
|
2023-08-29 01:18:34 +00:00
|
|
|
extern bool ata_dev_power_init_tf(struct ata_device *dev,
|
|
|
|
struct ata_taskfile *tf, bool set_active);
|
ata: libata-scsi: Disable scsi device manage_system_start_stop
The introduction of a device link to create a consumer/supplier
relationship between the scsi device of an ATA device and the ATA port
of that ATA device fixes the ordering of system suspend and resume
operations. For suspend, the scsi device is suspended first and the ata
port after it. This is fine as this allows the synchronize cache and
START STOP UNIT commands issued by the scsi disk driver to be executed
before the ata port is disabled.
For resume operations, the ata port is resumed first, followed
by the scsi device. This allows having the request queue of the scsi
device to be unfrozen after the ata port resume is scheduled in EH,
thus avoiding to see new requests prematurely issued to the ATA device.
Since libata sets manage_system_start_stop to 1, the scsi disk resume
operation also results in issuing a START STOP UNIT command to the
device being resumed so that the device exits standby power mode.
However, restoring the ATA device to the active power mode must be
synchronized with libata EH processing of the port resume operation to
avoid either 1) seeing the start stop unit command being received too
early when the port is not yet resumed and ready to accept commands, or
after the port resume process issues commands such as IDENTIFY to
revalidate the device. In this last case, the risk is that the device
revalidation fails with timeout errors as the drive is still spun down.
Commit 0a8589055936 ("ata,scsi: do not issue START STOP UNIT on resume")
disabled issuing the START STOP UNIT command to avoid issues with it.
But this is incorrect as transitioning a device to the active power
mode from the standby power mode set on suspend requires a media access
command. The IDENTIFY, READ LOG and SET FEATURES commands executed in
libata EH context triggered by the ata port resume operation may thus
fail.
Fix these synchronization issues is by handling a device power mode
transitions for system suspend and resume directly in libata EH context,
without relying on the scsi disk driver management triggered with the
manage_system_start_stop flag.
To do this, the following libata helper functions are introduced:
1) ata_dev_power_set_standby():
This function issues a STANDBY IMMEDIATE command to transitiom a device
to the standby power mode. For HDDs, this spins down the disks. This
function applies only to ATA and ZAC devices and does nothing otherwise.
This function also does nothing for devices that have the
ATA_FLAG_NO_POWEROFF_SPINDOWN or ATA_FLAG_NO_HIBERNATE_SPINDOWN flag
set.
For suspend, call ata_dev_power_set_standby() in
ata_eh_handle_port_suspend() before the port is disabled and frozen.
ata_eh_unload() is also modified to transition all enabled devices to
the standby power mode when the system is shutdown or devices removed.
2) ata_dev_power_set_active() and
This function applies to ATA or ZAC devices and issues a VERIFY command
for 1 sector at LBA 0 to transition the device to the active power mode.
For HDDs, since this function will complete only once the disk spin up.
Its execution uses the same timeouts as for reset, to give the drive
enough time to complete spinup without triggering a command timeout.
For resume, call ata_dev_power_set_active() in
ata_eh_revalidate_and_attach() after the port has been enabled and
before any other command is issued to the device.
With these changes, the manage_system_start_stop and no_start_on_resume
scsi device flags do not need to be set in ata_scsi_dev_config(). The
flag manage_runtime_start_stop is still set to allow the sd driver to
spinup/spindown a disk through the sd runtime operations.
Fixes: 0a8589055936 ("ata,scsi: do not issue START STOP UNIT on resume")
Cc: stable@vger.kernel.org
Signed-off-by: Damien Le Moal <dlemoal@kernel.org>
Reviewed-by: Hannes Reinecke <hare@suse.de>
Tested-by: Geert Uytterhoeven <geert+renesas@glider.be>
Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com>
2023-08-26 00:43:39 +00:00
|
|
|
extern void ata_dev_power_set_standby(struct ata_device *dev);
|
|
|
|
extern void ata_dev_power_set_active(struct ata_device *dev);
|
2009-01-29 11:31:33 +00:00
|
|
|
extern int sata_down_spd_limit(struct ata_link *link, u32 spd_limit);
|
2007-02-02 07:22:30 +00:00
|
|
|
extern int ata_down_xfermask_limit(struct ata_device *dev, unsigned int sel);
|
2010-09-01 15:50:05 +00:00
|
|
|
extern unsigned int ata_dev_set_feature(struct ata_device *dev,
|
2022-08-16 11:53:28 +00:00
|
|
|
u8 subcmd, u8 action);
|
2008-11-10 05:48:21 +00:00
|
|
|
extern void ata_qc_free(struct ata_queued_cmd *qc);
|
2006-03-31 11:41:11 +00:00
|
|
|
extern void ata_qc_issue(struct ata_queued_cmd *qc);
|
2006-05-15 11:58:05 +00:00
|
|
|
extern void __ata_qc_complete(struct ata_queued_cmd *qc);
|
2008-06-17 03:36:26 +00:00
|
|
|
extern int atapi_check_dma(struct ata_queued_cmd *qc);
|
2005-04-16 22:20:36 +00:00
|
|
|
extern void swap_buf_le16(u16 *buf, unsigned int buf_words);
|
libata: implement slave_link
Explanation taken from the comment of ata_slave_link_init().
In libata, a port contains links and a link contains devices. There
is single host link but if a PMP is attached to it, there can be
multiple fan-out links. On SATA, there's usually a single device
connected to a link but PATA and SATA controllers emulating TF based
interface can have two - master and slave.
However, there are a few controllers which don't fit into this
abstraction too well - SATA controllers which emulate TF interface
with both master and slave devices but also have separate SCR
register sets for each device. These controllers need separate links
for physical link handling (e.g. onlineness, link speed) but should
be treated like a traditional M/S controller for everything else
(e.g. command issue, softreset).
slave_link is libata's way of handling this class of controllers
without impacting core layer too much. For anything other than
physical link handling, the default host link is used for both master
and slave. For physical link handling, separate @ap->slave_link is
used. All dirty details are implemented inside libata core layer.
From LLD's POV, the only difference is that prereset, hardreset and
postreset are called once more for the slave link, so the reset
sequence looks like the following.
prereset(M) -> prereset(S) -> hardreset(M) -> hardreset(S) ->
softreset(M) -> postreset(M) -> postreset(S)
Note that softreset is called only for the master. Softreset resets
both M/S by definition, so SRST on master should handle both (the
standard method will work just fine).
As slave_link excludes PMP support and only code paths which deal with
the attributes of physical link are affected, all the changes are
localized to libata.h, libata-core.c and libata-eh.c.
* ata_is_host_link() updated so that slave_link is considered as host
link too.
* iterator extended to iterate over the slave_link when using the
underbarred version.
* force param handling updated such that devno 16 is mapped to the
slave link/device.
* ata_link_on/offline() updated to return the combined result from
master and slave link. ata_phys_link_on/offline() are the direct
versions.
* EH autopsy and report are performed separately for master slave
links. Reset is udpated to implement the above described reset
sequence.
Except for reset update, most changes are minor, many of them just
modifying dev->link to ata_dev_phys_link(dev) or using phys online
test instead.
After this update, LLDs can take full advantage of per-dev SCR
registers by simply turning on slave link.
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
2008-07-31 08:02:43 +00:00
|
|
|
extern bool ata_phys_link_online(struct ata_link *link);
|
|
|
|
extern bool ata_phys_link_offline(struct ata_link *link);
|
2006-05-31 09:27:30 +00:00
|
|
|
extern void ata_dev_init(struct ata_device *dev);
|
2007-09-23 04:14:12 +00:00
|
|
|
extern void ata_link_init(struct ata_port *ap, struct ata_link *link, int pmp);
|
|
|
|
extern int sata_link_init_spd(struct ata_link *link);
|
2005-05-12 19:45:22 +00:00
|
|
|
extern int ata_task_ioctl(struct scsi_device *scsidev, void __user *arg);
|
|
|
|
extern int ata_cmd_ioctl(struct scsi_device *scsidev, void __user *arg);
|
2007-04-17 14:44:07 +00:00
|
|
|
extern struct ata_port *ata_port_alloc(struct ata_host *host);
|
2010-05-25 19:31:38 +00:00
|
|
|
extern const char *sata_spd_string(unsigned int spd);
|
2017-06-04 12:42:20 +00:00
|
|
|
extern unsigned int ata_read_log_page(struct ata_device *dev, u8 log,
|
|
|
|
u8 page, void *buf, unsigned int sectors);
|
2005-04-16 22:20:36 +00:00
|
|
|
|
2012-06-25 08:13:03 +00:00
|
|
|
#define to_ata_port(d) container_of(d, struct ata_port, tdev)
|
|
|
|
|
2006-09-28 18:29:01 +00:00
|
|
|
/* libata-acpi.c */
|
2007-05-05 14:50:38 +00:00
|
|
|
#ifdef CONFIG_ATA_ACPI
|
2009-09-15 19:17:28 +00:00
|
|
|
extern unsigned int ata_acpi_gtf_filter;
|
2007-12-15 06:05:01 +00:00
|
|
|
extern void ata_acpi_dissociate(struct ata_host *host);
|
libata: reimplement ACPI invocation
This patch reimplements ACPI invocation such that, instead of
exporting ACPI details to the rest of libata, ACPI event handlers -
ata_acpi_on_resume() and ata_acpi_on_devcfg() - are used. These two
functions are responsible for determining whether specific ACPI method
is used and when.
On resume, _GTF is scheduled by setting ATA_DFLAG_ACPI_PENDING device
flag. This is done this way to avoid performing the action on wrong
device device (device swapping while suspended).
On every ata_dev_configure(), ata_acpi_on_devcfg() is called, which
performs _SDD and _GTF. _GTF is performed only after resuming and, if
SATA, hardreset as the ACPI spec specifies. As _GTF may contain
arbitrary commands, IDENTIFY page is re-read after _GTF taskfiles are
executed.
If one of ACPI methods fails, ata_acpi_on_devcfg() retries on the
first failure. If it fails again on the second try, ACPI is disabled
on the device. Note that successful configuration clears ACPI failed
status.
With all feature checks moved to the above two functions,
do_drive_set_taskfiles() is trivial and thus collapsed into
ata_acpi_exec_tfs(), which is now static and converted to return the
number of executed taskfiles to be used by ata_acpi_on_resume(). As
failures are handled properly, ata_acpi_push_id() now returns -errno
on errors instead of unconditional zero.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
2007-05-14 18:28:16 +00:00
|
|
|
extern void ata_acpi_on_resume(struct ata_port *ap);
|
2007-12-15 06:05:01 +00:00
|
|
|
extern int ata_acpi_on_devcfg(struct ata_device *dev);
|
|
|
|
extern void ata_acpi_on_disable(struct ata_device *dev);
|
2007-11-02 01:32:38 +00:00
|
|
|
extern void ata_acpi_set_state(struct ata_port *ap, pm_message_t state);
|
ata: acpi: rework the ata acpi bind support
Binding ACPI handle to SCSI device has several drawbacks, namely:
1 During ATA device initialization time, ACPI handle will be needed
while SCSI devices are not created yet. So each time ACPI handle is
needed, instead of retrieving the handle by ACPI_HANDLE macro,
a namespace scan is performed to find the handle for the corresponding
ATA device. This is inefficient, and also expose a restriction on
calling path not holding any lock.
2 The binding to SCSI device tree makes code complex, while at the same
time doesn't bring us any benefit. All ACPI handlings are still done
in ATA module, not in SCSI.
Rework the ATA ACPI binding code to bind ACPI handle to ATA transport
devices(ATA port and ATA device). The binding needs to be done only once,
since the ATA transport devices do not go away with hotplug. And due to
this, the flush_work call in hotplug handler for ATA bay is no longer
needed.
Tested on an Intel test platform for binding and runtime power off for
ODD(ZPODD) and hard disk; on an ASUS S400C for binding and normal boot
and S3, where its SATA port node has _SDD and _GTF control methods when
configured as an AHCI controller and its PATA device node has _GTF
control method when configured as an IDE controller. SATA PMP binding
and ATA hotplug is not tested.
Signed-off-by: Aaron Lu <aaron.lu@intel.com>
Tested-by: Dirk Griesbach <spamthis@freenet.de>
Signed-off-by: Tejun Heo <tj@kernel.org>
2013-08-23 02:17:54 +00:00
|
|
|
extern void ata_acpi_bind_port(struct ata_port *ap);
|
|
|
|
extern void ata_acpi_bind_dev(struct ata_device *dev);
|
|
|
|
extern acpi_handle ata_dev_acpi_handle(struct ata_device *dev);
|
2006-09-28 18:29:01 +00:00
|
|
|
#else
|
2007-12-15 06:05:01 +00:00
|
|
|
static inline void ata_acpi_dissociate(struct ata_host *host) { }
|
libata: reimplement ACPI invocation
This patch reimplements ACPI invocation such that, instead of
exporting ACPI details to the rest of libata, ACPI event handlers -
ata_acpi_on_resume() and ata_acpi_on_devcfg() - are used. These two
functions are responsible for determining whether specific ACPI method
is used and when.
On resume, _GTF is scheduled by setting ATA_DFLAG_ACPI_PENDING device
flag. This is done this way to avoid performing the action on wrong
device device (device swapping while suspended).
On every ata_dev_configure(), ata_acpi_on_devcfg() is called, which
performs _SDD and _GTF. _GTF is performed only after resuming and, if
SATA, hardreset as the ACPI spec specifies. As _GTF may contain
arbitrary commands, IDENTIFY page is re-read after _GTF taskfiles are
executed.
If one of ACPI methods fails, ata_acpi_on_devcfg() retries on the
first failure. If it fails again on the second try, ACPI is disabled
on the device. Note that successful configuration clears ACPI failed
status.
With all feature checks moved to the above two functions,
do_drive_set_taskfiles() is trivial and thus collapsed into
ata_acpi_exec_tfs(), which is now static and converted to return the
number of executed taskfiles to be used by ata_acpi_on_resume(). As
failures are handled properly, ata_acpi_push_id() now returns -errno
on errors instead of unconditional zero.
Signed-off-by: Tejun Heo <htejun@gmail.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
2007-05-14 18:28:16 +00:00
|
|
|
static inline void ata_acpi_on_resume(struct ata_port *ap) { }
|
2007-12-15 06:05:01 +00:00
|
|
|
static inline int ata_acpi_on_devcfg(struct ata_device *dev) { return 0; }
|
|
|
|
static inline void ata_acpi_on_disable(struct ata_device *dev) { }
|
2007-11-02 01:32:38 +00:00
|
|
|
static inline void ata_acpi_set_state(struct ata_port *ap,
|
|
|
|
pm_message_t state) { }
|
ata: acpi: rework the ata acpi bind support
Binding ACPI handle to SCSI device has several drawbacks, namely:
1 During ATA device initialization time, ACPI handle will be needed
while SCSI devices are not created yet. So each time ACPI handle is
needed, instead of retrieving the handle by ACPI_HANDLE macro,
a namespace scan is performed to find the handle for the corresponding
ATA device. This is inefficient, and also expose a restriction on
calling path not holding any lock.
2 The binding to SCSI device tree makes code complex, while at the same
time doesn't bring us any benefit. All ACPI handlings are still done
in ATA module, not in SCSI.
Rework the ATA ACPI binding code to bind ACPI handle to ATA transport
devices(ATA port and ATA device). The binding needs to be done only once,
since the ATA transport devices do not go away with hotplug. And due to
this, the flush_work call in hotplug handler for ATA bay is no longer
needed.
Tested on an Intel test platform for binding and runtime power off for
ODD(ZPODD) and hard disk; on an ASUS S400C for binding and normal boot
and S3, where its SATA port node has _SDD and _GTF control methods when
configured as an AHCI controller and its PATA device node has _GTF
control method when configured as an IDE controller. SATA PMP binding
and ATA hotplug is not tested.
Signed-off-by: Aaron Lu <aaron.lu@intel.com>
Tested-by: Dirk Griesbach <spamthis@freenet.de>
Signed-off-by: Tejun Heo <tj@kernel.org>
2013-08-23 02:17:54 +00:00
|
|
|
static inline void ata_acpi_bind_port(struct ata_port *ap) {}
|
|
|
|
static inline void ata_acpi_bind_dev(struct ata_device *dev) {}
|
2006-09-28 18:29:01 +00:00
|
|
|
#endif
|
2005-04-16 22:20:36 +00:00
|
|
|
|
|
|
|
/* libata-scsi.c */
|
2020-03-26 15:58:18 +00:00
|
|
|
extern struct ata_device *ata_scsi_find_dev(struct ata_port *ap,
|
|
|
|
const struct scsi_device *scsidev);
|
2007-04-17 14:44:07 +00:00
|
|
|
extern int ata_scsi_add_hosts(struct ata_host *host,
|
2023-03-22 19:53:59 +00:00
|
|
|
const struct scsi_host_template *sht);
|
2007-07-16 05:29:40 +00:00
|
|
|
extern void ata_scsi_scan_host(struct ata_port *ap, int sync);
|
2006-05-31 09:28:01 +00:00
|
|
|
extern int ata_scsi_offline_dev(struct ata_device *dev);
|
2022-09-26 20:53:07 +00:00
|
|
|
extern bool ata_scsi_sense_is_valid(u8 sk, u8 asc, u8 ascq);
|
2016-04-04 09:44:03 +00:00
|
|
|
extern void ata_scsi_set_sense(struct ata_device *dev,
|
|
|
|
struct scsi_cmnd *cmd, u8 sk, u8 asc, u8 ascq);
|
2016-04-04 09:43:59 +00:00
|
|
|
extern void ata_scsi_set_sense_information(struct ata_device *dev,
|
|
|
|
struct scsi_cmnd *cmd,
|
|
|
|
const struct ata_taskfile *tf);
|
2007-09-23 04:14:13 +00:00
|
|
|
extern void ata_scsi_media_change_notify(struct ata_device *dev);
|
2006-11-22 14:55:48 +00:00
|
|
|
extern void ata_scsi_hotplug(struct work_struct *work);
|
2006-05-15 11:58:07 +00:00
|
|
|
extern void ata_schedule_scsi_eh(struct Scsi_Host *shost);
|
2006-11-22 14:55:48 +00:00
|
|
|
extern void ata_scsi_dev_rescan(struct work_struct *work);
|
2010-05-25 19:31:38 +00:00
|
|
|
extern int ata_scsi_user_scan(struct Scsi_Host *shost, unsigned int channel,
|
2014-06-25 13:27:36 +00:00
|
|
|
unsigned int id, u64 lun);
|
2020-03-26 15:58:19 +00:00
|
|
|
void ata_scsi_sdev_config(struct scsi_device *sdev);
|
2024-04-09 14:37:45 +00:00
|
|
|
int ata_scsi_dev_config(struct scsi_device *sdev, struct queue_limits *lim,
|
|
|
|
struct ata_device *dev);
|
2020-03-26 15:58:19 +00:00
|
|
|
int __ata_scsi_queuecmd(struct scsi_cmnd *scmd, struct ata_device *dev);
|
2005-04-16 22:20:36 +00:00
|
|
|
|
2006-04-02 09:51:53 +00:00
|
|
|
/* libata-eh.c */
|
2022-06-18 20:38:10 +00:00
|
|
|
extern unsigned int ata_internal_cmd_timeout(struct ata_device *dev, u8 cmd);
|
2008-05-19 17:17:54 +00:00
|
|
|
extern void ata_internal_cmd_timed_out(struct ata_device *dev, u8 cmd);
|
libata: implement cross-port EH exclusion
In libata, the non-EH code paths should always take and release
ap->lock explicitly when accessing hardware or shared data structures.
However, once EH is active, it's assumed that the port is owned by EH
and EH methods don't explicitly take ap->lock unless race from irq
handler or other code paths are expected. However, libata EH didn't
guarantee exclusion among EHs for ports of the same host. IOW,
multiple EHs may execute in parallel on multiple ports of the same
controller.
In many cases, especially in SATA, the ports are completely
independent of each other and this doesn't cause problems; however,
there are cases where different ports share the same resource, which
lead to obscure timing related bugs such as the one fixed by commit
213373cf (ata_piix: fix locking around SIDPR access).
This patch implements exclusion among EHs of the same host. When EH
begins, it acquires per-host EH ownership by calling ata_eh_acquire().
When EH finishes, the ownership is released by calling
ata_eh_release(). EH ownership is also released whenever the EH
thread goes to sleep from ata_msleep() or explicitly and reacquired
after waking up.
This ensures that while EH is actively accessing the hardware, it has
exclusive access to it while allowing EHs to interleave and progress
in parallel as they hit waiting stages, which dominate the time spent
in EH. This achieves cross-port EH exclusion without pervasive and
fragile changes while still allowing parallel EH for the most part.
This was first reported by yuanding02@gmail.com more than three years
ago in the following bugzilla. :-)
https://bugzilla.kernel.org/show_bug.cgi?id=8223
Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: Alan Cox <alan@lxorguk.ukuu.org.uk>
Reported-by: yuanding02@gmail.com
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
2010-09-06 15:57:14 +00:00
|
|
|
extern void ata_eh_acquire(struct ata_port *ap);
|
|
|
|
extern void ata_eh_release(struct ata_port *ap);
|
2006-04-11 17:04:39 +00:00
|
|
|
extern void ata_scsi_error(struct Scsi_Host *host);
|
2017-10-16 21:56:42 +00:00
|
|
|
extern void ata_eh_fastdrain_timerfn(struct timer_list *t);
|
2006-05-15 11:58:05 +00:00
|
|
|
extern void ata_qc_schedule_eh(struct ata_queued_cmd *qc);
|
2009-01-29 11:31:30 +00:00
|
|
|
extern void ata_dev_disable(struct ata_device *dev);
|
2007-09-23 04:14:12 +00:00
|
|
|
extern void ata_eh_detach_dev(struct ata_device *dev);
|
|
|
|
extern void ata_eh_about_to_do(struct ata_link *link, struct ata_device *dev,
|
|
|
|
unsigned int action);
|
|
|
|
extern void ata_eh_done(struct ata_link *link, struct ata_device *dev,
|
|
|
|
unsigned int action);
|
|
|
|
extern void ata_eh_autopsy(struct ata_port *ap);
|
2021-12-21 07:20:36 +00:00
|
|
|
const char *ata_get_cmd_name(u8 command);
|
2007-09-23 04:14:12 +00:00
|
|
|
extern void ata_eh_report(struct ata_port *ap);
|
|
|
|
extern int ata_eh_reset(struct ata_link *link, int classify,
|
|
|
|
ata_prereset_fn_t prereset, ata_reset_fn_t softreset,
|
|
|
|
ata_reset_fn_t hardreset, ata_postreset_fn_t postreset);
|
2007-11-27 10:28:55 +00:00
|
|
|
extern int ata_set_mode(struct ata_link *link, struct ata_device **r_failed_dev);
|
2007-09-23 04:14:12 +00:00
|
|
|
extern int ata_eh_recover(struct ata_port *ap, ata_prereset_fn_t prereset,
|
|
|
|
ata_reset_fn_t softreset, ata_reset_fn_t hardreset,
|
|
|
|
ata_postreset_fn_t postreset,
|
|
|
|
struct ata_link **r_failed_disk);
|
|
|
|
extern void ata_eh_finish(struct ata_port *ap);
|
2010-05-25 19:31:38 +00:00
|
|
|
extern int ata_ering_map(struct ata_ering *ering,
|
|
|
|
int (*map_fn)(struct ata_ering_entry *, void *),
|
2021-12-21 07:20:25 +00:00
|
|
|
void *arg);
|
libata: check zero power ready status for ZPODD
Per the Mount Fuji spec, the ODD is considered zero power ready when:
- For slot type ODD, no media inside;
- For tray type ODD, no media inside and tray closed.
The information can be retrieved by either the returned information of
command GET_EVENT_STATUS_NOTIFICATION(the command is used to poll for
media event) or sense code.
The information provided by the media status byte is not accurate, it
is possible that after a new disc is just inserted, the status byte
still returns media not present. So this information can not be used as
the deciding factor, we use sense code to decide if zpready status is
true.
When we first sensed the ODD in the zero power ready state, the
zp_sampled will be set and timestamp will be recoreded. And after ODD
stayed in this state for some pre-defined period, the ODD is considered
as power off ready and the zp_ready flag will be set. The zp_ready flag
serves as the deciding factor other code will use to see if power off is
OK for the ODD.
The Mount Fuji spec suggests a delay should be used here, to avoid the
case user ejects the ODD and then instantly inserts a new one again, so
that we can avoid a power transition. And some ODDs may be slow to place
its head to the home position after disc is ejected, so a delay here is
generally a good idea. And the delay time can be changed via the module
param zpodd_poweroff_delay.
The zero power ready status check is performed in the ata port's runtime
suspend code path, when port is not frozen yet, as we need to issue some
IOs to the ODD.
Signed-off-by: Aaron Lu <aaron.lu@intel.com>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
2013-01-15 09:21:00 +00:00
|
|
|
extern unsigned int atapi_eh_tur(struct ata_device *dev, u8 *r_sense_key);
|
|
|
|
extern unsigned int atapi_eh_request_sense(struct ata_device *dev,
|
|
|
|
u8 *sense_buf, u8 dfl_sense_key);
|
2006-04-02 09:51:53 +00:00
|
|
|
|
2008-04-07 13:47:21 +00:00
|
|
|
/* libata-pmp.c */
|
2008-04-07 13:47:22 +00:00
|
|
|
#ifdef CONFIG_SATA_PMP
|
2008-04-07 13:47:21 +00:00
|
|
|
extern int sata_pmp_scr_read(struct ata_link *link, int reg, u32 *val);
|
|
|
|
extern int sata_pmp_scr_write(struct ata_link *link, int reg, u32 val);
|
2010-09-01 15:50:07 +00:00
|
|
|
extern int sata_pmp_set_lpm(struct ata_link *link, enum ata_lpm_policy policy,
|
|
|
|
unsigned hints);
|
2008-04-07 13:47:21 +00:00
|
|
|
extern int sata_pmp_attach(struct ata_device *dev);
|
2008-04-07 13:47:22 +00:00
|
|
|
#else /* CONFIG_SATA_PMP */
|
|
|
|
static inline int sata_pmp_scr_read(struct ata_link *link, int reg, u32 *val)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int sata_pmp_scr_write(struct ata_link *link, int reg, u32 val)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
2010-09-01 15:50:07 +00:00
|
|
|
static inline int sata_pmp_set_lpm(struct ata_link *link,
|
|
|
|
enum ata_lpm_policy policy, unsigned hints)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
2008-04-07 13:47:22 +00:00
|
|
|
static inline int sata_pmp_attach(struct ata_device *dev)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
#endif /* CONFIG_SATA_PMP */
|
2008-04-07 13:47:21 +00:00
|
|
|
|
2006-10-09 02:10:26 +00:00
|
|
|
/* libata-sff.c */
|
2008-04-07 13:47:21 +00:00
|
|
|
#ifdef CONFIG_ATA_SFF
|
2010-05-10 19:41:38 +00:00
|
|
|
extern void ata_sff_flush_pio_task(struct ata_port *ap);
|
2010-05-10 19:41:35 +00:00
|
|
|
extern void ata_sff_port_init(struct ata_port *ap);
|
|
|
|
extern int ata_sff_init(void);
|
|
|
|
extern void ata_sff_exit(void);
|
|
|
|
#else /* CONFIG_ATA_SFF */
|
2010-05-10 19:41:38 +00:00
|
|
|
static inline void ata_sff_flush_pio_task(struct ata_port *ap)
|
|
|
|
{ }
|
2010-05-10 19:41:35 +00:00
|
|
|
static inline void ata_sff_port_init(struct ata_port *ap)
|
|
|
|
{ }
|
|
|
|
static inline int ata_sff_init(void)
|
|
|
|
{ return 0; }
|
|
|
|
static inline void ata_sff_exit(void)
|
|
|
|
{ }
|
2008-04-07 13:47:21 +00:00
|
|
|
#endif /* CONFIG_ATA_SFF */
|
2007-01-30 08:59:17 +00:00
|
|
|
|
2013-01-15 09:20:58 +00:00
|
|
|
/* libata-zpodd.c */
|
|
|
|
#ifdef CONFIG_SATA_ZPODD
|
|
|
|
void zpodd_init(struct ata_device *dev);
|
|
|
|
void zpodd_exit(struct ata_device *dev);
|
|
|
|
static inline bool zpodd_dev_enabled(struct ata_device *dev)
|
|
|
|
{
|
|
|
|
return dev->zpodd != NULL;
|
|
|
|
}
|
libata: check zero power ready status for ZPODD
Per the Mount Fuji spec, the ODD is considered zero power ready when:
- For slot type ODD, no media inside;
- For tray type ODD, no media inside and tray closed.
The information can be retrieved by either the returned information of
command GET_EVENT_STATUS_NOTIFICATION(the command is used to poll for
media event) or sense code.
The information provided by the media status byte is not accurate, it
is possible that after a new disc is just inserted, the status byte
still returns media not present. So this information can not be used as
the deciding factor, we use sense code to decide if zpready status is
true.
When we first sensed the ODD in the zero power ready state, the
zp_sampled will be set and timestamp will be recoreded. And after ODD
stayed in this state for some pre-defined period, the ODD is considered
as power off ready and the zp_ready flag will be set. The zp_ready flag
serves as the deciding factor other code will use to see if power off is
OK for the ODD.
The Mount Fuji spec suggests a delay should be used here, to avoid the
case user ejects the ODD and then instantly inserts a new one again, so
that we can avoid a power transition. And some ODDs may be slow to place
its head to the home position after disc is ejected, so a delay here is
generally a good idea. And the delay time can be changed via the module
param zpodd_poweroff_delay.
The zero power ready status check is performed in the ata port's runtime
suspend code path, when port is not frozen yet, as we need to issue some
IOs to the ODD.
Signed-off-by: Aaron Lu <aaron.lu@intel.com>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
2013-01-15 09:21:00 +00:00
|
|
|
void zpodd_on_suspend(struct ata_device *dev);
|
2013-01-15 09:21:01 +00:00
|
|
|
bool zpodd_zpready(struct ata_device *dev);
|
|
|
|
void zpodd_enable_run_wake(struct ata_device *dev);
|
|
|
|
void zpodd_disable_run_wake(struct ata_device *dev);
|
|
|
|
void zpodd_post_poweron(struct ata_device *dev);
|
2013-01-15 09:20:58 +00:00
|
|
|
#else /* CONFIG_SATA_ZPODD */
|
|
|
|
static inline void zpodd_init(struct ata_device *dev) {}
|
|
|
|
static inline void zpodd_exit(struct ata_device *dev) {}
|
|
|
|
static inline bool zpodd_dev_enabled(struct ata_device *dev) { return false; }
|
libata: check zero power ready status for ZPODD
Per the Mount Fuji spec, the ODD is considered zero power ready when:
- For slot type ODD, no media inside;
- For tray type ODD, no media inside and tray closed.
The information can be retrieved by either the returned information of
command GET_EVENT_STATUS_NOTIFICATION(the command is used to poll for
media event) or sense code.
The information provided by the media status byte is not accurate, it
is possible that after a new disc is just inserted, the status byte
still returns media not present. So this information can not be used as
the deciding factor, we use sense code to decide if zpready status is
true.
When we first sensed the ODD in the zero power ready state, the
zp_sampled will be set and timestamp will be recoreded. And after ODD
stayed in this state for some pre-defined period, the ODD is considered
as power off ready and the zp_ready flag will be set. The zp_ready flag
serves as the deciding factor other code will use to see if power off is
OK for the ODD.
The Mount Fuji spec suggests a delay should be used here, to avoid the
case user ejects the ODD and then instantly inserts a new one again, so
that we can avoid a power transition. And some ODDs may be slow to place
its head to the home position after disc is ejected, so a delay here is
generally a good idea. And the delay time can be changed via the module
param zpodd_poweroff_delay.
The zero power ready status check is performed in the ata port's runtime
suspend code path, when port is not frozen yet, as we need to issue some
IOs to the ODD.
Signed-off-by: Aaron Lu <aaron.lu@intel.com>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
2013-01-15 09:21:00 +00:00
|
|
|
static inline void zpodd_on_suspend(struct ata_device *dev) {}
|
2013-01-15 09:21:01 +00:00
|
|
|
static inline bool zpodd_zpready(struct ata_device *dev) { return false; }
|
|
|
|
static inline void zpodd_enable_run_wake(struct ata_device *dev) {}
|
|
|
|
static inline void zpodd_disable_run_wake(struct ata_device *dev) {}
|
|
|
|
static inline void zpodd_post_poweron(struct ata_device *dev) {}
|
2013-01-15 09:20:58 +00:00
|
|
|
#endif /* CONFIG_SATA_ZPODD */
|
|
|
|
|
2005-04-16 22:20:36 +00:00
|
|
|
#endif /* __LIBATA_H__ */
|