Lines Matching refs:fw_event
246 struct fw_event_work *fw_event; in alloc_fw_event_work() local
248 fw_event = kzalloc(sizeof(*fw_event) + len, GFP_ATOMIC); in alloc_fw_event_work()
249 if (!fw_event) in alloc_fw_event_work()
252 kref_init(&fw_event->refcount); in alloc_fw_event_work()
253 return fw_event; in alloc_fw_event_work()
3562 _scsih_fw_event_add(struct MPT3SAS_ADAPTER *ioc, struct fw_event_work *fw_event) in _scsih_fw_event_add() argument
3570 fw_event_work_get(fw_event); in _scsih_fw_event_add()
3571 INIT_LIST_HEAD(&fw_event->list); in _scsih_fw_event_add()
3572 list_add_tail(&fw_event->list, &ioc->fw_event_list); in _scsih_fw_event_add()
3573 INIT_WORK(&fw_event->work, _firmware_event_work); in _scsih_fw_event_add()
3574 fw_event_work_get(fw_event); in _scsih_fw_event_add()
3575 queue_work(ioc->firmware_event_thread, &fw_event->work); in _scsih_fw_event_add()
3589 *fw_event) in _scsih_fw_event_del_from_list()
3594 if (!list_empty(&fw_event->list)) { in _scsih_fw_event_del_from_list()
3595 list_del_init(&fw_event->list); in _scsih_fw_event_del_from_list()
3596 fw_event_work_put(fw_event); in _scsih_fw_event_del_from_list()
3611 struct fw_event_work *fw_event; in mpt3sas_send_trigger_data_event() local
3617 fw_event = alloc_fw_event_work(sz); in mpt3sas_send_trigger_data_event()
3618 if (!fw_event) in mpt3sas_send_trigger_data_event()
3620 fw_event->event = MPT3SAS_PROCESS_TRIGGER_DIAG; in mpt3sas_send_trigger_data_event()
3621 fw_event->ioc = ioc; in mpt3sas_send_trigger_data_event()
3622 memcpy(fw_event->event_data, event_data, sizeof(*event_data)); in mpt3sas_send_trigger_data_event()
3623 _scsih_fw_event_add(ioc, fw_event); in mpt3sas_send_trigger_data_event()
3624 fw_event_work_put(fw_event); in mpt3sas_send_trigger_data_event()
3634 struct fw_event_work *fw_event; in _scsih_error_recovery_delete_devices() local
3636 fw_event = alloc_fw_event_work(0); in _scsih_error_recovery_delete_devices()
3637 if (!fw_event) in _scsih_error_recovery_delete_devices()
3639 fw_event->event = MPT3SAS_REMOVE_UNRESPONDING_DEVICES; in _scsih_error_recovery_delete_devices()
3640 fw_event->ioc = ioc; in _scsih_error_recovery_delete_devices()
3641 _scsih_fw_event_add(ioc, fw_event); in _scsih_error_recovery_delete_devices()
3642 fw_event_work_put(fw_event); in _scsih_error_recovery_delete_devices()
3652 struct fw_event_work *fw_event; in mpt3sas_port_enable_complete() local
3654 fw_event = alloc_fw_event_work(0); in mpt3sas_port_enable_complete()
3655 if (!fw_event) in mpt3sas_port_enable_complete()
3657 fw_event->event = MPT3SAS_PORT_ENABLE_COMPLETE; in mpt3sas_port_enable_complete()
3658 fw_event->ioc = ioc; in mpt3sas_port_enable_complete()
3659 _scsih_fw_event_add(ioc, fw_event); in mpt3sas_port_enable_complete()
3660 fw_event_work_put(fw_event); in mpt3sas_port_enable_complete()
3666 struct fw_event_work *fw_event = NULL; in dequeue_next_fw_event() local
3670 fw_event = list_first_entry(&ioc->fw_event_list, in dequeue_next_fw_event()
3672 list_del_init(&fw_event->list); in dequeue_next_fw_event()
3673 fw_event_work_put(fw_event); in dequeue_next_fw_event()
3677 return fw_event; in dequeue_next_fw_event()
3692 struct fw_event_work *fw_event; in _scsih_fw_event_cleanup_queue() local
3707 while ((fw_event = dequeue_next_fw_event(ioc)) || in _scsih_fw_event_cleanup_queue()
3708 (fw_event = ioc->current_event)) { in _scsih_fw_event_cleanup_queue()
3724 if (fw_event == ioc->current_event && in _scsih_fw_event_cleanup_queue()
3739 if (fw_event->event == MPT3SAS_PORT_ENABLE_COMPLETE) { in _scsih_fw_event_cleanup_queue()
3752 if (cancel_work_sync(&fw_event->work)) in _scsih_fw_event_cleanup_queue()
3753 fw_event_work_put(fw_event); in _scsih_fw_event_cleanup_queue()
4659 struct fw_event_work *fw_event; in _scsih_check_topo_delete_events() local
4704 list_for_each_entry(fw_event, &ioc->fw_event_list, list) { in _scsih_check_topo_delete_events()
4705 if (fw_event->event != MPI2_EVENT_SAS_TOPOLOGY_CHANGE_LIST || in _scsih_check_topo_delete_events()
4706 fw_event->ignore) in _scsih_check_topo_delete_events()
4709 fw_event->event_data; in _scsih_check_topo_delete_events()
4718 fw_event->ignore = 1; in _scsih_check_topo_delete_events()
4740 struct fw_event_work *fw_event; in _scsih_check_pcie_topo_remove_events() local
4775 list_for_each_entry(fw_event, &ioc->fw_event_list, list) { in _scsih_check_pcie_topo_remove_events()
4776 if (fw_event->event != MPI2_EVENT_PCIE_TOPOLOGY_CHANGE_LIST || in _scsih_check_pcie_topo_remove_events()
4777 fw_event->ignore) in _scsih_check_pcie_topo_remove_events()
4781 fw_event->event_data; in _scsih_check_pcie_topo_remove_events()
4790 fw_event->ignore = 1; in _scsih_check_pcie_topo_remove_events()
5610 struct fw_event_work *fw_event; in _scsih_send_event_to_turn_on_pfa_led() local
5612 fw_event = alloc_fw_event_work(0); in _scsih_send_event_to_turn_on_pfa_led()
5613 if (!fw_event) in _scsih_send_event_to_turn_on_pfa_led()
5615 fw_event->event = MPT3SAS_TURN_ON_PFA_LED; in _scsih_send_event_to_turn_on_pfa_led()
5616 fw_event->device_handle = handle; in _scsih_send_event_to_turn_on_pfa_led()
5617 fw_event->ioc = ioc; in _scsih_send_event_to_turn_on_pfa_led()
5618 _scsih_fw_event_add(ioc, fw_event); in _scsih_send_event_to_turn_on_pfa_led()
5619 fw_event_work_put(fw_event); in _scsih_send_event_to_turn_on_pfa_led()
7583 struct fw_event_work *fw_event) in _scsih_sas_topology_change_event() argument
7596 fw_event->event_data; in _scsih_sas_topology_change_event()
7609 if (fw_event->ignore) { in _scsih_sas_topology_change_event()
7640 if (fw_event->ignore) { in _scsih_sas_topology_change_event()
8332 struct fw_event_work *fw_event) in _scsih_pcie_topology_change_event() argument
8341 (Mpi26EventDataPCIeTopologyChangeList_t *) fw_event->event_data; in _scsih_pcie_topology_change_event()
8351 if (fw_event->ignore) { in _scsih_pcie_topology_change_event()
8358 if (fw_event->ignore) { in _scsih_pcie_topology_change_event()
8510 struct fw_event_work *fw_event) in _scsih_pcie_device_status_change_event() argument
8517 (Mpi26EventDataPCIeDeviceStatusChange_t *)fw_event->event_data; in _scsih_pcie_device_status_change_event()
8592 struct fw_event_work *fw_event) in _scsih_sas_enclosure_dev_status_change_event() argument
8597 (Mpi2EventDataSasEnclDevStatusChange_t *)fw_event->event_data; in _scsih_sas_enclosure_dev_status_change_event()
8604 fw_event->event_data); in _scsih_sas_enclosure_dev_status_change_event()
8657 struct fw_event_work *fw_event) in _scsih_sas_broadcast_primitive_event() argument
8670 fw_event->event_data; in _scsih_sas_broadcast_primitive_event()
8822 struct fw_event_work *fw_event) in _scsih_sas_discovery_event() argument
8825 (Mpi2EventDataSasDiscovery_t *) fw_event->event_data; in _scsih_sas_discovery_event()
8857 struct fw_event_work *fw_event) in _scsih_sas_device_discovery_error_event() argument
8860 (Mpi25EventDataSasDeviceDiscoveryError_t *)fw_event->event_data; in _scsih_sas_device_discovery_error_event()
8888 struct fw_event_work *fw_event) in _scsih_pcie_enumeration_event() argument
8891 (Mpi26EventDataPCIeEnumeration_t *)fw_event->event_data; in _scsih_pcie_enumeration_event()
9341 struct fw_event_work *fw_event) in _scsih_sas_ir_config_change_event() argument
9348 fw_event->event_data; in _scsih_sas_ir_config_change_event()
9411 struct fw_event_work *fw_event) in _scsih_sas_ir_volume_event() argument
9420 (Mpi2EventDataIrVolume_t *) fw_event->event_data; in _scsih_sas_ir_volume_event()
9492 struct fw_event_work *fw_event) in _scsih_sas_ir_physical_disk_event() argument
9501 (Mpi2EventDataIrPhysicalDisk_t *) fw_event->event_data; in _scsih_sas_ir_physical_disk_event()
9618 struct fw_event_work *fw_event) in _scsih_sas_ir_operation_status_event() argument
9622 fw_event->event_data; in _scsih_sas_ir_operation_status_event()
10720 _mpt3sas_fw_work(struct MPT3SAS_ADAPTER *ioc, struct fw_event_work *fw_event) in _mpt3sas_fw_work() argument
10722 ioc->current_event = fw_event; in _mpt3sas_fw_work()
10723 _scsih_fw_event_del_from_list(ioc, fw_event); in _mpt3sas_fw_work()
10727 fw_event_work_put(fw_event); in _mpt3sas_fw_work()
10732 switch (fw_event->event) { in _mpt3sas_fw_work()
10736 fw_event->event_data); in _mpt3sas_fw_work()
10778 _scsih_turn_on_pfa_led(ioc, fw_event->device_handle); in _mpt3sas_fw_work()
10781 _scsih_sas_topology_change_event(ioc, fw_event); in _mpt3sas_fw_work()
10787 fw_event->event_data); in _mpt3sas_fw_work()
10790 _scsih_sas_discovery_event(ioc, fw_event); in _mpt3sas_fw_work()
10793 _scsih_sas_device_discovery_error_event(ioc, fw_event); in _mpt3sas_fw_work()
10796 _scsih_sas_broadcast_primitive_event(ioc, fw_event); in _mpt3sas_fw_work()
10800 fw_event); in _mpt3sas_fw_work()
10803 _scsih_sas_ir_config_change_event(ioc, fw_event); in _mpt3sas_fw_work()
10806 _scsih_sas_ir_volume_event(ioc, fw_event); in _mpt3sas_fw_work()
10809 _scsih_sas_ir_physical_disk_event(ioc, fw_event); in _mpt3sas_fw_work()
10812 _scsih_sas_ir_operation_status_event(ioc, fw_event); in _mpt3sas_fw_work()
10815 _scsih_pcie_device_status_change_event(ioc, fw_event); in _mpt3sas_fw_work()
10818 _scsih_pcie_enumeration_event(ioc, fw_event); in _mpt3sas_fw_work()
10821 _scsih_pcie_topology_change_event(ioc, fw_event); in _mpt3sas_fw_work()
10826 fw_event_work_put(fw_event); in _mpt3sas_fw_work()
10841 struct fw_event_work *fw_event = container_of(work, in _firmware_event_work() local
10844 _mpt3sas_fw_work(fw_event->ioc, fw_event); in _firmware_event_work()
10864 struct fw_event_work *fw_event; in mpt3sas_scsih_event_callback() local
11020 fw_event = alloc_fw_event_work(sz); in mpt3sas_scsih_event_callback()
11021 if (!fw_event) { in mpt3sas_scsih_event_callback()
11027 memcpy(fw_event->event_data, mpi_reply->EventData, sz); in mpt3sas_scsih_event_callback()
11028 fw_event->ioc = ioc; in mpt3sas_scsih_event_callback()
11029 fw_event->VF_ID = mpi_reply->VF_ID; in mpt3sas_scsih_event_callback()
11030 fw_event->VP_ID = mpi_reply->VP_ID; in mpt3sas_scsih_event_callback()
11031 fw_event->event = event; in mpt3sas_scsih_event_callback()
11032 _scsih_fw_event_add(ioc, fw_event); in mpt3sas_scsih_event_callback()
11033 fw_event_work_put(fw_event); in mpt3sas_scsih_event_callback()