diff options
author | Holger Schurig <hs4233@mail.mn-solutions.de> | 2007-11-26 04:07:14 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:04:55 -0500 |
commit | 3a1886491710c196656a005fcc693172f5bb4c8a (patch) | |
tree | c33009fb8cacd0fdea6fe7b7fdb7b5269c3063e4 /drivers/net/wireless/libertas/cmdresp.c | |
parent | 69f9032d9dfeb763b467fdbe8cf5938f5457083a (diff) |
libertas: rework event subscription
This patch moves re-works the implementation of event subscription
via debugfs. For this:
* it tells cmd.c and cmdresp.c about CMD_802_11_SUBSCRIBE_EVENT
* removes lots of low-level cmd stuff from debugfs.c
* create unified functions to read/write snr, rssi, bcnmiss and
failcount
* introduces #define's for subscription event bitmask values
* add a function to search for a specific element in an IE
(a.k.a. TLV)
* add a function to find out the size of the TLV. This is needed
because lbs_prepare_and_send_command() has an argument for a
data buffer, but not for it's lengths and TLVs can be, by
definition, vary in size.
* fix a bug where it was not possible to disable an event
Signed-off-by: Holger Schurig <hs4233@mail.mn-solutions.de>
Acked-by: Dan Williams <dcbw@redhat.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/libertas/cmdresp.c')
-rw-r--r-- | drivers/net/wireless/libertas/cmdresp.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/drivers/net/wireless/libertas/cmdresp.c b/drivers/net/wireless/libertas/cmdresp.c index 3596957f1d5a..87b5bd2988e7 100644 --- a/drivers/net/wireless/libertas/cmdresp.c +++ b/drivers/net/wireless/libertas/cmdresp.c | |||
@@ -554,6 +554,26 @@ static int lbs_ret_802_11_bcn_ctrl(struct lbs_private * priv, | |||
554 | return 0; | 554 | return 0; |
555 | } | 555 | } |
556 | 556 | ||
557 | static int lbs_ret_802_11_subscribe_event(struct lbs_private *priv, | ||
558 | struct cmd_ds_command *resp) | ||
559 | { | ||
560 | struct lbs_adapter *adapter = priv->adapter; | ||
561 | struct cmd_ds_802_11_subscribe_event *cmd_event = | ||
562 | &resp->params.subscribe_event; | ||
563 | struct cmd_ds_802_11_subscribe_event *dst_event = | ||
564 | adapter->cur_cmd->pdata_buf; | ||
565 | |||
566 | lbs_deb_enter(LBS_DEB_CMD); | ||
567 | |||
568 | if (dst_event->action == cpu_to_le16(CMD_ACT_GET)) { | ||
569 | dst_event->events = le16_to_cpu(cmd_event->events); | ||
570 | memcpy(dst_event->tlv, cmd_event->tlv, sizeof(dst_event->tlv)); | ||
571 | } | ||
572 | |||
573 | lbs_deb_leave(LBS_DEB_CMD); | ||
574 | return 0; | ||
575 | } | ||
576 | |||
557 | static inline int handle_cmd_response(u16 respcmd, | 577 | static inline int handle_cmd_response(u16 respcmd, |
558 | struct cmd_ds_command *resp, | 578 | struct cmd_ds_command *resp, |
559 | struct lbs_private *priv) | 579 | struct lbs_private *priv) |
@@ -689,6 +709,10 @@ static inline int handle_cmd_response(u16 respcmd, | |||
689 | sizeof(struct cmd_ds_802_11_led_ctrl)); | 709 | sizeof(struct cmd_ds_802_11_led_ctrl)); |
690 | spin_unlock_irqrestore(&adapter->driver_lock, flags); | 710 | spin_unlock_irqrestore(&adapter->driver_lock, flags); |
691 | break; | 711 | break; |
712 | case CMD_RET(CMD_802_11_SUBSCRIBE_EVENT): | ||
713 | ret = lbs_ret_802_11_subscribe_event(priv, resp); | ||
714 | break; | ||
715 | |||
692 | case CMD_RET(CMD_802_11_PWR_CFG): | 716 | case CMD_RET(CMD_802_11_PWR_CFG): |
693 | spin_lock_irqsave(&adapter->driver_lock, flags); | 717 | spin_lock_irqsave(&adapter->driver_lock, flags); |
694 | memmove(adapter->cur_cmd->pdata_buf, &resp->params.pwrcfg, | 718 | memmove(adapter->cur_cmd->pdata_buf, &resp->params.pwrcfg, |