aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ata
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ata')
-rw-r--r--drivers/ata/libata-scsi.c89
-rw-r--r--drivers/ata/libata.h28
2 files changed, 21 insertions, 96 deletions
diff --git a/drivers/ata/libata-scsi.c b/drivers/ata/libata-scsi.c
index a34f32442edf..e516816f66a6 100644
--- a/drivers/ata/libata-scsi.c
+++ b/drivers/ata/libata-scsi.c
@@ -179,6 +179,13 @@ DEVICE_ATTR(link_power_management_policy, S_IRUGO | S_IWUSR,
179 ata_scsi_lpm_show, ata_scsi_lpm_put); 179 ata_scsi_lpm_show, ata_scsi_lpm_put);
180EXPORT_SYMBOL_GPL(dev_attr_link_power_management_policy); 180EXPORT_SYMBOL_GPL(dev_attr_link_power_management_policy);
181 181
182static void ata_scsi_set_sense(struct scsi_cmnd *cmd, u8 sk, u8 asc, u8 ascq)
183{
184 cmd->result = (DRIVER_SENSE << 24) | SAM_STAT_CHECK_CONDITION;
185
186 scsi_build_sense_buffer(0, cmd->sense_buffer, sk, asc, ascq);
187}
188
182static void ata_scsi_invalid_field(struct scsi_cmnd *cmd, 189static void ata_scsi_invalid_field(struct scsi_cmnd *cmd,
183 void (*done)(struct scsi_cmnd *)) 190 void (*done)(struct scsi_cmnd *))
184{ 191{
@@ -1696,10 +1703,9 @@ static inline void ata_scsi_rbuf_put(struct scsi_cmnd *cmd, u8 *buf)
1696 * LOCKING: 1703 * LOCKING:
1697 * spin_lock_irqsave(host lock) 1704 * spin_lock_irqsave(host lock)
1698 */ 1705 */
1699 1706static void ata_scsi_rbuf_fill(struct ata_scsi_args *args,
1700void ata_scsi_rbuf_fill(struct ata_scsi_args *args, 1707 unsigned int (*actor)(struct ata_scsi_args *args,
1701 unsigned int (*actor) (struct ata_scsi_args *args, 1708 u8 *rbuf, unsigned int buflen))
1702 u8 *rbuf, unsigned int buflen))
1703{ 1709{
1704 u8 *rbuf; 1710 u8 *rbuf;
1705 unsigned int buflen, rc; 1711 unsigned int buflen, rc;
@@ -1748,9 +1754,8 @@ void ata_scsi_rbuf_fill(struct ata_scsi_args *args,
1748 * LOCKING: 1754 * LOCKING:
1749 * spin_lock_irqsave(host lock) 1755 * spin_lock_irqsave(host lock)
1750 */ 1756 */
1751 1757static unsigned int ata_scsiop_inq_std(struct ata_scsi_args *args, u8 *rbuf,
1752unsigned int ata_scsiop_inq_std(struct ata_scsi_args *args, u8 *rbuf, 1758 unsigned int buflen)
1753 unsigned int buflen)
1754{ 1759{
1755 u8 hdr[] = { 1760 u8 hdr[] = {
1756 TYPE_DISK, 1761 TYPE_DISK,
@@ -1804,9 +1809,8 @@ unsigned int ata_scsiop_inq_std(struct ata_scsi_args *args, u8 *rbuf,
1804 * LOCKING: 1809 * LOCKING:
1805 * spin_lock_irqsave(host lock) 1810 * spin_lock_irqsave(host lock)
1806 */ 1811 */
1807 1812static unsigned int ata_scsiop_inq_00(struct ata_scsi_args *args, u8 *rbuf,
1808unsigned int ata_scsiop_inq_00(struct ata_scsi_args *args, u8 *rbuf, 1813 unsigned int buflen)
1809 unsigned int buflen)
1810{ 1814{
1811 const u8 pages[] = { 1815 const u8 pages[] = {
1812 0x00, /* page 0x00, this page */ 1816 0x00, /* page 0x00, this page */
@@ -1832,9 +1836,8 @@ unsigned int ata_scsiop_inq_00(struct ata_scsi_args *args, u8 *rbuf,
1832 * LOCKING: 1836 * LOCKING:
1833 * spin_lock_irqsave(host lock) 1837 * spin_lock_irqsave(host lock)
1834 */ 1838 */
1835 1839static unsigned int ata_scsiop_inq_80(struct ata_scsi_args *args, u8 *rbuf,
1836unsigned int ata_scsiop_inq_80(struct ata_scsi_args *args, u8 *rbuf, 1840 unsigned int buflen)
1837 unsigned int buflen)
1838{ 1841{
1839 const u8 hdr[] = { 1842 const u8 hdr[] = {
1840 0, 1843 0,
@@ -1865,9 +1868,8 @@ unsigned int ata_scsiop_inq_80(struct ata_scsi_args *args, u8 *rbuf,
1865 * LOCKING: 1868 * LOCKING:
1866 * spin_lock_irqsave(host lock) 1869 * spin_lock_irqsave(host lock)
1867 */ 1870 */
1868 1871static unsigned int ata_scsiop_inq_83(struct ata_scsi_args *args, u8 *rbuf,
1869unsigned int ata_scsiop_inq_83(struct ata_scsi_args *args, u8 *rbuf, 1872 unsigned int buflen)
1870 unsigned int buflen)
1871{ 1873{
1872 int num; 1874 int num;
1873 const int sat_model_serial_desc_len = 68; 1875 const int sat_model_serial_desc_len = 68;
@@ -1915,9 +1917,8 @@ unsigned int ata_scsiop_inq_83(struct ata_scsi_args *args, u8 *rbuf,
1915 * LOCKING: 1917 * LOCKING:
1916 * spin_lock_irqsave(host lock) 1918 * spin_lock_irqsave(host lock)
1917 */ 1919 */
1918
1919static unsigned int ata_scsiop_inq_89(struct ata_scsi_args *args, u8 *rbuf, 1920static unsigned int ata_scsiop_inq_89(struct ata_scsi_args *args, u8 *rbuf,
1920 unsigned int buflen) 1921 unsigned int buflen)
1921{ 1922{
1922 u8 pbuf[60]; 1923 u8 pbuf[60];
1923 struct ata_taskfile tf; 1924 struct ata_taskfile tf;
@@ -1972,9 +1973,8 @@ static unsigned int ata_scsiop_inq_89(struct ata_scsi_args *args, u8 *rbuf,
1972 * LOCKING: 1973 * LOCKING:
1973 * spin_lock_irqsave(host lock) 1974 * spin_lock_irqsave(host lock)
1974 */ 1975 */
1975 1976static unsigned int ata_scsiop_noop(struct ata_scsi_args *args, u8 *rbuf,
1976unsigned int ata_scsiop_noop(struct ata_scsi_args *args, u8 *rbuf, 1977 unsigned int buflen)
1977 unsigned int buflen)
1978{ 1978{
1979 VPRINTK("ENTER\n"); 1979 VPRINTK("ENTER\n");
1980 return 0; 1980 return 0;
@@ -2312,53 +2312,6 @@ unsigned int ata_scsiop_report_luns(struct ata_scsi_args *args, u8 *rbuf,
2312 return 0; 2312 return 0;
2313} 2313}
2314 2314
2315/**
2316 * ata_scsi_set_sense - Set SCSI sense data and status
2317 * @cmd: SCSI request to be handled
2318 * @sk: SCSI-defined sense key
2319 * @asc: SCSI-defined additional sense code
2320 * @ascq: SCSI-defined additional sense code qualifier
2321 *
2322 * Helper function that builds a valid fixed format, current
2323 * response code and the given sense key (sk), additional sense
2324 * code (asc) and additional sense code qualifier (ascq) with
2325 * a SCSI command status of %SAM_STAT_CHECK_CONDITION and
2326 * DRIVER_SENSE set in the upper bits of scsi_cmnd::result .
2327 *
2328 * LOCKING:
2329 * Not required
2330 */
2331
2332void ata_scsi_set_sense(struct scsi_cmnd *cmd, u8 sk, u8 asc, u8 ascq)
2333{
2334 cmd->result = (DRIVER_SENSE << 24) | SAM_STAT_CHECK_CONDITION;
2335
2336 scsi_build_sense_buffer(0, cmd->sense_buffer, sk, asc, ascq);
2337}
2338
2339/**
2340 * ata_scsi_badcmd - End a SCSI request with an error
2341 * @cmd: SCSI request to be handled
2342 * @done: SCSI command completion function
2343 * @asc: SCSI-defined additional sense code
2344 * @ascq: SCSI-defined additional sense code qualifier
2345 *
2346 * Helper function that completes a SCSI command with
2347 * %SAM_STAT_CHECK_CONDITION, with a sense key %ILLEGAL_REQUEST
2348 * and the specified additional sense codes.
2349 *
2350 * LOCKING:
2351 * spin_lock_irqsave(host lock)
2352 */
2353
2354void ata_scsi_badcmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmnd *), u8 asc, u8 ascq)
2355{
2356 DPRINTK("ENTER\n");
2357 ata_scsi_set_sense(cmd, ILLEGAL_REQUEST, asc, ascq);
2358
2359 done(cmd);
2360}
2361
2362static void atapi_sense_complete(struct ata_queued_cmd *qc) 2315static void atapi_sense_complete(struct ata_queued_cmd *qc)
2363{ 2316{
2364 if (qc->err_mask && ((qc->err_mask & AC_ERR_DEV) == 0)) { 2317 if (qc->err_mask && ((qc->err_mask & AC_ERR_DEV) == 0)) {
diff --git a/drivers/ata/libata.h b/drivers/ata/libata.h
index ae2cfd95d43e..4514283937ea 100644
--- a/drivers/ata/libata.h
+++ b/drivers/ata/libata.h
@@ -146,34 +146,6 @@ extern void ata_scsi_scan_host(struct ata_port *ap, int sync);
146extern int ata_scsi_offline_dev(struct ata_device *dev); 146extern int ata_scsi_offline_dev(struct ata_device *dev);
147extern void ata_scsi_media_change_notify(struct ata_device *dev); 147extern void ata_scsi_media_change_notify(struct ata_device *dev);
148extern void ata_scsi_hotplug(struct work_struct *work); 148extern void ata_scsi_hotplug(struct work_struct *work);
149extern unsigned int ata_scsiop_inq_std(struct ata_scsi_args *args, u8 *rbuf,
150 unsigned int buflen);
151
152extern unsigned int ata_scsiop_inq_00(struct ata_scsi_args *args, u8 *rbuf,
153 unsigned int buflen);
154
155extern unsigned int ata_scsiop_inq_80(struct ata_scsi_args *args, u8 *rbuf,
156 unsigned int buflen);
157extern unsigned int ata_scsiop_inq_83(struct ata_scsi_args *args, u8 *rbuf,
158 unsigned int buflen);
159extern unsigned int ata_scsiop_noop(struct ata_scsi_args *args, u8 *rbuf,
160 unsigned int buflen);
161extern unsigned int ata_scsiop_sync_cache(struct ata_scsi_args *args, u8 *rbuf,
162 unsigned int buflen);
163extern unsigned int ata_scsiop_mode_sense(struct ata_scsi_args *args, u8 *rbuf,
164 unsigned int buflen);
165extern unsigned int ata_scsiop_read_cap(struct ata_scsi_args *args, u8 *rbuf,
166 unsigned int buflen);
167extern unsigned int ata_scsiop_report_luns(struct ata_scsi_args *args, u8 *rbuf,
168 unsigned int buflen);
169extern void ata_scsi_badcmd(struct scsi_cmnd *cmd,
170 void (*done)(struct scsi_cmnd *),
171 u8 asc, u8 ascq);
172extern void ata_scsi_set_sense(struct scsi_cmnd *cmd,
173 u8 sk, u8 asc, u8 ascq);
174extern void ata_scsi_rbuf_fill(struct ata_scsi_args *args,
175 unsigned int (*actor) (struct ata_scsi_args *args,
176 u8 *rbuf, unsigned int buflen));
177extern void ata_schedule_scsi_eh(struct Scsi_Host *shost); 149extern void ata_schedule_scsi_eh(struct Scsi_Host *shost);
178extern void ata_scsi_dev_rescan(struct work_struct *work); 150extern void ata_scsi_dev_rescan(struct work_struct *work);
179extern int ata_bus_probe(struct ata_port *ap); 151extern int ata_bus_probe(struct ata_port *ap);