summaryrefslogtreecommitdiff
path: root/mac80211/ti-utils/ini.h
blob: 9bc34d08049913d68ba3135339bd6cf8b6c61f24 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
/*
 * This file is part of wl1271
 *
 * Copyright (C) 2010 Nokia Corporation
 *
 * Contact: Luciano Coelho <luciano.coelho@nokia.com>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * version 2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA
 *
 */

#ifndef __INI_H__
#define __INI_H__

#include <linux/limits.h>

#define WL1271_INI_MAX_SMART_REFLEX_PARAM 16

struct wl1271_ini_general_params {
unsigned char ref_clock;
unsigned char settling_time;
unsigned char clk_valid_on_wakeup;
unsigned char dc2dc_mode;
unsigned char dual_mode_select;
unsigned char tx_bip_fem_auto_detect;
unsigned char tx_bip_fem_manufacturer;
unsigned char general_settings;
unsigned char sr_state;
unsigned char srf1[WL1271_INI_MAX_SMART_REFLEX_PARAM];
unsigned char srf2[WL1271_INI_MAX_SMART_REFLEX_PARAM];
unsigned char srf3[WL1271_INI_MAX_SMART_REFLEX_PARAM];
} __attribute__((packed));

#define WL128X_INI_MAX_SETTINGS_PARAM 4

struct wl128x_ini_general_params {
unsigned char ref_clock;
unsigned char settling_time;
unsigned char clk_valid_on_wakeup;
unsigned char tcxo_ref_clock;
unsigned char tcxo_settling_time;
unsigned char tcxo_valid_on_wakeup;
unsigned char tcxo_ldo_voltage;
unsigned char xtal_itrim_val;
unsigned char platform_conf;
unsigned char dual_mode_select;
unsigned char tx_bip_fem_auto_detect;
unsigned char tx_bip_fem_manufacturer;
unsigned char general_settings[WL128X_INI_MAX_SETTINGS_PARAM];
unsigned char sr_state;
unsigned char srf1[WL1271_INI_MAX_SMART_REFLEX_PARAM];
unsigned char srf2[WL1271_INI_MAX_SMART_REFLEX_PARAM];
unsigned char srf3[WL1271_INI_MAX_SMART_REFLEX_PARAM];
} __attribute__((packed));

#define WL1271_INI_RSSI_PROCESS_COMPENS_SIZE 15

struct wl1271_ini_band_params_2 {
unsigned char rx_trace_insertion_loss;
unsigned char tx_trace_loss;
unsigned char
rx_rssi_process_compens[WL1271_INI_RSSI_PROCESS_COMPENS_SIZE];
} __attribute__((packed));

#define WL1271_INI_CHANNEL_COUNT_2 14

struct wl128x_ini_band_params_2 {
unsigned char rx_trace_insertion_loss;
unsigned char tx_trace_loss[WL1271_INI_CHANNEL_COUNT_2];
unsigned char
rx_rssi_process_compens[WL1271_INI_RSSI_PROCESS_COMPENS_SIZE];
} __attribute__((packed));

#define WL1271_INI_RATE_GROUP_COUNT 6

