On 12/10/2016 14:12, Dan Carpenter wrote:
Hello John Garry,

The patch dc8a49cabc73: "scsi: hisi_sas: add internal abort to
hisi_sas_abort_task()" from Aug 24, 2016, leads to the following
static checker warning:

        drivers/scsi/hisi_sas/hisi_sas_main.c:848 hisi_sas_abort_task()
        error: we previously assumed 'slot' could be null (see line 847)

drivers/scsi/hisi_sas/hisi_sas_main.c
    809          spin_unlock_irqrestore(&task->task_state_lock, flags);
    810          sas_dev->dev_status = HISI_SAS_DEV_EH;
    811          if (task->lldd_task && task->task_proto & SAS_PROTOCOL_SSP) {
                     ^^^^^^^^^^^^^^^
We assume that ->lldd_task can be NULL.

    812                  struct scsi_cmnd *cmnd = task->uldd_task;
    813                  struct hisi_sas_slot *slot = task->lldd_task;
    814                  u32 tag = slot->idx;
    815
    816                  int_to_scsilun(cmnd->device->lun, &lun);
    817                  tmf_task.tmf = TMF_ABORT_TASK;
    818                  tmf_task.tag_of_task_to_be_managed = cpu_to_le16(tag);
    819
    820                  rc = hisi_sas_debug_issue_ssp_tmf(task->dev, 
lun.scsi_lun,
    821                                                    &tmf_task);
    822
    823                  /* if successful, clear the task and callback 
forwards.*/
    824                  if (rc == TMF_RESP_FUNC_COMPLETE) {
    825                          if (task->lldd_task) {
    826                                  struct hisi_sas_slot *slot;
    827
    828                                  slot = &hisi_hba->slot_info
    829                                          
[tmf_task.tag_of_task_to_be_managed];
    830                                  spin_lock_irqsave(&hisi_hba->lock, 
flags);
    831                                  hisi_hba->hw->slot_complete(hisi_hba, 
slot, 1);
    832                                  
spin_unlock_irqrestore(&hisi_hba->lock, flags);
    833                          }
    834                  }
    835
    836                  hisi_sas_internal_task_abort(hisi_hba, device,
    837                                               HISI_SAS_INT_ABT_CMD, 
tag);
    838          } else if (task->task_proto & SAS_PROTOCOL_SATA ||
    839                  task->task_proto & SAS_PROTOCOL_STP) {
    840                  if (task->dev->dev_type == SAS_SATA_DEV) {
    841                          hisi_sas_internal_task_abort(hisi_hba, device,
    842                                                       
HISI_SAS_INT_ABT_DEV, 0);
    843                          rc = TMF_RESP_FUNC_COMPLETE;
    844                  }
    845          } else if (task->task_proto & SAS_PROTOCOL_SMP) {
    846                  /* SMP */
    847                  struct hisi_sas_slot *slot = task->lldd_task;

We assign it to slot.

I will check this.

Thanks,
John


    848                  u32 tag = slot->idx;
                                   ^^^^^^^^^
slot dereferenced without checking.

    849
    850                  hisi_sas_internal_task_abort(hisi_hba, device,
    851                                               HISI_SAS_INT_ABT_CMD, 
tag);
    852          }



regards,
dan carpenter

.



--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to