diff options
author | Holger Schurig <hs4233@mail.mn-solutions.de> | 2009-10-16 11:33:23 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-10-27 16:48:29 -0400 |
commit | bca61f8a4df69949cc7426b39daa867f5274a9b8 (patch) | |
tree | d1a7759587dde147022fdf1cdf06654f7d94f957 | |
parent | 9e66e701d0e42efd548f0f7249af8a56f8e07b67 (diff) |
libertas: harmonize cmd.h
* move declarations for functions of cmd.c/cmdresp.c into cmd.h
* move declarations from cmd.h that are in main.c to decl.h
* group command functions
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>
-rw-r--r-- | drivers/net/wireless/libertas/11d.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/cmd.h | 120 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/cmdresp.c | 1 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/decl.h | 24 | ||||
-rw-r--r-- | drivers/net/wireless/libertas/host.h | 15 |
5 files changed, 96 insertions, 65 deletions
diff --git a/drivers/net/wireless/libertas/11d.c b/drivers/net/wireless/libertas/11d.c index 5c6968101f0d..93f2d5fb3920 100644 --- a/drivers/net/wireless/libertas/11d.c +++ b/drivers/net/wireless/libertas/11d.c | |||
@@ -6,6 +6,7 @@ | |||
6 | #include <linux/wireless.h> | 6 | #include <linux/wireless.h> |
7 | 7 | ||
8 | #include "host.h" | 8 | #include "host.h" |
9 | #include "cmd.h" | ||
9 | #include "decl.h" | 10 | #include "decl.h" |
10 | #include "11d.h" | 11 | #include "11d.h" |
11 | #include "dev.h" | 12 | #include "dev.h" |
diff --git a/drivers/net/wireless/libertas/cmd.h b/drivers/net/wireless/libertas/cmd.h index bf7c421c7a53..7c44cc94a25b 100644 --- a/drivers/net/wireless/libertas/cmd.h +++ b/drivers/net/wireless/libertas/cmd.h | |||
@@ -6,8 +6,27 @@ | |||
6 | #include "host.h" | 6 | #include "host.h" |
7 | #include "dev.h" | 7 | #include "dev.h" |
8 | 8 | ||
9 | |||
10 | /* Command & response transfer between host and card */ | ||
11 | |||
12 | struct cmd_ctrl_node { | ||
13 | struct list_head list; | ||
14 | int result; | ||
15 | /* command response */ | ||
16 | int (*callback)(struct lbs_private *, | ||
17 | unsigned long, | ||
18 | struct cmd_header *); | ||
19 | unsigned long callback_arg; | ||
20 | /* command data */ | ||
21 | struct cmd_header *cmdbuf; | ||
22 | /* wait queue */ | ||
23 | u16 cmdwaitqwoken; | ||
24 | wait_queue_head_t cmdwait_q; | ||
25 | }; | ||
26 | |||
27 | |||
9 | /* lbs_cmd() infers the size of the buffer to copy data back into, from | 28 | /* lbs_cmd() infers the size of the buffer to copy data back into, from |
10 | the size of the target of the pointer. Since the command to be sent | 29 | the size of the target of the pointer. Since the command to be sent |
11 | may often be smaller, that size is set in cmd->size by the caller.*/ | 30 | may often be smaller, that size is set in cmd->size by the caller.*/ |
12 | #define lbs_cmd(priv, cmdnr, cmd, cb, cb_arg) ({ \ | 31 | #define lbs_cmd(priv, cmdnr, cmd, cb, cb_arg) ({ \ |
13 | uint16_t __sz = le16_to_cpu((cmd)->hdr.size); \ | 32 | uint16_t __sz = le16_to_cpu((cmd)->hdr.size); \ |
@@ -18,6 +37,11 @@ | |||
18 | #define lbs_cmd_with_response(priv, cmdnr, cmd) \ | 37 | #define lbs_cmd_with_response(priv, cmdnr, cmd) \ |
19 | lbs_cmd(priv, cmdnr, cmd, lbs_cmd_copyback, (unsigned long) (cmd)) | 38 | lbs_cmd(priv, cmdnr, cmd, lbs_cmd_copyback, (unsigned long) (cmd)) |
20 | 39 | ||
40 | int lbs_prepare_and_send_command(struct lbs_private *priv, | ||
41 | u16 cmd_no, | ||
42 | u16 cmd_action, | ||
43 | u16 wait_option, u32 cmd_oid, void *pdata_buf); | ||
44 | |||
21 | void lbs_cmd_async(struct lbs_private *priv, uint16_t command, | 45 | void lbs_cmd_async(struct lbs_private *priv, uint16_t command, |
22 | struct cmd_header *in_cmd, int in_cmd_size); | 46 | struct cmd_header *in_cmd, int in_cmd_size); |
23 | 47 | ||
@@ -31,62 +55,102 @@ struct cmd_ctrl_node *__lbs_cmd_async(struct lbs_private *priv, | |||
31 | int (*callback)(struct lbs_private *, unsigned long, struct cmd_header *), | 55 | int (*callback)(struct lbs_private *, unsigned long, struct cmd_header *), |
32 | unsigned long callback_arg); | 56 | unsigned long callback_arg); |
33 | 57 | ||
34 | int lbs_set_power_adapt_cfg(struct lbs_private *priv, int enable, int8_t p0, | 58 | int lbs_cmd_copyback(struct lbs_private *priv, unsigned long extra, |
35 | int8_t p1, int8_t p2); | 59 | struct cmd_header *resp); |
36 | 60 | ||
37 | int lbs_set_tpc_cfg(struct lbs_private *priv, int enable, int8_t p0, int8_t p1, | 61 | int lbs_allocate_cmd_buffer(struct lbs_private *priv); |
38 | int8_t p2, int usesnr); | 62 | int lbs_free_cmd_buffer(struct lbs_private *priv); |
39 | 63 | ||
40 | int lbs_set_power_adapt_cfg(struct lbs_private *priv, int enable, int8_t p0, | 64 | int lbs_execute_next_command(struct lbs_private *priv); |
41 | int8_t p1, int8_t p2); | 65 | void lbs_complete_command(struct lbs_private *priv, struct cmd_ctrl_node *cmd, |
66 | int result); | ||
67 | int lbs_process_command_response(struct lbs_private *priv, u8 *data, u32 len); | ||
42 | 68 | ||
43 | int lbs_set_tpc_cfg(struct lbs_private *priv, int enable, int8_t p0, int8_t p1, | ||
44 | int8_t p2, int usesnr); | ||
45 | 69 | ||
46 | int lbs_cmd_copyback(struct lbs_private *priv, unsigned long extra, | 70 | /* From cmdresp.c */ |
47 | struct cmd_header *resp); | ||
48 | 71 | ||
49 | int lbs_update_hw_spec(struct lbs_private *priv); | 72 | void lbs_mac_event_disconnected(struct lbs_private *priv); |
50 | 73 | ||
51 | int lbs_mesh_access(struct lbs_private *priv, uint16_t cmd_action, | ||
52 | struct cmd_ds_mesh_access *cmd); | ||
53 | 74 | ||
54 | int lbs_set_data_rate(struct lbs_private *priv, u8 rate); | 75 | |
76 | /* Events */ | ||
77 | |||
78 | int lbs_process_event(struct lbs_private *priv, u32 event); | ||
79 | |||
80 | |||
81 | /* Actual commands */ | ||
82 | |||
83 | int lbs_update_hw_spec(struct lbs_private *priv); | ||
55 | 84 | ||
56 | int lbs_get_channel(struct lbs_private *priv); | 85 | int lbs_get_channel(struct lbs_private *priv); |
86 | |||
57 | int lbs_set_channel(struct lbs_private *priv, u8 channel); | 87 | int lbs_set_channel(struct lbs_private *priv, u8 channel); |
58 | 88 | ||
89 | int lbs_update_channel(struct lbs_private *priv); | ||
90 | |||
91 | int lbs_host_sleep_cfg(struct lbs_private *priv, uint32_t criteria, | ||
92 | struct wol_config *p_wol_config); | ||
93 | |||
94 | int lbs_cmd_802_11_sleep_params(struct lbs_private *priv, uint16_t cmd_action, | ||
95 | struct sleep_params *sp); | ||
96 | |||
97 | void lbs_ps_sleep(struct lbs_private *priv, int wait_option); | ||
98 | |||
99 | void lbs_ps_wakeup(struct lbs_private *priv, int wait_option); | ||
100 | |||
101 | void lbs_ps_confirm_sleep(struct lbs_private *priv); | ||
102 | |||
103 | int lbs_set_radio(struct lbs_private *priv, u8 preamble, u8 radio_on); | ||
104 | |||
105 | void lbs_set_mac_control(struct lbs_private *priv); | ||
106 | |||
107 | int lbs_get_tx_power(struct lbs_private *priv, s16 *curlevel, s16 *minlevel, | ||
108 | s16 *maxlevel); | ||
109 | |||
110 | int lbs_set_snmp_mib(struct lbs_private *priv, u32 oid, u16 val); | ||
111 | |||
112 | int lbs_get_snmp_mib(struct lbs_private *priv, u32 oid, u16 *out_val); | ||
113 | |||
114 | |||
115 | /* Mesh related */ | ||
116 | |||
117 | int lbs_mesh_access(struct lbs_private *priv, uint16_t cmd_action, | ||
118 | struct cmd_ds_mesh_access *cmd); | ||
119 | |||
59 | int lbs_mesh_config_send(struct lbs_private *priv, | 120 | int lbs_mesh_config_send(struct lbs_private *priv, |
60 | struct cmd_ds_mesh_config *cmd, | 121 | struct cmd_ds_mesh_config *cmd, |
61 | uint16_t action, uint16_t type); | 122 | uint16_t action, uint16_t type); |
123 | |||
62 | int lbs_mesh_config(struct lbs_private *priv, uint16_t enable, uint16_t chan); | 124 | int lbs_mesh_config(struct lbs_private *priv, uint16_t enable, uint16_t chan); |
63 | 125 | ||
64 | int lbs_host_sleep_cfg(struct lbs_private *priv, uint32_t criteria, | 126 | |
65 | struct wol_config *p_wol_config); | 127 | /* Commands only used in wext.c, assoc. and scan.c */ |
66 | int lbs_suspend(struct lbs_private *priv); | 128 | |
67 | void lbs_resume(struct lbs_private *priv); | 129 | int lbs_set_power_adapt_cfg(struct lbs_private *priv, int enable, int8_t p0, |
130 | int8_t p1, int8_t p2); | ||
131 | |||
132 | int lbs_set_tpc_cfg(struct lbs_private *priv, int enable, int8_t p0, int8_t p1, | ||
133 | int8_t p2, int usesnr); | ||
134 | |||
135 | int lbs_set_data_rate(struct lbs_private *priv, u8 rate); | ||
68 | 136 | ||
69 | int lbs_cmd_802_11_rate_adapt_rateset(struct lbs_private *priv, | 137 | int lbs_cmd_802_11_rate_adapt_rateset(struct lbs_private *priv, |
70 | uint16_t cmd_action); | 138 | uint16_t cmd_action); |
139 | |||
71 | int lbs_cmd_802_11_inactivity_timeout(struct lbs_private *priv, | 140 | int lbs_cmd_802_11_inactivity_timeout(struct lbs_private *priv, |
72 | uint16_t cmd_action, uint16_t *timeout); | 141 | uint16_t cmd_action, uint16_t *timeout); |
73 | int lbs_cmd_802_11_sleep_params(struct lbs_private *priv, uint16_t cmd_action, | 142 | |
74 | struct sleep_params *sp); | ||
75 | int lbs_cmd_802_11_set_wep(struct lbs_private *priv, uint16_t cmd_action, | 143 | int lbs_cmd_802_11_set_wep(struct lbs_private *priv, uint16_t cmd_action, |
76 | struct assoc_request *assoc); | 144 | struct assoc_request *assoc); |
145 | |||
77 | int lbs_cmd_802_11_enable_rsn(struct lbs_private *priv, uint16_t cmd_action, | 146 | int lbs_cmd_802_11_enable_rsn(struct lbs_private *priv, uint16_t cmd_action, |
78 | uint16_t *enable); | 147 | uint16_t *enable); |
148 | |||
79 | int lbs_cmd_802_11_key_material(struct lbs_private *priv, uint16_t cmd_action, | 149 | int lbs_cmd_802_11_key_material(struct lbs_private *priv, uint16_t cmd_action, |
80 | struct assoc_request *assoc); | 150 | struct assoc_request *assoc); |
81 | 151 | ||
82 | int lbs_get_tx_power(struct lbs_private *priv, s16 *curlevel, s16 *minlevel, | ||
83 | s16 *maxlevel); | ||
84 | int lbs_set_tx_power(struct lbs_private *priv, s16 dbm); | 152 | int lbs_set_tx_power(struct lbs_private *priv, s16 dbm); |
85 | 153 | ||
86 | int lbs_set_radio(struct lbs_private *priv, u8 preamble, u8 radio_on); | 154 | int lbs_set_deep_sleep(struct lbs_private *priv, int deep_sleep); |
87 | |||
88 | int lbs_set_snmp_mib(struct lbs_private *priv, u32 oid, u16 val); | ||
89 | |||
90 | int lbs_get_snmp_mib(struct lbs_private *priv, u32 oid, u16 *out_val); | ||
91 | 155 | ||
92 | #endif /* _LBS_CMD_H */ | 156 | #endif /* _LBS_CMD_H */ |
diff --git a/drivers/net/wireless/libertas/cmdresp.c b/drivers/net/wireless/libertas/cmdresp.c index 9ee8bd11bda9..a45061b1f33c 100644 --- a/drivers/net/wireless/libertas/cmdresp.c +++ b/drivers/net/wireless/libertas/cmdresp.c | |||
@@ -11,6 +11,7 @@ | |||
11 | 11 | ||
12 | #include "host.h" | 12 | #include "host.h" |
13 | #include "decl.h" | 13 | #include "decl.h" |
14 | #include "cmd.h" | ||
14 | #include "defs.h" | 15 | #include "defs.h" |
15 | #include "dev.h" | 16 | #include "dev.h" |
16 | #include "assoc.h" | 17 | #include "assoc.h" |
diff --git a/drivers/net/wireless/libertas/decl.h b/drivers/net/wireless/libertas/decl.h index fb91c3639fc1..20fa8176cd88 100644 --- a/drivers/net/wireless/libertas/decl.h +++ b/drivers/net/wireless/libertas/decl.h | |||
@@ -17,23 +17,13 @@ struct net_device; | |||
17 | struct cmd_ctrl_node; | 17 | struct cmd_ctrl_node; |
18 | struct cmd_ds_command; | 18 | struct cmd_ds_command; |
19 | 19 | ||
20 | void lbs_set_mac_control(struct lbs_private *priv); | 20 | int lbs_suspend(struct lbs_private *priv); |
21 | void lbs_resume(struct lbs_private *priv); | ||
21 | 22 | ||
22 | void lbs_send_tx_feedback(struct lbs_private *priv, u32 try_count); | 23 | void lbs_send_tx_feedback(struct lbs_private *priv, u32 try_count); |
23 | 24 | ||
24 | int lbs_free_cmd_buffer(struct lbs_private *priv); | ||
25 | |||
26 | int lbs_prepare_and_send_command(struct lbs_private *priv, | ||
27 | u16 cmd_no, | ||
28 | u16 cmd_action, | ||
29 | u16 wait_option, u32 cmd_oid, void *pdata_buf); | ||
30 | |||
31 | int lbs_allocate_cmd_buffer(struct lbs_private *priv); | ||
32 | int lbs_execute_next_command(struct lbs_private *priv); | ||
33 | int lbs_process_event(struct lbs_private *priv, u32 event); | ||
34 | void lbs_queue_event(struct lbs_private *priv, u32 event); | 25 | void lbs_queue_event(struct lbs_private *priv, u32 event); |
35 | void lbs_notify_command_response(struct lbs_private *priv, u8 resp_idx); | 26 | void lbs_notify_command_response(struct lbs_private *priv, u8 resp_idx); |
36 | int lbs_set_deep_sleep(struct lbs_private *priv, int deep_sleep); | ||
37 | int lbs_enter_auto_deep_sleep(struct lbs_private *priv); | 27 | int lbs_enter_auto_deep_sleep(struct lbs_private *priv); |
38 | int lbs_exit_auto_deep_sleep(struct lbs_private *priv); | 28 | int lbs_exit_auto_deep_sleep(struct lbs_private *priv); |
39 | 29 | ||
@@ -41,26 +31,17 @@ u32 lbs_fw_index_to_data_rate(u8 index); | |||
41 | u8 lbs_data_rate_to_fw_index(u32 rate); | 31 | u8 lbs_data_rate_to_fw_index(u32 rate); |
42 | 32 | ||
43 | /** The proc fs interface */ | 33 | /** The proc fs interface */ |
44 | int lbs_process_command_response(struct lbs_private *priv, u8 *data, u32 len); | ||
45 | void lbs_complete_command(struct lbs_private *priv, struct cmd_ctrl_node *cmd, | ||
46 | int result); | ||
47 | netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, | 34 | netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, |
48 | struct net_device *dev); | 35 | struct net_device *dev); |
49 | int lbs_set_regiontable(struct lbs_private *priv, u8 region, u8 band); | 36 | int lbs_set_regiontable(struct lbs_private *priv, u8 region, u8 band); |
50 | 37 | ||
51 | int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *); | 38 | int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *); |
52 | 39 | ||
53 | void lbs_ps_sleep(struct lbs_private *priv, int wait_option); | ||
54 | void lbs_ps_confirm_sleep(struct lbs_private *priv); | ||
55 | void lbs_ps_wakeup(struct lbs_private *priv, int wait_option); | ||
56 | |||
57 | struct chan_freq_power *lbs_find_cfp_by_band_and_channel( | 40 | struct chan_freq_power *lbs_find_cfp_by_band_and_channel( |
58 | struct lbs_private *priv, | 41 | struct lbs_private *priv, |
59 | u8 band, | 42 | u8 band, |
60 | u16 channel); | 43 | u16 channel); |
61 | 44 | ||
62 | void lbs_mac_event_disconnected(struct lbs_private *priv); | ||
63 | |||
64 | void lbs_send_iwevcustom_event(struct lbs_private *priv, s8 *str); | 45 | void lbs_send_iwevcustom_event(struct lbs_private *priv, s8 *str); |
65 | 46 | ||
66 | /* persistcfg.c */ | 47 | /* persistcfg.c */ |
@@ -76,6 +57,5 @@ int lbs_start_card(struct lbs_private *priv); | |||
76 | void lbs_stop_card(struct lbs_private *priv); | 57 | void lbs_stop_card(struct lbs_private *priv); |
77 | void lbs_host_to_card_done(struct lbs_private *priv); | 58 | void lbs_host_to_card_done(struct lbs_private *priv); |
78 | 59 | ||
79 | int lbs_update_channel(struct lbs_private *priv); | ||
80 | 60 | ||
81 | #endif | 61 | #endif |
diff --git a/drivers/net/wireless/libertas/host.h b/drivers/net/wireless/libertas/host.h index 45cd7f1e5937..5188e6539c6c 100644 --- a/drivers/net/wireless/libertas/host.h +++ b/drivers/net/wireless/libertas/host.h | |||
@@ -374,21 +374,6 @@ struct cmd_header { | |||
374 | __le16 result; | 374 | __le16 result; |
375 | } __attribute__ ((packed)); | 375 | } __attribute__ ((packed)); |
376 | 376 | ||
377 | struct cmd_ctrl_node { | ||
378 | struct list_head list; | ||
379 | int result; | ||
380 | /* command response */ | ||
381 | int (*callback)(struct lbs_private *, | ||
382 | unsigned long, | ||
383 | struct cmd_header *); | ||
384 | unsigned long callback_arg; | ||
385 | /* command data */ | ||
386 | struct cmd_header *cmdbuf; | ||
387 | /* wait queue */ | ||
388 | u16 cmdwaitqwoken; | ||
389 | wait_queue_head_t cmdwait_q; | ||
390 | }; | ||
391 | |||
392 | /* Generic structure to hold all key types. */ | 377 | /* Generic structure to hold all key types. */ |
393 | struct enc_key { | 378 | struct enc_key { |
394 | u16 len; | 379 | u16 len; |