mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-19 12:24:34 +08:00
scsi: aic7xxx: aic79xx: Remove driver-defined SAM status definitions
Replace the driver-defined SAM status definitions with the standard mid-layer defined ones. Link: https://lore.kernel.org/r/20210113090500.129644-9-hare@suse.de Reviewed-by: Bart van Assche <bvanassche@acm.org> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Hannes Reinecke <hare@suse.de> Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
c23435dbc7
commit
54c9f6fdef
@ -8911,7 +8911,7 @@ ahd_handle_scsi_status(struct ahd_softc *ahd, struct scb *scb)
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (siu->status == SCSI_STATUS_OK)
|
||||
if (siu->status == SAM_STAT_GOOD)
|
||||
ahd_set_transaction_status(scb,
|
||||
CAM_REQ_CMP_ERR);
|
||||
}
|
||||
@ -8925,8 +8925,8 @@ ahd_handle_scsi_status(struct ahd_softc *ahd, struct scb *scb)
|
||||
ahd_done(ahd, scb);
|
||||
break;
|
||||
}
|
||||
case SCSI_STATUS_CMD_TERMINATED:
|
||||
case SCSI_STATUS_CHECK_COND:
|
||||
case SAM_STAT_COMMAND_TERMINATED:
|
||||
case SAM_STAT_CHECK_CONDITION:
|
||||
{
|
||||
struct ahd_devinfo devinfo;
|
||||
struct ahd_dma_seg *sg;
|
||||
@ -9016,7 +9016,7 @@ ahd_handle_scsi_status(struct ahd_softc *ahd, struct scb *scb)
|
||||
ahd_queue_scb(ahd, scb);
|
||||
break;
|
||||
}
|
||||
case SCSI_STATUS_OK:
|
||||
case SAM_STAT_GOOD:
|
||||
printk("%s: Interrupted for status of 0???\n",
|
||||
ahd_name(ahd));
|
||||
fallthrough;
|
||||
|
@ -1834,7 +1834,7 @@ ahd_done(struct ahd_softc *ahd, struct scb *scb)
|
||||
|
||||
if (dev->openings == 1
|
||||
&& ahd_get_transaction_status(scb) == CAM_REQ_CMP
|
||||
&& ahd_get_scsi_status(scb) != SCSI_STATUS_QUEUE_FULL)
|
||||
&& ahd_get_scsi_status(scb) != SAM_STAT_TASK_SET_FULL)
|
||||
dev->tag_success_count++;
|
||||
/*
|
||||
* Some devices deal with temporary internal resource
|
||||
@ -1891,8 +1891,8 @@ ahd_linux_handle_scsi_status(struct ahd_softc *ahd,
|
||||
switch (ahd_get_scsi_status(scb)) {
|
||||
default:
|
||||
break;
|
||||
case SCSI_STATUS_CHECK_COND:
|
||||
case SCSI_STATUS_CMD_TERMINATED:
|
||||
case SAM_STAT_CHECK_CONDITION:
|
||||
case SAM_STAT_COMMAND_TERMINATED:
|
||||
{
|
||||
struct scsi_cmnd *cmd;
|
||||
|
||||
@ -1947,7 +1947,7 @@ ahd_linux_handle_scsi_status(struct ahd_softc *ahd,
|
||||
}
|
||||
break;
|
||||
}
|
||||
case SCSI_STATUS_QUEUE_FULL:
|
||||
case SAM_STAT_TASK_SET_FULL:
|
||||
/*
|
||||
* By the time the core driver has returned this
|
||||
* command, all other commands that were queued
|
||||
@ -1993,7 +1993,7 @@ ahd_linux_handle_scsi_status(struct ahd_softc *ahd,
|
||||
dev->last_queuefull_same_count = 0;
|
||||
}
|
||||
ahd_set_transaction_status(scb, CAM_REQUEUE_REQ);
|
||||
ahd_set_scsi_status(scb, SCSI_STATUS_OK);
|
||||
ahd_set_scsi_status(scb, SAM_STAT_GOOD);
|
||||
ahd_platform_set_tags(ahd, sdev, &devinfo,
|
||||
(dev->flags & AHD_DEV_Q_BASIC)
|
||||
? AHD_QUEUE_BASIC : AHD_QUEUE_TAGGED);
|
||||
@ -2007,7 +2007,7 @@ ahd_linux_handle_scsi_status(struct ahd_softc *ahd,
|
||||
ahd_platform_set_tags(ahd, sdev, &devinfo,
|
||||
(dev->flags & AHD_DEV_Q_BASIC)
|
||||
? AHD_QUEUE_BASIC : AHD_QUEUE_TAGGED);
|
||||
ahd_set_scsi_status(scb, SCSI_STATUS_BUSY);
|
||||
ahd_set_scsi_status(scb, SAM_STAT_BUSY);
|
||||
}
|
||||
}
|
||||
|
||||
@ -2039,8 +2039,8 @@ ahd_linux_queue_cmd_complete(struct ahd_softc *ahd, struct scsi_cmnd *cmd)
|
||||
scsi_status = ahd_cmd_get_scsi_status(cmd);
|
||||
|
||||
switch(scsi_status) {
|
||||
case SCSI_STATUS_CMD_TERMINATED:
|
||||
case SCSI_STATUS_CHECK_COND:
|
||||
case SAM_STAT_COMMAND_TERMINATED:
|
||||
case SAM_STAT_CHECK_CONDITION:
|
||||
if ((cmd->result >> 24) != DRIVER_SENSE) {
|
||||
do_fallback = 1;
|
||||
} else {
|
||||
|
@ -1041,12 +1041,12 @@ ahc_handle_seqint(struct ahc_softc *ahc, u_int intstat)
|
||||
ahc_freeze_scb(scb);
|
||||
ahc_set_scsi_status(scb, hscb->shared_data.status.scsi_status);
|
||||
switch (hscb->shared_data.status.scsi_status) {
|
||||
case SCSI_STATUS_OK:
|
||||
case SAM_STAT_GOOD:
|
||||
printk("%s: Interrupted for status of 0???\n",
|
||||
ahc_name(ahc));
|
||||
break;
|
||||
case SCSI_STATUS_CMD_TERMINATED:
|
||||
case SCSI_STATUS_CHECK_COND:
|
||||
case SAM_STAT_COMMAND_TERMINATED:
|
||||
case SAM_STAT_CHECK_CONDITION:
|
||||
{
|
||||
struct ahc_dma_seg *sg;
|
||||
struct scsi_sense *sc;
|
||||
|
@ -1759,7 +1759,7 @@ ahc_done(struct ahc_softc *ahc, struct scb *scb)
|
||||
|
||||
if (dev->openings == 1
|
||||
&& ahc_get_transaction_status(scb) == CAM_REQ_CMP
|
||||
&& ahc_get_scsi_status(scb) != SCSI_STATUS_QUEUE_FULL)
|
||||
&& ahc_get_scsi_status(scb) != SAM_STAT_TASK_SET_FULL)
|
||||
dev->tag_success_count++;
|
||||
/*
|
||||
* Some devices deal with temporary internal resource
|
||||
@ -1816,8 +1816,8 @@ ahc_linux_handle_scsi_status(struct ahc_softc *ahc,
|
||||
switch (ahc_get_scsi_status(scb)) {
|
||||
default:
|
||||
break;
|
||||
case SCSI_STATUS_CHECK_COND:
|
||||
case SCSI_STATUS_CMD_TERMINATED:
|
||||
case SAM_STAT_CHECK_CONDITION:
|
||||
case SAM_STAT_COMMAND_TERMINATED:
|
||||
{
|
||||
struct scsi_cmnd *cmd;
|
||||
|
||||
@ -1855,7 +1855,7 @@ ahc_linux_handle_scsi_status(struct ahc_softc *ahc,
|
||||
}
|
||||
break;
|
||||
}
|
||||
case SCSI_STATUS_QUEUE_FULL:
|
||||
case SAM_STAT_TASK_SET_FULL:
|
||||
{
|
||||
/*
|
||||
* By the time the core driver has returned this
|
||||
@ -1899,7 +1899,7 @@ ahc_linux_handle_scsi_status(struct ahc_softc *ahc,
|
||||
dev->last_queuefull_same_count = 0;
|
||||
}
|
||||
ahc_set_transaction_status(scb, CAM_REQUEUE_REQ);
|
||||
ahc_set_scsi_status(scb, SCSI_STATUS_OK);
|
||||
ahc_set_scsi_status(scb, SAM_STAT_GOOD);
|
||||
ahc_platform_set_tags(ahc, sdev, &devinfo,
|
||||
(dev->flags & AHC_DEV_Q_BASIC)
|
||||
? AHC_QUEUE_BASIC : AHC_QUEUE_TAGGED);
|
||||
@ -1910,7 +1910,7 @@ ahc_linux_handle_scsi_status(struct ahc_softc *ahc,
|
||||
* as if the target returned BUSY SCSI status.
|
||||
*/
|
||||
dev->openings = 1;
|
||||
ahc_set_scsi_status(scb, SCSI_STATUS_BUSY);
|
||||
ahc_set_scsi_status(scb, SAM_STAT_BUSY);
|
||||
ahc_platform_set_tags(ahc, sdev, &devinfo,
|
||||
(dev->flags & AHC_DEV_Q_BASIC)
|
||||
? AHC_QUEUE_BASIC : AHC_QUEUE_TAGGED);
|
||||
|
@ -117,21 +117,6 @@ struct scsi_sense_data
|
||||
#define SSD_FULL_SIZE sizeof(struct scsi_sense_data)
|
||||
};
|
||||
|
||||
/*
|
||||
* Status Byte
|
||||
*/
|
||||
#define SCSI_STATUS_OK 0x00
|
||||
#define SCSI_STATUS_CHECK_COND 0x02
|
||||
#define SCSI_STATUS_COND_MET 0x04
|
||||
#define SCSI_STATUS_BUSY 0x08
|
||||
#define SCSI_STATUS_INTERMED 0x10
|
||||
#define SCSI_STATUS_INTERMED_COND_MET 0x14
|
||||
#define SCSI_STATUS_RESERV_CONFLICT 0x18
|
||||
#define SCSI_STATUS_CMD_TERMINATED 0x22 /* Obsolete in SAM-2 */
|
||||
#define SCSI_STATUS_QUEUE_FULL 0x28
|
||||
#define SCSI_STATUS_ACA_ACTIVE 0x30
|
||||
#define SCSI_STATUS_TASK_ABORTED 0x40
|
||||
|
||||
/************************* Large Disk Handling ********************************/
|
||||
static inline int
|
||||
aic_sector_div(sector_t capacity, int heads, int sectors)
|
||||
|
Loading…
Reference in New Issue
Block a user