James Bottomley | 366ca51 | 2008-01-18 10:47:01 -0600 | [diff] [blame] | 1 | #include <linux/kernel.h> |
Paul Gortmaker | 0970366 | 2011-05-27 09:37:25 -0400 | [diff] [blame] | 2 | #include <linux/export.h> |
James Bottomley | 366ca51 | 2008-01-18 10:47:01 -0600 | [diff] [blame] | 3 | #include <scsi/sas.h> |
| 4 | #include <scsi/libsas.h> |
| 5 | |
| 6 | /* fill task_status_struct based on SSP response frame */ |
| 7 | void sas_ssp_task_response(struct device *dev, struct sas_task *task, |
| 8 | struct ssp_response_iu *iu) |
| 9 | { |
| 10 | struct task_status_struct *tstat = &task->task_status; |
| 11 | |
| 12 | tstat->resp = SAS_TASK_COMPLETE; |
| 13 | |
| 14 | if (iu->datapres == 0) |
| 15 | tstat->stat = iu->status; |
| 16 | else if (iu->datapres == 1) |
| 17 | tstat->stat = iu->resp_data[3]; |
| 18 | else if (iu->datapres == 2) { |
James Bottomley | df64d3c | 2010-07-27 15:51:13 -0500 | [diff] [blame] | 19 | tstat->stat = SAM_STAT_CHECK_CONDITION; |
James Bottomley | 366ca51 | 2008-01-18 10:47:01 -0600 | [diff] [blame] | 20 | tstat->buf_valid_size = |
| 21 | min_t(int, SAS_STATUS_BUF_SIZE, |
| 22 | be32_to_cpu(iu->sense_data_len)); |
| 23 | memcpy(tstat->buf, iu->sense_data, tstat->buf_valid_size); |
| 24 | |
James Bottomley | df64d3c | 2010-07-27 15:51:13 -0500 | [diff] [blame] | 25 | if (iu->status != SAM_STAT_CHECK_CONDITION) |
James Bottomley | 366ca51 | 2008-01-18 10:47:01 -0600 | [diff] [blame] | 26 | dev_printk(KERN_WARNING, dev, |
| 27 | "dev %llx sent sense data, but " |
| 28 | "stat(%x) is not CHECK CONDITION\n", |
| 29 | SAS_ADDR(task->dev->sas_addr), |
| 30 | iu->status); |
| 31 | } |
| 32 | else |
| 33 | /* when datapres contains corrupt/unknown value... */ |
James Bottomley | df64d3c | 2010-07-27 15:51:13 -0500 | [diff] [blame] | 34 | tstat->stat = SAM_STAT_CHECK_CONDITION; |
James Bottomley | 366ca51 | 2008-01-18 10:47:01 -0600 | [diff] [blame] | 35 | } |
| 36 | EXPORT_SYMBOL_GPL(sas_ssp_task_response); |
| 37 | |