struct wl1271_ini_fem_params_2 {
__le16 tx_bip_ref_pd_voltage;
unsigned char tx_bip_ref_power;
unsigned char tx_bip_ref_offset;
unsigned char
tx_per_rate_pwr_limits_normal[WL1271_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_degraded[WL1271_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_extreme[WL1271_INI_RATE_GROUP_COUNT];
unsigned char tx_per_chan_pwr_limits_11b[WL1271_INI_CHANNEL_COUNT_2];
unsigned char tx_per_chan_pwr_limits_ofdm[WL1271_INI_CHANNEL_COUNT_2];
unsigned char tx_pd_vs_rate_offsets[WL1271_INI_RATE_GROUP_COUNT];
unsigned char tx_ibias[WL1271_INI_RATE_GROUP_COUNT];
unsigned char rx_fem_insertion_loss;
unsigned char degraded_low_to_normal_thr;
unsigned char normal_to_degraded_high_thr;
} __attribute__((packed));

#define WL128X_INI_RATE_GROUP_COUNT 7
/* low and high temperatures*/
#define WL128X_INI_PD_VS_TEMPERATURE_RANGES 2

struct wl128x_ini_fem_params_2 {
__le16 tx_bip_ref_pd_voltage;
unsigned char tx_bip_ref_power;
unsigned char tx_bip_ref_offset;
unsigned char
tx_per_rate_pwr_limits_normal [WL128X_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_degraded [WL128X_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_extreme [WL128X_INI_RATE_GROUP_COUNT];
unsigned char tx_per_chan_pwr_limits_11b[WL1271_INI_CHANNEL_COUNT_2];
unsigned char tx_per_chan_pwr_limits_ofdm[WL1271_INI_CHANNEL_COUNT_2];
unsigned char tx_pd_vs_rate_offsets[WL128X_INI_RATE_GROUP_COUNT];
unsigned char tx_ibias[WL128X_INI_RATE_GROUP_COUNT + 1];
unsigned char tx_pd_vs_chan_offsets[WL1271_INI_CHANNEL_COUNT_2];
unsigned char tx_pd_vs_temperature[WL128X_INI_PD_VS_TEMPERATURE_RANGES];
unsigned char rx_fem_insertion_loss;
unsigned char degraded_low_to_normal_thr;
unsigned char normal_to_degraded_high_thr;
} __attribute__((packed));

#define WL1271_INI_CHANNEL_COUNT_5 35
#define WL1271_INI_SUB_BAND_COUNT_5 7

struct wl1271_ini_band_params_5 {
unsigned char rx_trace_insertion_loss[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char tx_trace_loss[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char
rx_rssi_process_compens[WL1271_INI_RSSI_PROCESS_COMPENS_SIZE];
} __attribute__((packed));

struct wl128x_ini_band_params_5 {
unsigned char rx_trace_insertion_loss[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char tx_trace_loss[WL1271_INI_CHANNEL_COUNT_5];
unsigned char
rx_rssi_process_compens[WL1271_INI_RSSI_PROCESS_COMPENS_SIZE];
} __attribute__((packed));

struct wl1271_ini_fem_params_5 {
__le16 tx_bip_ref_pd_voltage[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char tx_bip_ref_power[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char tx_bip_ref_offset[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char
tx_per_rate_pwr_limits_normal[WL1271_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_degraded[WL1271_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_extreme[WL1271_INI_RATE_GROUP_COUNT];
unsigned char tx_per_chan_pwr_limits_ofdm[WL1271_INI_CHANNEL_COUNT_5];
unsigned char tx_pd_vs_rate_offsets[WL1271_INI_RATE_GROUP_COUNT];
unsigned char tx_ibias[WL1271_INI_RATE_GROUP_COUNT];
unsigned char rx_fem_insertion_loss[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char degraded_low_to_normal_thr;
unsigned char normal_to_degraded_high_thr;
} __attribute__((packed));

struct wl128x_ini_fem_params_5 {
__le16 tx_bip_ref_pd_voltage[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char tx_bip_ref_power[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char tx_bip_ref_offset[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char
tx_per_rate_pwr_limits_normal [WL128X_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_degraded [WL128X_INI_RATE_GROUP_COUNT];
unsigned char
tx_per_rate_pwr_limits_extreme [WL128X_INI_RATE_GROUP_COUNT];
unsigned char tx_per_chan_pwr_limits_ofdm[WL1271_INI_CHANNEL_COUNT_5];
unsigned char tx_pd_vs_rate_offsets[WL128X_INI_RATE_GROUP_COUNT];
unsigned char tx_ibias[WL128X_INI_RATE_GROUP_COUNT];
unsigned char tx_pd_vs_chan_offsets[WL1271_INI_CHANNEL_COUNT_5];
unsigned char tx_pd_vs_temperature[WL1271_INI_SUB_BAND_COUNT_5 *
WL128X_INI_PD_VS_TEMPERATURE_RANGES];
unsigned char rx_fem_insertion_loss[WL1271_INI_SUB_BAND_COUNT_5];
unsigned char degraded_low_to_normal_thr;
unsigned char normal_to_degraded_high_thr;
} __attribute__((packed));

/* NVS data structure */
#define WL1271_INI_NVS_SECTION_SIZE     468
#define WL1271_INI_FEM_MODULE_COUNT                  2

#define WL1271_INI_LEGACY_NVS_FILE_SIZE              800

struct wl1271_nvs_file {
/* NVS section */
unsigned char nvs[WL1271_INI_NVS_SECTION_SIZE];

/* INI section */
struct wl1271_ini_general_params general_params;
unsigned char padding1;
struct wl1271_ini_band_params_2 stat_radio_params_2;
unsigned char padding2;
struct {
struct wl1271_ini_fem_params_2 params;
unsigned char padding;
} dyn_radio_params_2[WL1271_INI_FEM_MODULE_COUNT];
struct wl1271_ini_band_params_5 stat_radio_params_5;
unsigned char padding3;
struct {
struct wl1271_ini_fem_params_5 params;
unsigned char padding;
} dyn_radio_params_5[WL1271_INI_FEM_MODULE_COUNT];
} __attribute__((packed));

struct wl128x_nvs_file {
/* NVS section */
unsigned char nvs[WL1271_INI_NVS_SECTION_SIZE];

/* INI section */
struct wl128x_ini_general_params general_params;
unsigned char fem_vendor_and_options;
struct wl128x_ini_band_params_2 stat_radio_params_2;
unsigned char padding2;
struct {
struct wl128x_ini_fem_params_2 params;
unsigned char padding;
} dyn_radio_params_2[WL1271_INI_FEM_MODULE_COUNT];
struct wl128x_ini_band_params_5 stat_radio_params_5;
unsigned char padding3;
struct {
struct wl128x_ini_fem_params_5 params;
unsigned char padding;
} dyn_radio_params_5[WL1271_INI_FEM_MODULE_COUNT];
} __attribute__((packed));

struct wl1271_ini {
struct wl1271_ini_general_params general_params;
unsigned char padding1;
struct wl1271_ini_band_params_2 stat_radio_params_2;
unsigned char padding2;
struct {
struct wl1271_ini_fem_params_2 params;
unsigned char padding;
} dyn_radio_params_2[WL1271_INI_FEM_MODULE_COUNT];
struct wl1271_ini_band_params_5 stat_radio_params_5;
unsigned char padding3;
struct {
struct wl1271_ini_fem_params_5 params;
unsigned char padding;
} dyn_radio_params_5[WL1271_INI_FEM_MODULE_COUNT];
} __attribute__((packed));

struct wl128x_ini {
struct wl128x_ini_general_params general_params;
unsigned char fem_vendor_and_options;
struct wl128x_ini_band_params_2 stat_radio_params_2;
unsigned char padding2;
struct {
struct wl128x_ini_fem_params_2 params;
unsigned char padding;
} dyn_radio_params_2[WL1271_INI_FEM_MODULE_COUNT];
struct wl128x_ini_band_params_5 stat_radio_params_5;
unsigned char padding3;
struct {
struct wl128x_ini_fem_params_5 params;
unsigned char padding;
} dyn_radio_params_5[WL1271_INI_FEM_MODULE_COUNT];
} __attribute__((packed));

enum wl1271_ini_section {
UKNOWN_SECTION,
GENERAL_PRMS,
FEM_PRMS,
BAND2_PRMS,
BAND5_PRMS,
FEM0_BAND2_PRMS,
FEM1_BAND2_PRMS,
FEM1_BAND5_PRMS
};

enum wl12xx_arch {
UNKNOWN_ARCH,
WL1271_ARCH,
WL128X_ARCH
};

struct wl12xx_ini {
union {
struct wl1271_ini ini1271;
struct wl128x_ini ini128x;
};
};

#define DUAL_MODE_UNSET    0xff
#define NO_FEM_PARSED      0xff

struct wl12xx_common {
enum wl12xx_arch arch;
unsigned char dual_mode;
unsigned char done_fem; /* Number of FEM already parsed */
struct wl12xx_parse_ops *parse_ops;
struct wl12xx_nvs_ops   *nvs_ops;
struct wl12xx_ini ini;
};

struct wl12xx_parse_ops {
int (*prs_general_prms)(char *l, struct wl12xx_common *cmn,
struct wl12xx_ini *p);
/* int (*prs_fem_prms)(char *l, void *gp); */
int (*prs_band2_prms)(char *l, struct wl12xx_ini *p);
int (*prs_band5_prms)(char *l, struct wl12xx_ini *p);
int (*prs_fem0_band2_prms)(char *l, struct wl12xx_ini *p);
int (*prs_fem1_band2_prms)(char *l, struct wl12xx_ini *p);
int (*prs_fem1_band5_prms)(char *l, struct wl12xx_ini *p);
};

struct wl12xx_nvs_ops {
int (*nvs_fill_radio_prms)(int fd, struct wl12xx_ini *p, char *buf);
int (*nvs_set_autofem)(int fd, char *buf, unsigned char val);
int (*nvs_set_fem_manuf)(int fd, char *buf, unsigned char val);
};

int nvs_get_arch(int file_size, struct wl12xx_common *cmn);

int read_ini(const char *filename, struct wl12xx_common *cmn);

#endif