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_primative_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()
1620 struct fw_event_work *fw_event = in mptsas_firmware_event_work() local
1622 MPT_ADAPTER *ioc = fw_event->ioc; in mptsas_firmware_event_work()
1625 if (fw_event->event == -1) { in mptsas_firmware_event_work()
1638 mptsas_free_fw_event(ioc, fw_event); in mptsas_firmware_event_work()
1645 mptsas_free_fw_event(ioc, fw_event); in mptsas_firmware_event_work()
1650 "event = (0x%02x)\n", ioc->name, __func__, fw_event, in mptsas_firmware_event_work()
1651 (fw_event->event & 0xFF))); in mptsas_firmware_event_work()
1653 switch (fw_event->event) { in mptsas_firmware_event_work()
1655 mptsas_send_sas_event(fw_event); in mptsas_firmware_event_work()
1658 mptsas_send_raid_event(fw_event); in mptsas_firmware_event_work()
1661 mptsas_send_ir2_event(fw_event); in mptsas_firmware_event_work()
1666 mptsas_free_fw_event(ioc, fw_event); in mptsas_firmware_event_work()
1669 mptsas_broadcast_primative_work(fw_event); in mptsas_firmware_event_work()
1672 mptsas_send_expander_event(fw_event); in mptsas_firmware_event_work()
1675 mptsas_send_link_status_event(fw_event); in mptsas_firmware_event_work()
1678 mptsas_handle_queue_full_event(fw_event); in mptsas_firmware_event_work()
3603 mptsas_send_expander_event(struct fw_event_work *fw_event) in mptsas_send_expander_event() argument
3611 ioc = fw_event->ioc; in mptsas_send_expander_event()
3613 fw_event->event_data; in mptsas_send_expander_event()
3636 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_expander_event()
3679 mptsas_send_link_status_event(struct fw_event_work *fw_event) in mptsas_send_link_status_event() argument
3689 ioc = fw_event->ioc; in mptsas_send_link_status_event()
3690 link_data = (MpiEventDataSasPhyLinkStatus_t *)fw_event->event_data; in mptsas_send_link_status_event()
3768 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_link_status_event()
4022 mptsas_handle_queue_full_event(struct fw_event_work *fw_event) in mptsas_handle_queue_full_event() argument
4035 ioc = fw_event->ioc; in mptsas_handle_queue_full_event()
4036 qfull_data = (EventDataQueueFull_t *)fw_event->event_data; in mptsas_handle_queue_full_event()
4105 mptsas_free_fw_event(ioc, fw_event); in mptsas_handle_queue_full_event()
4303 mptsas_hotplug_work(MPT_ADAPTER *ioc, struct fw_event_work *fw_event, in mptsas_hotplug_work() argument
4326 mptsas_free_fw_event(ioc, fw_event); in mptsas_hotplug_work()
4562 mptsas_free_fw_event(ioc, fw_event); in mptsas_hotplug_work()
4566 mptsas_send_sas_event(struct fw_event_work *fw_event) in mptsas_send_sas_event() argument
4574 ioc = fw_event->ioc; in mptsas_send_sas_event()
4576 fw_event->event_data; in mptsas_send_sas_event()
4583 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4591 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4612 mptsas_hotplug_work(ioc, fw_event, &hot_plug_info); in mptsas_send_sas_event()
4618 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4626 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_sas_event()
4632 mptsas_send_raid_event(struct fw_event_work *fw_event) in mptsas_send_raid_event() argument
4643 ioc = fw_event->ioc; in mptsas_send_raid_event()
4644 raid_event_data = (EVENT_DATA_RAID *)fw_event->event_data; in mptsas_send_raid_event()
4742 mptsas_hotplug_work(ioc, fw_event, &hot_plug_info); in mptsas_send_raid_event()
4744 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_raid_event()
4835 mptsas_broadcast_primative_work(struct fw_event_work *fw_event) in mptsas_broadcast_primative_work() argument
4837 MPT_ADAPTER *ioc = fw_event->ioc; in mptsas_broadcast_primative_work()
4856 mptsas_requeue_fw_event(ioc, fw_event, 1000); in mptsas_broadcast_primative_work()
4921 mptsas_free_fw_event(ioc, fw_event); in mptsas_broadcast_primative_work()
4933 mptsas_send_ir2_event(struct fw_event_work *fw_event) in mptsas_send_ir2_event() argument
4941 ioc = fw_event->ioc; in mptsas_send_ir2_event()
4942 ir2_data = (MPI_EVENT_DATA_IR2 *)fw_event->event_data; in mptsas_send_ir2_event()
4967 mptsas_free_fw_event(ioc, fw_event); in mptsas_send_ir2_event()
4970 mptsas_hotplug_work(ioc, fw_event, &hot_plug_info); in mptsas_send_ir2_event()
4978 struct fw_event_work *fw_event; in mptsas_event_process() local
5087 fw_event = kzalloc(sizeof(*fw_event) + event_data_sz, GFP_ATOMIC); in mptsas_event_process()
5088 if (!fw_event) { in mptsas_event_process()
5093 memcpy(fw_event->event_data, reply->Data, event_data_sz); in mptsas_event_process()
5094 fw_event->event = event; in mptsas_event_process()
5095 fw_event->ioc = ioc; in mptsas_event_process()
5096 mptsas_add_fw_event(ioc, fw_event, delay); in mptsas_event_process()