Lines Matching refs:fw_event
107 static void mptsas_send_sas_event(struct fw_event_work *fw_event);
108 static void mptsas_send_raid_event(struct fw_event_work *fw_event);
109 static void mptsas_send_ir2_event(struct fw_event_work *fw_event);
124 static void mptsas_send_link_status_event(struct fw_event_work *fw_event);
129 static void mptsas_send_expander_event(struct fw_event_work *fw_event);
132 static void mptsas_broadcast_primitive_work(struct fw_event_work *fw_event);
133 static void mptsas_handle_queue_full_event(struct fw_event_work *fw_event);
285 mptsas_add_fw_event(MPT_ADAPTER *ioc, struct fw_event_work *fw_event, in mptsas_add_fw_event() argument
291 list_add_tail(&fw_event->list, &ioc->fw_event_list); in mptsas_add_fw_event()
292 INIT_DELAYED_WORK(&fw_event->work, mptsas_firmware_event_work); in mptsas_add_fw_event()
295 fw_event, smp_processor_id())); in mptsas_add_fw_event()
297 &fw_event->work, delay); in mptsas_add_fw_event()
303 mptsas_requeue_fw_event(MPT_ADAPTER *ioc, struct fw_event_work *fw_event, in mptsas_requeue_fw_event() argument
310 fw_event, smp_processor_id())); in mptsas_requeue_fw_event()
311 fw_event->retries++; in mptsas_requeue_fw_event()
313 &fw_event->work, msecs_to_jiffies(delay)); in mptsas_requeue_fw_event()
319 mptsas_free_fw_event(MPT_ADAPTER *ioc, struct fw_event_work *fw_event) in mptsas_free_fw_event() argument
325 ioc->name, __func__, fw_event)); in mptsas_free_fw_event()
326 list_del(&fw_event->list); in mptsas_free_fw_event()
327 kfree(fw_event); in mptsas_free_fw_event()
336 struct fw_event_work *fw_event, *next; in mptsas_cleanup_fw_event_q() local
357 list_for_each_entry_safe(fw_event, next, &ioc->fw_event_list, list) { in mptsas_cleanup_fw_event_q()
358 if (cancel_delayed_work(&fw_event->work)) in mptsas_cleanup_fw_event_q()
359 mptsas_free_fw_event(ioc, fw_event); in mptsas_cleanup_fw_event_q()
992 struct fw_event_work *fw_event; in mptsas_queue_device_delete() local
994 fw_event = kzalloc(sizeof(*fw_event) + in mptsas_queue_device_delete()
997 if (!fw_event) { in mptsas_queue_device_delete()
1002 memcpy(fw_event->event_data, sas_event_data, in mptsas_queue_device_delete()
1004 fw_event->event = MPI_EVENT_SAS_DEVICE_STATUS_CHANGE; in mptsas_queue_device_delete()
1005 fw_event->ioc = ioc; in mptsas_queue_device_delete()
1006 mptsas_add_fw_event(ioc, fw_event, msecs_to_jiffies(1)); in mptsas_queue_device_delete()
1012 struct fw_event_work *fw_event; in mptsas_queue_rescan() local
1014 fw_event = kzalloc(sizeof(*fw_event), GFP_ATOMIC); in mptsas_queue_rescan()
1015 if (!fw_event) { in mptsas_queue_rescan()
1020 fw_event->event = -1; in mptsas_queue_rescan()
1021 fw_event->ioc = ioc; in mptsas_queue_rescan()
1022 mptsas_add_fw_event(ioc, fw_event, msecs_to_jiffies(1)); in mptsas_queue_rescan()
1619 struct fw_event_work *fw_event = in mptsas_firmware_event_work() local
1621 MPT_ADAPTER *ioc = fw_event->ioc; in mptsas_firmware_event_work()
1624 if (fw_event->event == -1) { in mptsas_firmware_event_work()
1637 mptsas_free_fw_event(ioc, fw_event); in mptsas_firmware_event_work()
1644 mptsas_free_fw_event(ioc, fw_event); in mptsas_firmware_event_work()
1649 "event = (0x%02x)\n", ioc->name, __func__, fw_event, in mptsas_firmware_event_work()
1650 (fw_event->event & 0xFF))); in mptsas_firmware_event_work()
1652 switch (fw_event->event) { in mptsas_firmware_event_work()
1654 mptsas_send_sas_event(fw_event); in mptsas_firmware_event_work()
1657 mptsas_send_raid_event(fw_event); in mptsas_firmware_event_work()
1660 mptsas_send_ir2_event(fw_event); in mptsas_firmware_event_work()
1665 mptsas_free_fw_event(ioc, fw_event); in mptsas_firmware_event_work()
1668 mptsas_broadcast_primitive_work(fw_event); in mptsas_firmware_event_work()
1671 mptsas_send_expander_event(fw_event); in mptsas_firmware_event_work()
1674 mptsas_send_link_status_event(fw_event); in mptsas_firmware_event_work()
1677 mptsas_handle_queue_full_event(fw_event); in mptsas_firmware_event_work()
3601 mptsas_send_expander_event(struct fw_event_work *fw_event) in mptsas_send_expander_event() argument
3609 ioc = fw_event->ioc; in mptsas_send_expander_event()
3611 fw_event->event_data; in mptsas_send_expander_event()
3634 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_expander_event()
3677 mptsas_send_link_status_event(struct fw_event_work *fw_event) in mptsas_send_link_status_event() argument
3687 ioc = fw_event->ioc; in mptsas_send_link_status_event()
3688 link_data = (MpiEventDataSasPhyLinkStatus_t *)fw_event->event_data; in mptsas_send_link_status_event()
3766 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_link_status_event()
4020 mptsas_handle_queue_full_event(struct fw_event_work *fw_event) in mptsas_handle_queue_full_event() argument
4033 ioc = fw_event->ioc; in mptsas_handle_queue_full_event()
4034 qfull_data = (EventDataQueueFull_t *)fw_event->event_data; in mptsas_handle_queue_full_event()
4103 mptsas_free_fw_event(ioc, fw_event); in mptsas_handle_queue_full_event()
4301 mptsas_hotplug_work(MPT_ADAPTER *ioc, struct fw_event_work *fw_event, in mptsas_hotplug_work() argument
4324 mptsas_free_fw_event(ioc, fw_event); in mptsas_hotplug_work()
4561 mptsas_free_fw_event(ioc, fw_event); in mptsas_hotplug_work()
4565 mptsas_send_sas_event(struct fw_event_work *fw_event) in mptsas_send_sas_event() argument
4573 ioc = fw_event->ioc; in mptsas_send_sas_event()
4575 fw_event->event_data; in mptsas_send_sas_event()
4582 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4590 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4611 mptsas_hotplug_work(ioc, fw_event, &hot_plug_info); in mptsas_send_sas_event()
4617 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4625 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4631 mptsas_send_raid_event(struct fw_event_work *fw_event) in mptsas_send_raid_event() argument
4642 ioc = fw_event->ioc; in mptsas_send_raid_event()
4643 raid_event_data = (EVENT_DATA_RAID *)fw_event->event_data; in mptsas_send_raid_event()
4741 mptsas_hotplug_work(ioc, fw_event, &hot_plug_info); in mptsas_send_raid_event()
4743 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_raid_event()
4834 mptsas_broadcast_primitive_work(struct fw_event_work *fw_event) in mptsas_broadcast_primitive_work() argument
4836 MPT_ADAPTER *ioc = fw_event->ioc; in mptsas_broadcast_primitive_work()
4855 mptsas_requeue_fw_event(ioc, fw_event, 1000); in mptsas_broadcast_primitive_work()
4920 mptsas_free_fw_event(ioc, fw_event); in mptsas_broadcast_primitive_work()
4932 mptsas_send_ir2_event(struct fw_event_work *fw_event) in mptsas_send_ir2_event() argument
4940 ioc = fw_event->ioc; in mptsas_send_ir2_event()
4941 ir2_data = (MPI_EVENT_DATA_IR2 *)fw_event->event_data; in mptsas_send_ir2_event()
4966 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_ir2_event()
4969 mptsas_hotplug_work(ioc, fw_event, &hot_plug_info); in mptsas_send_ir2_event()
4977 struct fw_event_work *fw_event; in mptsas_event_process() local
5086 fw_event = kzalloc(sizeof(*fw_event) + event_data_sz, GFP_ATOMIC); in mptsas_event_process()
5087 if (!fw_event) { in mptsas_event_process()
5092 memcpy(fw_event->event_data, reply->Data, event_data_sz); in mptsas_event_process()
5093 fw_event->event = event; in mptsas_event_process()
5094 fw_event->ioc = ioc; in mptsas_event_process()
5095 mptsas_add_fw_event(ioc, fw_event, delay); in mptsas_event_process()