diff options
Diffstat (limited to 'drivers/net/wireless/iwlwifi')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn-rxon.c | 72 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn.h | 2 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-core.c | 71 | ||||
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-core.h | 2 |
4 files changed, 74 insertions, 73 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-rxon.c b/drivers/net/wireless/iwlwifi/iwl-agn-rxon.c index fd091812af53..994fb21a0a87 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn-rxon.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn-rxon.c | |||
@@ -32,6 +32,78 @@ | |||
32 | #include "iwl-trans.h" | 32 | #include "iwl-trans.h" |
33 | #include "iwl-shared.h" | 33 | #include "iwl-shared.h" |
34 | 34 | ||
35 | /* | ||
36 | * initialize rxon structure with default values from eeprom | ||
37 | */ | ||
38 | void iwl_connection_init_rx_config(struct iwl_priv *priv, | ||
39 | struct iwl_rxon_context *ctx) | ||
40 | { | ||
41 | const struct iwl_channel_info *ch_info; | ||
42 | |||
43 | memset(&ctx->staging, 0, sizeof(ctx->staging)); | ||
44 | |||
45 | if (!ctx->vif) { | ||
46 | ctx->staging.dev_type = ctx->unused_devtype; | ||
47 | } else | ||
48 | switch (ctx->vif->type) { | ||
49 | case NL80211_IFTYPE_AP: | ||
50 | ctx->staging.dev_type = ctx->ap_devtype; | ||
51 | break; | ||
52 | |||
53 | case NL80211_IFTYPE_STATION: | ||
54 | ctx->staging.dev_type = ctx->station_devtype; | ||
55 | ctx->staging.filter_flags = RXON_FILTER_ACCEPT_GRP_MSK; | ||
56 | break; | ||
57 | |||
58 | case NL80211_IFTYPE_ADHOC: | ||
59 | ctx->staging.dev_type = ctx->ibss_devtype; | ||
60 | ctx->staging.flags = RXON_FLG_SHORT_PREAMBLE_MSK; | ||
61 | ctx->staging.filter_flags = RXON_FILTER_BCON_AWARE_MSK | | ||
62 | RXON_FILTER_ACCEPT_GRP_MSK; | ||
63 | break; | ||
64 | |||
65 | default: | ||
66 | IWL_ERR(priv, "Unsupported interface type %d\n", | ||
67 | ctx->vif->type); | ||
68 | break; | ||
69 | } | ||
70 | |||
71 | #if 0 | ||
72 | /* TODO: Figure out when short_preamble would be set and cache from | ||
73 | * that */ | ||
74 | if (!hw_to_local(priv->hw)->short_preamble) | ||
75 | ctx->staging.flags &= ~RXON_FLG_SHORT_PREAMBLE_MSK; | ||
76 | else | ||
77 | ctx->staging.flags |= RXON_FLG_SHORT_PREAMBLE_MSK; | ||
78 | #endif | ||
79 | |||
80 | ch_info = iwl_get_channel_info(priv, priv->band, | ||
81 | le16_to_cpu(ctx->active.channel)); | ||
82 | |||
83 | if (!ch_info) | ||
84 | ch_info = &priv->channel_info[0]; | ||
85 | |||
86 | ctx->staging.channel = cpu_to_le16(ch_info->channel); | ||
87 | priv->band = ch_info->band; | ||
88 | |||
89 | iwl_set_flags_for_band(priv, ctx, priv->band, ctx->vif); | ||
90 | |||
91 | ctx->staging.ofdm_basic_rates = | ||
92 | (IWL_OFDM_RATES_MASK >> IWL_FIRST_OFDM_RATE) & 0xFF; | ||
93 | ctx->staging.cck_basic_rates = | ||
94 | (IWL_CCK_RATES_MASK >> IWL_FIRST_CCK_RATE) & 0xF; | ||
95 | |||
96 | /* clear both MIX and PURE40 mode flag */ | ||
97 | ctx->staging.flags &= ~(RXON_FLG_CHANNEL_MODE_MIXED | | ||
98 | RXON_FLG_CHANNEL_MODE_PURE_40); | ||
99 | if (ctx->vif) | ||
100 | memcpy(ctx->staging.node_addr, ctx->vif->addr, ETH_ALEN); | ||
101 | |||
102 | ctx->staging.ofdm_ht_single_stream_basic_rates = 0xff; | ||
103 | ctx->staging.ofdm_ht_dual_stream_basic_rates = 0xff; | ||
104 | ctx->staging.ofdm_ht_triple_stream_basic_rates = 0xff; | ||
105 | } | ||
106 | |||
35 | static int iwlagn_disable_bss(struct iwl_priv *priv, | 107 | static int iwlagn_disable_bss(struct iwl_priv *priv, |
36 | struct iwl_rxon_context *ctx, | 108 | struct iwl_rxon_context *ctx, |
37 | struct iwl_rxon_cmd *send) | 109 | struct iwl_rxon_cmd *send) |
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.h b/drivers/net/wireless/iwlwifi/iwl-agn.h index ecc217c7c625..8f9ea33e950e 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn.h +++ b/drivers/net/wireless/iwlwifi/iwl-agn.h | |||
@@ -117,6 +117,8 @@ int iwl_dvm_send_cmd_pdu(struct iwl_priv *priv, u8 id, | |||
117 | u32 flags, u16 len, const void *data); | 117 | u32 flags, u16 len, const void *data); |
118 | 118 | ||
119 | /* RXON */ | 119 | /* RXON */ |
120 | void iwl_connection_init_rx_config(struct iwl_priv *priv, | ||
121 | struct iwl_rxon_context *ctx); | ||
120 | int iwlagn_set_pan_params(struct iwl_priv *priv); | 122 | int iwlagn_set_pan_params(struct iwl_priv *priv); |
121 | int iwlagn_commit_rxon(struct iwl_priv *priv, struct iwl_rxon_context *ctx); | 123 | int iwlagn_commit_rxon(struct iwl_priv *priv, struct iwl_rxon_context *ctx); |
122 | void iwlagn_set_rxon_chain(struct iwl_priv *priv, struct iwl_rxon_context *ctx); | 124 | void iwlagn_set_rxon_chain(struct iwl_priv *priv, struct iwl_rxon_context *ctx); |
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.c b/drivers/net/wireless/iwlwifi/iwl-core.c index fdca7abd31c4..942cbdbfa021 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.c +++ b/drivers/net/wireless/iwlwifi/iwl-core.c | |||
@@ -43,77 +43,6 @@ | |||
43 | 43 | ||
44 | const u8 iwl_bcast_addr[ETH_ALEN] = { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }; | 44 | const u8 iwl_bcast_addr[ETH_ALEN] = { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF }; |
45 | 45 | ||
46 | /* | ||
47 | * initialize rxon structure with default values from eeprom | ||
48 | */ | ||
49 | void iwl_connection_init_rx_config(struct iwl_priv *priv, | ||
50 | struct iwl_rxon_context *ctx) | ||
51 | { | ||
52 | const struct iwl_channel_info *ch_info; | ||
53 | |||
54 | memset(&ctx->staging, 0, sizeof(ctx->staging)); | ||
55 | |||
56 | if (!ctx->vif) { | ||
57 | ctx->staging.dev_type = ctx->unused_devtype; | ||
58 | } else switch (ctx->vif->type) { | ||
59 | case NL80211_IFTYPE_AP: | ||
60 | ctx->staging.dev_type = ctx->ap_devtype; | ||
61 | break; | ||
62 | |||
63 | case NL80211_IFTYPE_STATION: | ||
64 | ctx->staging.dev_type = ctx->station_devtype; | ||
65 | ctx->staging.filter_flags = RXON_FILTER_ACCEPT_GRP_MSK; | ||
66 | break; | ||
67 | |||
68 | case NL80211_IFTYPE_ADHOC: | ||
69 | ctx->staging.dev_type = ctx->ibss_devtype; | ||
70 | ctx->staging.flags = RXON_FLG_SHORT_PREAMBLE_MSK; | ||
71 | ctx->staging.filter_flags = RXON_FILTER_BCON_AWARE_MSK | | ||
72 | RXON_FILTER_ACCEPT_GRP_MSK; | ||
73 | break; | ||
74 | |||
75 | default: | ||
76 | IWL_ERR(priv, "Unsupported interface type %d\n", | ||
77 | ctx->vif->type); | ||
78 | break; | ||
79 | } | ||
80 | |||
81 | #if 0 | ||
82 | /* TODO: Figure out when short_preamble would be set and cache from | ||
83 | * that */ | ||
84 | if (!hw_to_local(priv->hw)->short_preamble) | ||
85 | ctx->staging.flags &= ~RXON_FLG_SHORT_PREAMBLE_MSK; | ||
86 | else | ||
87 | ctx->staging.flags |= RXON_FLG_SHORT_PREAMBLE_MSK; | ||
88 | #endif | ||
89 | |||
90 | ch_info = iwl_get_channel_info(priv, priv->band, | ||
91 | le16_to_cpu(ctx->active.channel)); | ||
92 | |||
93 | if (!ch_info) | ||
94 | ch_info = &priv->channel_info[0]; | ||
95 | |||
96 | ctx->staging.channel = cpu_to_le16(ch_info->channel); | ||
97 | priv->band = ch_info->band; | ||
98 | |||
99 | iwl_set_flags_for_band(priv, ctx, priv->band, ctx->vif); | ||
100 | |||
101 | ctx->staging.ofdm_basic_rates = | ||
102 | (IWL_OFDM_RATES_MASK >> IWL_FIRST_OFDM_RATE) & 0xFF; | ||
103 | ctx->staging.cck_basic_rates = | ||
104 | (IWL_CCK_RATES_MASK >> IWL_FIRST_CCK_RATE) & 0xF; | ||
105 | |||
106 | /* clear both MIX and PURE40 mode flag */ | ||
107 | ctx->staging.flags &= ~(RXON_FLG_CHANNEL_MODE_MIXED | | ||
108 | RXON_FLG_CHANNEL_MODE_PURE_40); | ||
109 | if (ctx->vif) | ||
110 | memcpy(ctx->staging.node_addr, ctx->vif->addr, ETH_ALEN); | ||
111 | |||
112 | ctx->staging.ofdm_ht_single_stream_basic_rates = 0xff; | ||
113 | ctx->staging.ofdm_ht_dual_stream_basic_rates = 0xff; | ||
114 | ctx->staging.ofdm_ht_triple_stream_basic_rates = 0xff; | ||
115 | } | ||
116 | |||
117 | void iwl_set_rate(struct iwl_priv *priv) | 46 | void iwl_set_rate(struct iwl_priv *priv) |
118 | { | 47 | { |
119 | struct iwl_rxon_context *ctx; | 48 | struct iwl_rxon_context *ctx; |
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.h b/drivers/net/wireless/iwlwifi/iwl-core.h index a2b131a16198..8f6b16b80d9a 100644 --- a/drivers/net/wireless/iwlwifi/iwl-core.h +++ b/drivers/net/wireless/iwlwifi/iwl-core.h | |||
@@ -78,8 +78,6 @@ struct iwl_cmd; | |||
78 | * L i b * | 78 | * L i b * |
79 | ***************************/ | 79 | ***************************/ |
80 | 80 | ||
81 | void iwl_connection_init_rx_config(struct iwl_priv *priv, | ||
82 | struct iwl_rxon_context *ctx); | ||
83 | void iwl_set_rate(struct iwl_priv *priv); | 81 | void iwl_set_rate(struct iwl_priv *priv); |
84 | int iwl_cmd_echo_test(struct iwl_priv *priv); | 82 | int iwl_cmd_echo_test(struct iwl_priv *priv); |
85 | #ifdef CONFIG_IWLWIFI_DEBUGFS | 83 | #ifdef CONFIG_IWLWIFI_DEBUGFS |