Lines Matching refs:sas_dev

211 	struct hisi_sas_device *sas_dev = &hisi_hba->devices[device_id];  in hisi_sas_slot_task_free()  local
243 spin_lock(&sas_dev->lock); in hisi_sas_slot_task_free()
245 spin_unlock(&sas_dev->lock); in hisi_sas_slot_task_free()
401 struct hisi_sas_device *sas_dev) in hisi_sas_task_deliver() argument
413 spin_lock(&sas_dev->lock); in hisi_sas_task_deliver()
414 list_add_tail(&slot->entry, &sas_dev->list); in hisi_sas_task_deliver()
415 spin_unlock(&sas_dev->lock); in hisi_sas_task_deliver()
420 slot->device_id = sas_dev->device_id; in hisi_sas_task_deliver()
466 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_queue_command() local
507 if (DEV_IS_GONE(sas_dev)) { in hisi_sas_queue_command()
508 if (sas_dev) in hisi_sas_queue_command()
510 sas_dev->device_id); in hisi_sas_queue_command()
603 hisi_sas_task_deliver(hisi_hba, slot, dq, sas_dev); in hisi_sas_queue_command()
660 struct hisi_sas_device *sas_dev = NULL; in hisi_sas_alloc_dev() local
672 sas_dev = &hisi_hba->devices[i]; in hisi_sas_alloc_dev()
673 sas_dev->dev_status = HISI_SAS_DEV_INIT; in hisi_sas_alloc_dev()
674 sas_dev->dev_type = device->dev_type; in hisi_sas_alloc_dev()
675 sas_dev->hisi_hba = hisi_hba; in hisi_sas_alloc_dev()
676 sas_dev->sas_device = device; in hisi_sas_alloc_dev()
677 sas_dev->dq = dq; in hisi_sas_alloc_dev()
678 spin_lock_init(&sas_dev->lock); in hisi_sas_alloc_dev()
687 return sas_dev; in hisi_sas_alloc_dev()
743 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_tmf_aborted() local
744 struct hisi_hba *hisi_hba = sas_dev->hisi_hba; in hisi_sas_tmf_aborted()
811 struct hisi_sas_device *sas_dev = ddev->lldd_dev; in hisi_sas_slave_alloc() local
821 sas_dev->dev_status = HISI_SAS_DEV_NORMAL; in hisi_sas_slave_alloc()
830 struct hisi_sas_device *sas_dev; in hisi_sas_dev_found() local
835 sas_dev = hisi_hba->hw->alloc_dev(device); in hisi_sas_dev_found()
837 sas_dev = hisi_sas_alloc_dev(device); in hisi_sas_dev_found()
838 if (!sas_dev) { in hisi_sas_dev_found()
844 device->lldd_dev = sas_dev; in hisi_sas_dev_found()
845 hisi_hba->hw->setup_itct(hisi_hba, sas_dev); in hisi_sas_dev_found()
862 sas_dev->device_id, sas_dev->dev_type); in hisi_sas_dev_found()
1106 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_release_task() local
1108 spin_lock(&sas_dev->lock); in hisi_sas_release_task()
1109 list_for_each_entry_safe(slot, slot2, &sas_dev->list, entry) in hisi_sas_release_task()
1112 spin_unlock(&sas_dev->lock); in hisi_sas_release_task()
1117 struct hisi_sas_device *sas_dev; in hisi_sas_release_tasks() local
1122 sas_dev = &hisi_hba->devices[i]; in hisi_sas_release_tasks()
1123 device = sas_dev->sas_device; in hisi_sas_release_tasks()
1125 if ((sas_dev->dev_type == SAS_PHY_UNUSED) || in hisi_sas_release_tasks()
1142 hisi_sas_internal_task_abort_dev(struct hisi_sas_device *sas_dev, in hisi_sas_internal_task_abort_dev() argument
1146 struct domain_device *device = sas_dev->sas_device; in hisi_sas_internal_task_abort_dev()
1147 struct hisi_hba *hisi_hba = sas_dev->hisi_hba; in hisi_sas_internal_task_abort_dev()
1166 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_dev_gone() local
1172 sas_dev->device_id, sas_dev->dev_type); in hisi_sas_dev_gone()
1176 hisi_sas_internal_task_abort_dev(sas_dev, true); in hisi_sas_dev_gone()
1180 ret = hisi_hba->hw->clear_itct(hisi_hba, sas_dev); in hisi_sas_dev_gone()
1185 hisi_hba->hw->free_device(sas_dev); in hisi_sas_dev_gone()
1189 sas_dev->dev_type = SAS_PHY_UNUSED; in hisi_sas_dev_gone()
1190 sas_dev->sas_device = NULL; in hisi_sas_dev_gone()
1350 struct hisi_sas_device *sas_dev = &hisi_hba->devices[i]; in hisi_sas_refresh_port_id() local
1351 struct domain_device *device = sas_dev->sas_device; in hisi_sas_refresh_port_id()
1357 if ((sas_dev->dev_type == SAS_PHY_UNUSED) in hisi_sas_refresh_port_id()
1379 hisi_hba->hw->setup_itct(hisi_hba, sas_dev); in hisi_sas_refresh_port_id()
1419 struct hisi_sas_device *sas_dev; in hisi_sas_reset_init_all_devices() local
1424 sas_dev = &hisi_hba->devices[i]; in hisi_sas_reset_init_all_devices()
1425 device = sas_dev->sas_device; in hisi_sas_reset_init_all_devices()
1427 if ((sas_dev->dev_type == SAS_PHY_UNUSED) || !device) in hisi_sas_reset_init_all_devices()
1469 struct hisi_sas_device *sas_dev = &hisi_hba->devices[i]; in hisi_sas_terminate_stp_reject() local
1470 struct domain_device *device = sas_dev->sas_device; in hisi_sas_terminate_stp_reject()
1472 if ((sas_dev->dev_type == SAS_PHY_UNUSED) || !device) in hisi_sas_terminate_stp_reject()
1475 rc = hisi_sas_internal_task_abort_dev(sas_dev, false); in hisi_sas_terminate_stp_reject()
1618 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_abort_task() local
1625 if (!sas_dev) in hisi_sas_abort_task()
1681 rc = hisi_sas_internal_task_abort_dev(sas_dev, false); in hisi_sas_abort_task()
1692 if ((sas_dev->dev_status == HISI_SAS_DEV_NCQ_ERR) && in hisi_sas_abort_task()
1727 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_abort_task_set() local
1732 rc = hisi_sas_internal_task_abort_dev(sas_dev, false); in hisi_sas_abort_task_set()
1749 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_debug_I_T_nexus_reset() local
1771 reset_type = (sas_dev->dev_status == HISI_SAS_DEV_INIT || in hisi_sas_debug_I_T_nexus_reset()
1812 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_I_T_nexus_reset() local
1817 if (sas_dev->dev_status == HISI_SAS_DEV_NCQ_ERR) in hisi_sas_I_T_nexus_reset()
1818 sas_dev->dev_status = HISI_SAS_DEV_NORMAL; in hisi_sas_I_T_nexus_reset()
1820 rc = hisi_sas_internal_task_abort_dev(sas_dev, false); in hisi_sas_I_T_nexus_reset()
1862 struct hisi_sas_device *sas_dev = device->lldd_dev; in hisi_sas_lu_reset() local
1868 rc = hisi_sas_internal_task_abort_dev(sas_dev, false); in hisi_sas_lu_reset()
1893 sas_dev->device_id, rc); in hisi_sas_lu_reset()
1922 struct hisi_sas_device *sas_dev = &hisi_hba->devices[i]; in hisi_sas_clear_nexus_ha() local
1923 struct domain_device *device = sas_dev->sas_device; in hisi_sas_clear_nexus_ha()
1925 if ((sas_dev->dev_type == SAS_PHY_UNUSED) || !device || in hisi_sas_clear_nexus_ha()