5 * Common code specific definitions for mac80211 Prism54 drivers
7 * Copyright (c) 2006, Michael Wu <flamingice@sourmilk.net>
8 * Copyright (c) 2007, Christian Lamparter <chunkeey@web.de>
10 * Based on the islsm (softmac prism54) driver, which is:
11 * Copyright 2004-2006 Jean-Baptiste Note <jbnote@gmail.com>, et al.
13 * This program is free software; you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License version 2 as
15 * published by the Free Software Foundation.
22 } __attribute__((packed
));
24 struct bootrec_exp_if
{
30 } __attribute__((packed
));
43 } __attribute__((packed
));
45 #define BR_CODE_MIN 0x80000000
46 #define BR_CODE_COMPONENT_ID 0x80000001
47 #define BR_CODE_COMPONENT_VERSION 0x80000002
48 #define BR_CODE_DEPENDENT_IF 0x80000003
49 #define BR_CODE_EXPOSED_IF 0x80000004
50 #define BR_CODE_DESCR 0x80000101
51 #define BR_CODE_MAX 0x8FFFFFFF
52 #define BR_CODE_END_OF_BRA 0xFF0000FF
53 #define LEGACY_BR_CODE_END_OF_BRA 0xFFFFFFFF
55 /* PDA defines are Copyright (C) 2005 Nokia Corporation (taken from islsm_pda.h) */
58 __le16 len
; /* includes both code and data */
61 } __attribute__ ((packed
));
63 struct eeprom_pda_wrap
{
69 } __attribute__ ((packed
));
71 struct pda_iq_autocal_entry
{
74 } __attribute__ ((packed
));
76 struct pda_channel_output_limit
{
84 } __attribute__ ((packed
));
86 struct pda_pa_curve_data_sample_rev0
{
90 } __attribute__ ((packed
));
92 struct pda_pa_curve_data_sample_rev1
{
100 } __attribute__ ((packed
));
102 struct p54_pa_curve_data_sample
{
111 } __attribute__ ((packed
));
113 struct pda_pa_curve_data
{
116 u8 points_per_channel
;
119 } __attribute__ ((packed
));
122 * this defines the PDR codes used to build PDAs as defined in document
123 * number 553155. The current implementation mirrors version 1.1 of the
124 * document and lists only PDRs supported by the ARM platform.
127 /* common and choice range (0x0000 - 0x0fff) */
128 #define PDR_END 0x0000
129 #define PDR_MANUFACTURING_PART_NUMBER 0x0001
130 #define PDR_PDA_VERSION 0x0002
131 #define PDR_NIC_SERIAL_NUMBER 0x0003
133 #define PDR_MAC_ADDRESS 0x0101
134 #define PDR_REGULATORY_DOMAIN_LIST 0x0103
135 #define PDR_TEMPERATURE_TYPE 0x0107
137 #define PDR_PRISM_PCI_IDENTIFIER 0x0402
139 /* ARM range (0x1000 - 0x1fff) */
140 #define PDR_COUNTRY_INFORMATION 0x1000
141 #define PDR_INTERFACE_LIST 0x1001
142 #define PDR_HARDWARE_PLATFORM_COMPONENT_ID 0x1002
143 #define PDR_OEM_NAME 0x1003
144 #define PDR_PRODUCT_NAME 0x1004
145 #define PDR_UTF8_OEM_NAME 0x1005
146 #define PDR_UTF8_PRODUCT_NAME 0x1006
147 #define PDR_COUNTRY_LIST 0x1007
148 #define PDR_DEFAULT_COUNTRY 0x1008
150 #define PDR_ANTENNA_GAIN 0x1100
152 #define PDR_PRISM_INDIGO_PA_CALIBRATION_DATA 0x1901
153 #define PDR_RSSI_LINEAR_APPROXIMATION 0x1902
154 #define PDR_PRISM_PA_CAL_OUTPUT_POWER_LIMITS 0x1903
155 #define PDR_PRISM_PA_CAL_CURVE_DATA 0x1904
156 #define PDR_RSSI_LINEAR_APPROXIMATION_DUAL_BAND 0x1905
157 #define PDR_PRISM_ZIF_TX_IQ_CALIBRATION 0x1906
158 #define PDR_REGULATORY_POWER_LIMITS 0x1907
159 #define PDR_RSSI_LINEAR_APPROXIMATION_EXTENDED 0x1908
160 #define PDR_RADIATED_TRANSMISSION_CORRECTION 0x1909
161 #define PDR_PRISM_TX_IQ_CALIBRATION 0x190a
163 /* reserved range (0x2000 - 0x7fff) */
165 /* customer range (0x8000 - 0xffff) */
166 #define PDR_BASEBAND_REGISTERS 0x8000
167 #define PDR_PER_CHANNEL_BASEBAND_REGISTERS 0x8001
169 /* stored in skb->cb */
175 struct p54_eeprom_lm86
{
179 } __attribute__ ((packed
));
193 } __attribute__ ((packed
));
195 struct p54_frame_sent_hdr
{
201 } __attribute__ ((packed
));
203 struct p54_tx_control_allocdata
{
216 } __attribute__ ((packed
));
218 struct p54_tx_control_filter
{
220 u8 mac_addr
[ETH_ALEN
];
226 __le32 basic_rate_mask
;
233 } v1
__attribute__ ((packed
));
241 } v2
__attribute__ ((packed
));
242 } __attribute__ ((packed
));
243 } __attribute__ ((packed
));
245 #define P54_TX_CONTROL_FILTER_V1_LEN (sizeof(struct p54_tx_control_filter))
246 #define P54_TX_CONTROL_FILTER_V2_LEN (sizeof(struct p54_tx_control_filter)-8)
248 struct p54_tx_control_channel
{
252 struct pda_iq_autocal_entry iq_autocal
;
253 u8 pa_points_per_curve
;
259 struct p54_pa_curve_data_sample curve_data
[8];
268 } v1
__attribute__ ((packed
));
271 __le32 basic_rate_mask
;
275 } v2
__attribute__ ((packed
));
276 } __attribute__ ((packed
));
277 } __attribute__ ((packed
));
279 #define P54_TX_CONTROL_CHANNEL_V1_LEN (sizeof(struct p54_tx_control_channel)-12)
280 #define P54_TX_CONTROL_CHANNEL_V2_LEN (sizeof(struct p54_tx_control_channel))
282 struct p54_tx_control_led
{
284 __le16 led_temporary
;
285 __le16 led_permanent
;
287 } __attribute__ ((packed
));
289 struct p54_tx_vdcf_queues
{
294 } __attribute__ ((packed
));
296 struct p54_tx_control_vdcf
{
301 struct p54_tx_vdcf_queues queue
[8];
304 } __attribute__ ((packed
));
306 struct p54_statistics
{
316 __le32 unkn
[10]; /* CCE / CCA / RADAR */
317 } __attribute__ ((packed
));
319 struct p54_tx_control_xbow_synth
{
324 } __attribute__ ((packed
));
326 #endif /* P54COMMON_H */