Lines Matching refs:ihost

138 	struct isci_host *ihost = container_of(sas_ha, typeof(*ihost), sas_ha);  in isci_show_id()  local
140 return snprintf(buf, PAGE_SIZE, "%d\n", ihost->id); in isci_show_id()
346 struct isci_host *ihost; in isci_setup_interrupts() local
367 ihost = pci_info->hosts[id]; in isci_setup_interrupts()
375 DRV_NAME"-msix", ihost); in isci_setup_interrupts()
382 ihost = pci_info->hosts[id]; in isci_setup_interrupts()
384 devm_free_irq(&pdev->dev, msix->vector, ihost); in isci_setup_interrupts()
392 for_each_isci_host(i, ihost, pdev) { in isci_setup_interrupts()
394 IRQF_SHARED, DRV_NAME"-intx", ihost); in isci_setup_interrupts()
424 static enum sci_status sci_user_parameters_set(struct isci_host *ihost, in sci_user_parameters_set() argument
458 memcpy(&ihost->user_parameters, sci_parms, sizeof(*sci_parms)); in sci_user_parameters_set()
463 static void sci_oem_defaults(struct isci_host *ihost) in sci_oem_defaults() argument
466 struct sci_user_parameters *user = &ihost->user_parameters; in sci_oem_defaults()
467 struct sci_oem_params *oem = &ihost->oem_parameters; in sci_oem_defaults()
501 oem->phys[i].sas_address.low = 0x1 + ihost->id; in sci_oem_defaults()
517 struct isci_host *ihost; in isci_host_alloc() local
521 ihost = devm_kzalloc(&pdev->dev, sizeof(*ihost), GFP_KERNEL); in isci_host_alloc()
522 if (!ihost) in isci_host_alloc()
525 ihost->pdev = pdev; in isci_host_alloc()
526 ihost->id = id; in isci_host_alloc()
527 spin_lock_init(&ihost->scic_lock); in isci_host_alloc()
528 init_waitqueue_head(&ihost->eventq); in isci_host_alloc()
529 ihost->sas_ha.dev = &ihost->pdev->dev; in isci_host_alloc()
530 ihost->sas_ha.lldd_ha = ihost; in isci_host_alloc()
531 tasklet_init(&ihost->completion_tasklet, in isci_host_alloc()
532 isci_host_completion_routine, (unsigned long)ihost); in isci_host_alloc()
536 sci_oem_defaults(ihost); in isci_host_alloc()
538 if (sci_user_parameters_set(ihost, &sci_user_params)) { in isci_host_alloc()
550 ihost->oem_parameters = orom->ctrl[id]; in isci_host_alloc()
555 if (sci_oem_parameters_validate(&ihost->oem_parameters, oem_version)) { in isci_host_alloc()
561 struct isci_port *iport = &ihost->ports[i]; in isci_host_alloc()
564 iport->isci_host = ihost; in isci_host_alloc()
568 isci_phy_init(&ihost->phys[i], ihost, i); in isci_host_alloc()
571 struct isci_remote_device *idev = &ihost->devices[i]; in isci_host_alloc()
582 (is_cable_select_overridden() ? "* " : ""), ihost->id, in isci_host_alloc()
583 lookup_cable_names(decode_cable_selection(ihost, 3)), in isci_host_alloc()
584 lookup_cable_names(decode_cable_selection(ihost, 2)), in isci_host_alloc()
585 lookup_cable_names(decode_cable_selection(ihost, 1)), in isci_host_alloc()
586 lookup_cable_names(decode_cable_selection(ihost, 0))); in isci_host_alloc()
588 err = isci_host_init(ihost); in isci_host_alloc()
592 SHOST_TO_SAS_HA(shost) = &ihost->sas_ha; in isci_host_alloc()
593 ihost->sas_ha.core.shost = shost; in isci_host_alloc()
604 err = isci_register_sas_ha(ihost); in isci_host_alloc()
608 return ihost; in isci_host_alloc()
713 struct isci_host *ihost; in isci_pci_remove() local
716 for_each_isci_host(i, ihost, pdev) { in isci_pci_remove()
717 wait_for_start(ihost); in isci_pci_remove()
718 isci_unregister(ihost); in isci_pci_remove()
719 isci_host_deinit(ihost); in isci_pci_remove()
727 struct isci_host *ihost; in isci_suspend() local
730 for_each_isci_host(i, ihost, pdev) { in isci_suspend()
731 sas_suspend_ha(&ihost->sas_ha); in isci_suspend()
732 isci_host_deinit(ihost); in isci_suspend()
745 struct isci_host *ihost; in isci_resume() local
760 for_each_isci_host(i, ihost, pdev) { in isci_resume()
761 sas_prep_resume_ha(&ihost->sas_ha); in isci_resume()
763 isci_host_init(ihost); in isci_resume()
764 isci_host_start(ihost->sas_ha.core.shost); in isci_resume()
765 wait_for_start(ihost); in isci_resume()
767 sas_resume_ha(&ihost->sas_ha); in isci_resume()