Lines Matching full:event
19 * struct brcmf_fweh_queue_item - event item on event queue.
22 * @code: event code.
23 * @ifidx: interface index related to this event.
25 * @emsg: common parameters of the firmware event message.
27 * @data: event specific data part of the firmware event.
51 /* array for mapping code to event name */
58 * brcmf_fweh_event_name() - returns name for given event code.
79 * brcmf_fweh_queue_event() - create and queue event.
81 * @fweh: firmware event handling info.
82 * @event: event queue entry.
85 struct brcmf_fweh_queue_item *event) in brcmf_fweh_queue_event() argument
90 list_add_tail(&event->q, &fweh->event_q); in brcmf_fweh_queue_event()
107 /* handle the event if valid interface and handler */ in brcmf_fweh_call_event_handler()
111 bphy_err(drvr, "unhandled event %d ignored\n", code); in brcmf_fweh_call_event_handler()
119 * brcmf_fweh_handle_if_event() - handle IF event.
122 * @emsg: event message object.
123 * @data: event object.
133 brcmf_dbg(EVENT, "action: %u ifidx: %u bsscfgidx: %u flags: %u role: %u\n", in brcmf_fweh_handle_if_event()
137 /* The P2P Device interface event must not be ignored contrary to what in brcmf_fweh_handle_if_event()
147 brcmf_dbg(EVENT, "event can be ignored\n"); in brcmf_fweh_handle_if_event()
158 brcmf_dbg(EVENT, "adding %s (%pM)\n", emsg->ifname, in brcmf_fweh_handle_if_event()
180 /* Default handling in case no-one waits for this event */ in brcmf_fweh_handle_if_event()
187 * brcmf_fweh_dequeue_event() - get event from the queue.
189 * @fweh: firmware event handling info.
194 struct brcmf_fweh_queue_item *event = NULL; in brcmf_fweh_dequeue_event() local
199 event = list_first_entry(&fweh->event_q, in brcmf_fweh_dequeue_event()
201 list_del(&event->q); in brcmf_fweh_dequeue_event()
205 return event; in brcmf_fweh_dequeue_event()
209 * brcmf_fweh_event_worker() - firmware event worker.
218 struct brcmf_fweh_queue_item *event; in brcmf_fweh_event_worker() local
226 while ((event = brcmf_fweh_dequeue_event(fweh))) { in brcmf_fweh_event_worker()
227 brcmf_dbg(EVENT, "event %s (%u) ifidx %u bsscfg %u addr %pM\n", in brcmf_fweh_event_worker()
228 brcmf_fweh_event_name(event->code), event->code, in brcmf_fweh_event_worker()
229 event->emsg.ifidx, event->emsg.bsscfgidx, in brcmf_fweh_event_worker()
230 event->emsg.addr); in brcmf_fweh_event_worker()
231 if (event->emsg.bsscfgidx >= BRCMF_MAX_IFS) { in brcmf_fweh_event_worker()
232 bphy_err(drvr, "invalid bsscfg index: %u\n", event->emsg.bsscfgidx); in brcmf_fweh_event_worker()
236 /* convert event message */ in brcmf_fweh_event_worker()
237 emsg_be = &event->emsg; in brcmf_fweh_event_worker()
240 emsg.event_code = event->code; in brcmf_fweh_event_worker()
250 brcmf_dbg(EVENT, " version %u flags %u status %u reason %u\n", in brcmf_fweh_event_worker()
252 brcmf_dbg_hex_dump(BRCMF_EVENT_ON(), event->data, in brcmf_fweh_event_worker()
254 "event payload, len=%d\n", emsg.datalen); in brcmf_fweh_event_worker()
256 /* special handling of interface event */ in brcmf_fweh_event_worker()
257 if (event->code == BRCMF_E_IF) { in brcmf_fweh_event_worker()
258 brcmf_fweh_handle_if_event(drvr, &emsg, event->data); in brcmf_fweh_event_worker()
262 if (event->code == BRCMF_E_TDLS_PEER_EVENT) in brcmf_fweh_event_worker()
266 err = brcmf_fweh_call_event_handler(drvr, ifp, event->code, in brcmf_fweh_event_worker()
267 &emsg, event->data); in brcmf_fweh_event_worker()
269 bphy_err(drvr, "event handler failed (%d)\n", in brcmf_fweh_event_worker()
270 event->code); in brcmf_fweh_event_worker()
274 kfree(event); in brcmf_fweh_event_worker()
290 * brcmf_fweh_attach() - initialize firmware event handling.
303 * brcmf_fweh_detach() - cleanup firmware event handling.
320 * brcmf_fweh_register() - register handler for given event code.
323 * @code: event code.
324 * @handler: handler for the given event code.
330 bphy_err(drvr, "event code %d already registered\n", code); in brcmf_fweh_register()
334 brcmf_dbg(TRACE, "event handler registered for %s\n", in brcmf_fweh_register()
343 * @code: event code.
348 brcmf_dbg(TRACE, "event handler cleared for %s\n", in brcmf_fweh_unregister()
367 brcmf_dbg(EVENT, "enable event %s\n", in brcmf_fweh_activate_events()
373 /* want to handle IF event as well */ in brcmf_fweh_activate_events()
374 brcmf_dbg(EVENT, "enable event IF\n"); in brcmf_fweh_activate_events()
386 * brcmf_fweh_process_event() - process skb as firmware event.
389 * @event_packet: event packet to process.
393 * If the packet buffer contains a firmware event message it will
394 * dispatch the event to a registered handler (using worker).
402 struct brcmf_fweh_queue_item *event; in brcmf_fweh_process_event() local
406 /* get event info */ in brcmf_fweh_process_event()
421 event = kzalloc(sizeof(*event) + datalen, gfp); in brcmf_fweh_process_event()
422 if (!event) in brcmf_fweh_process_event()
425 event->code = code; in brcmf_fweh_process_event()
426 event->ifidx = event_packet->msg.ifidx; in brcmf_fweh_process_event()
428 /* use memcpy to get aligned event message */ in brcmf_fweh_process_event()
429 memcpy(&event->emsg, &event_packet->msg, sizeof(event->emsg)); in brcmf_fweh_process_event()
430 memcpy(event->data, data, datalen); in brcmf_fweh_process_event()
431 event->datalen = datalen; in brcmf_fweh_process_event()
432 memcpy(event->ifaddr, event_packet->eth.h_dest, ETH_ALEN); in brcmf_fweh_process_event()
434 brcmf_fweh_queue_event(fweh, event); in brcmf_fweh_process_event()