iwlwifi: fix the Transmit Frame Descriptor rings
[deliverable/linux.git] / drivers / net / wireless / iwlwifi / iwl-2000.c
CommitLineData
c5a5e185
WYG
1/******************************************************************************
2 *
4e318262 3 * Copyright(c) 2008 - 2012 Intel Corporation. All rights reserved.
c5a5e185
WYG
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
8 *
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12 * more details.
13 *
14 * You should have received a copy of the GNU General Public License along with
15 * this program; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
17 *
18 * The full GNU General Public License is included in this distribution in the
19 * file called LICENSE.
20 *
21 * Contact Information:
22 * Intel Linux Wireless <ilw@linux.intel.com>
23 * Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
24 *
25 *****************************************************************************/
26
c5a5e185 27#include <linux/module.h>
8fcbd4dc 28#include <linux/stringify.h>
e9676695 29#include "iwl-config.h"
cebcbd75 30#include "iwl-cfg.h"
0db19cde
JB
31#include "iwl-agn-hw.h"
32#include "iwl-commands.h" /* needed for BT for now */
c5a5e185
WYG
33
34/* Highest firmware API version supported */
ca9a4605
JB
35#define IWL2030_UCODE_API_MAX 6
36#define IWL2000_UCODE_API_MAX 6
37#define IWL105_UCODE_API_MAX 6
38#define IWL135_UCODE_API_MAX 6
39
40/* Oldest version we won't warn about */
78cbcf2b
MV
41#define IWL2030_UCODE_API_OK 6
42#define IWL2000_UCODE_API_OK 6
43#define IWL105_UCODE_API_OK 6
44#define IWL135_UCODE_API_OK 6
c5a5e185
WYG
45
46/* Lowest firmware API version supported */
47#define IWL2030_UCODE_API_MIN 5
48#define IWL2000_UCODE_API_MIN 5
b4ed221d 49#define IWL105_UCODE_API_MIN 5
54e9c409 50#define IWL135_UCODE_API_MIN 5
c5a5e185 51
586aed96
JB
52/* EEPROM version */
53#define EEPROM_2000_TX_POWER_VERSION (6)
54#define EEPROM_2000_EEPROM_VERSION (0x805)
55
56
c5a5e185 57#define IWL2030_FW_PRE "iwlwifi-2030-"
8fcbd4dc 58#define IWL2030_MODULE_FIRMWARE(api) IWL2030_FW_PRE __stringify(api) ".ucode"
c5a5e185
WYG
59
60#define IWL2000_FW_PRE "iwlwifi-2000-"
8fcbd4dc 61#define IWL2000_MODULE_FIRMWARE(api) IWL2000_FW_PRE __stringify(api) ".ucode"
c5a5e185 62
b4ed221d 63#define IWL105_FW_PRE "iwlwifi-105-"
8fcbd4dc 64#define IWL105_MODULE_FIRMWARE(api) IWL105_FW_PRE __stringify(api) ".ucode"
c5a5e185 65
54e9c409 66#define IWL135_FW_PRE "iwlwifi-135-"
5092e47a 67#define IWL135_MODULE_FIRMWARE(api) IWL135_FW_PRE __stringify(api) ".ucode"
54e9c409 68
6794f3ee 69static const struct iwl_base_params iwl2000_base_params = {
c5a5e185
WYG
70 .eeprom_size = OTP_LOW_IMAGE_SIZE,
71 .num_of_queues = IWLAGN_NUM_QUEUES,
c5a5e185 72 .pll_cfg_val = 0,
c5a5e185
WYG
73 .max_ll_items = OTP_MAX_LL_ITEMS_2x00,
74 .shadow_ram_support = true,
75 .led_compensation = 51,
c5a5e185
WYG
76 .adv_thermal_throttle = true,
77 .support_ct_kill_exit = true,
78 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
79 .chain_noise_scale = 1000,
80 .wd_timeout = IWL_DEF_WD_TIMEOUT,
81 .max_event_log_size = 512,
c5a5e185 82 .shadow_reg_enable = true,
ae7f9a74 83 .hd_v2 = true,
c5a5e185
WYG
84};
85
86
6794f3ee 87static const struct iwl_base_params iwl2030_base_params = {
c5a5e185
WYG
88 .eeprom_size = OTP_LOW_IMAGE_SIZE,
89 .num_of_queues = IWLAGN_NUM_QUEUES,
c5a5e185 90 .pll_cfg_val = 0,
c5a5e185
WYG
91 .max_ll_items = OTP_MAX_LL_ITEMS_2x00,
92 .shadow_ram_support = true,
93 .led_compensation = 57,
c5a5e185
WYG
94 .adv_thermal_throttle = true,
95 .support_ct_kill_exit = true,
96 .plcp_delta_threshold = IWL_MAX_PLCP_ERR_THRESHOLD_DEF,
97 .chain_noise_scale = 1000,
98 .wd_timeout = IWL_LONG_WD_TIMEOUT,
99 .max_event_log_size = 512,
c5a5e185 100 .shadow_reg_enable = true,
ae7f9a74 101 .hd_v2 = true,
c5a5e185
WYG
102};
103
6794f3ee 104static const struct iwl_ht_params iwl2000_ht_params = {
c5a5e185
WYG
105 .ht_greenfield_support = true,
106 .use_rts_for_aggregation = true, /* use rts/cts protection */
107};
108
6794f3ee 109static const struct iwl_bt_params iwl2030_bt_params = {
c5a5e185
WYG
110 /* Due to bluetooth, we transmit 2.4 GHz probes only on antenna A */
111 .advanced_bt_coexist = true,
112 .agg_time_limit = BT_AGG_THRESHOLD_DEF,
113 .bt_init_traffic_load = IWL_BT_COEX_TRAFFIC_LOAD_NONE,
114 .bt_prio_boost = IWLAGN_BT_PRIO_BOOST_DEFAULT,
115 .bt_sco_disable = true,
6013270a 116 .bt_session_2 = true,
c5a5e185
WYG
117};
118
119#define IWL_DEVICE_2000 \
120 .fw_name_pre = IWL2000_FW_PRE, \
121 .ucode_api_max = IWL2000_UCODE_API_MAX, \
ca9a4605 122 .ucode_api_ok = IWL2000_UCODE_API_OK, \
c5a5e185 123 .ucode_api_min = IWL2000_UCODE_API_MIN, \
2d771cb6 124 .device_family = IWL_DEVICE_FAMILY_2000, \
dae66d0d
EG
125 .max_inst_size = IWL60_RTC_INST_SIZE, \
126 .max_data_size = IWL60_RTC_DATA_SIZE, \
c5a5e185
WYG
127 .eeprom_ver = EEPROM_2000_EEPROM_VERSION, \
128 .eeprom_calib_ver = EEPROM_2000_TX_POWER_VERSION, \
c5a5e185 129 .base_params = &iwl2000_base_params, \
c5a5e185 130 .need_temp_offset_calib = true, \
c6f30347 131 .temp_offset_v2 = true, \
cf61686a 132 .led_mode = IWL_LED_RF_STATE
c5a5e185 133
706c4ff6 134const struct iwl_cfg iwl2000_2bgn_cfg = {
6195d135 135 .name = "Intel(R) Centrino(R) Wireless-N 2200 BGN",
c5a5e185
WYG
136 IWL_DEVICE_2000,
137 .ht_params = &iwl2000_ht_params,
138};
139
706c4ff6 140const struct iwl_cfg iwl2000_2bgn_d_cfg = {
6195d135 141 .name = "Intel(R) Centrino(R) Wireless-N 2200D BGN",
1603dd49 142 IWL_DEVICE_2000,
ec8f734f 143 .ht_params = &iwl2000_ht_params,
1603dd49
WYG
144};
145
c5a5e185
WYG
146#define IWL_DEVICE_2030 \
147 .fw_name_pre = IWL2030_FW_PRE, \
148 .ucode_api_max = IWL2030_UCODE_API_MAX, \
ca9a4605 149 .ucode_api_ok = IWL2030_UCODE_API_OK, \
c5a5e185 150 .ucode_api_min = IWL2030_UCODE_API_MIN, \
2d771cb6 151 .device_family = IWL_DEVICE_FAMILY_2030, \
dae66d0d
EG
152 .max_inst_size = IWL60_RTC_INST_SIZE, \
153 .max_data_size = IWL60_RTC_DATA_SIZE, \
c5a5e185
WYG
154 .eeprom_ver = EEPROM_2000_EEPROM_VERSION, \
155 .eeprom_calib_ver = EEPROM_2000_TX_POWER_VERSION, \
c5a5e185
WYG
156 .base_params = &iwl2030_base_params, \
157 .bt_params = &iwl2030_bt_params, \
c5a5e185 158 .need_temp_offset_calib = true, \
c6f30347 159 .temp_offset_v2 = true, \
c5a5e185 160 .led_mode = IWL_LED_RF_STATE, \
cf61686a 161 .adv_pm = true
c5a5e185 162
706c4ff6 163const struct iwl_cfg iwl2030_2bgn_cfg = {
6195d135 164 .name = "Intel(R) Centrino(R) Wireless-N 2230 BGN",
96234cc8 165 IWL_DEVICE_2030,
c5a5e185
WYG
166 .ht_params = &iwl2000_ht_params,
167};
168
b4ed221d
WYG
169#define IWL_DEVICE_105 \
170 .fw_name_pre = IWL105_FW_PRE, \
171 .ucode_api_max = IWL105_UCODE_API_MAX, \
ca9a4605 172 .ucode_api_ok = IWL105_UCODE_API_OK, \
b4ed221d 173 .ucode_api_min = IWL105_UCODE_API_MIN, \
2d771cb6 174 .device_family = IWL_DEVICE_FAMILY_105, \
dae66d0d
EG
175 .max_inst_size = IWL60_RTC_INST_SIZE, \
176 .max_data_size = IWL60_RTC_DATA_SIZE, \
c5a5e185
WYG
177 .eeprom_ver = EEPROM_2000_EEPROM_VERSION, \
178 .eeprom_calib_ver = EEPROM_2000_TX_POWER_VERSION, \
c5a5e185 179 .base_params = &iwl2000_base_params, \
c5a5e185 180 .need_temp_offset_calib = true, \
c6f30347 181 .temp_offset_v2 = true, \
c5a5e185
WYG
182 .led_mode = IWL_LED_RF_STATE, \
183 .adv_pm = true, \
cf61686a 184 .rx_with_siso_diversity = true
c5a5e185 185
706c4ff6 186const struct iwl_cfg iwl105_bgn_cfg = {
6195d135 187 .name = "Intel(R) Centrino(R) Wireless-N 105 BGN",
b4ed221d 188 IWL_DEVICE_105,
c5a5e185
WYG
189 .ht_params = &iwl2000_ht_params,
190};
191
706c4ff6 192const struct iwl_cfg iwl105_bgn_d_cfg = {
6195d135 193 .name = "Intel(R) Centrino(R) Wireless-N 105D BGN",
b319d3eb
WYG
194 IWL_DEVICE_105,
195 .ht_params = &iwl2000_ht_params,
196};
197
b4ed221d 198#define IWL_DEVICE_135 \
54e9c409
WYG
199 .fw_name_pre = IWL135_FW_PRE, \
200 .ucode_api_max = IWL135_UCODE_API_MAX, \
ca9a4605 201 .ucode_api_ok = IWL135_UCODE_API_OK, \
54e9c409 202 .ucode_api_min = IWL135_UCODE_API_MIN, \
2d771cb6 203 .device_family = IWL_DEVICE_FAMILY_135, \
dae66d0d
EG
204 .max_inst_size = IWL60_RTC_INST_SIZE, \
205 .max_data_size = IWL60_RTC_DATA_SIZE, \
c5a5e185
WYG
206 .eeprom_ver = EEPROM_2000_EEPROM_VERSION, \
207 .eeprom_calib_ver = EEPROM_2000_TX_POWER_VERSION, \
c5a5e185
WYG
208 .base_params = &iwl2030_base_params, \
209 .bt_params = &iwl2030_bt_params, \
c5a5e185 210 .need_temp_offset_calib = true, \
c6f30347 211 .temp_offset_v2 = true, \
c5a5e185
WYG
212 .led_mode = IWL_LED_RF_STATE, \
213 .adv_pm = true, \
cf61686a 214 .rx_with_siso_diversity = true
c5a5e185 215
706c4ff6 216const struct iwl_cfg iwl135_bgn_cfg = {
6195d135 217 .name = "Intel(R) Centrino(R) Wireless-N 135 BGN",
b4ed221d 218 IWL_DEVICE_135,
c5a5e185
WYG
219 .ht_params = &iwl2000_ht_params,
220};
221
78cbcf2b
MV
222MODULE_FIRMWARE(IWL2000_MODULE_FIRMWARE(IWL2000_UCODE_API_OK));
223MODULE_FIRMWARE(IWL2030_MODULE_FIRMWARE(IWL2030_UCODE_API_OK));
224MODULE_FIRMWARE(IWL105_MODULE_FIRMWARE(IWL105_UCODE_API_OK));
225MODULE_FIRMWARE(IWL135_MODULE_FIRMWARE(IWL135_UCODE_API_OK));
This page took 0.16725 seconds and 5 git commands to generate.