5 * Shared defines for all mac80211 Prism54 code
7 * Copyright (c) 2006, Michael Wu <flamingice@sourmilk.net>
9 * Based on the islsm (softmac prism54) driver, which is:
10 * Copyright 2004-2006 Jean-Baptiste Note <jbnote@gmail.com>, et al.
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License version 2 as
14 * published by the Free Software Foundation.
17 #ifdef CONFIG_MAC80211_LEDS
18 #include <linux/leds.h>
19 #endif /* CONFIG_MAC80211_LEDS */
21 enum p54_control_frame_types {
22 P54_CONTROL_TYPE_SETUP = 0,
23 P54_CONTROL_TYPE_SCAN,
24 P54_CONTROL_TYPE_TRAP,
25 P54_CONTROL_TYPE_DCFINIT,
26 P54_CONTROL_TYPE_RX_KEYCACHE,
29 P54_CONTROL_TYPE_TXCANCEL,
30 P54_CONTROL_TYPE_TXDONE,
31 P54_CONTROL_TYPE_BURST,
32 P54_CONTROL_TYPE_STAT_READBACK,
34 P54_CONTROL_TYPE_EEPROM_READBACK,
36 P54_CONTROL_TYPE_GPIO,
37 P54_CONTROL_TYPE_TIMER,
38 P54_CONTROL_TYPE_MODULATION,
39 P54_CONTROL_TYPE_SYNTH_CONFIG,
40 P54_CONTROL_TYPE_DETECTOR_VALUE,
41 P54_CONTROL_TYPE_XBOW_SYNTH_CFG,
42 P54_CONTROL_TYPE_CCE_QUIET,
43 P54_CONTROL_TYPE_PSM_STA_UNLOCK,
45 P54_CONTROL_TYPE_BT_BALANCER = 28,
46 P54_CONTROL_TYPE_GROUP_ADDRESS_TABLE = 30,
47 P54_CONTROL_TYPE_ARPTABLE = 31,
48 P54_CONTROL_TYPE_BT_OPTIONS = 35
51 /* provide 16 bytes for the transport back-end */
52 #define P54_TX_INFO_DATA_SIZE 16
54 /* stored in ieee80211_tx_info's rate_driver_data */
58 void *data[P54_TX_INFO_DATA_SIZE / sizeof(void *)];
61 #define P54_MAX_CTRL_FRAME_LEN 0x1000
63 #define P54_HDR_FLAG_CONTROL BIT(15)
64 #define P54_HDR_FLAG_CONTROL_OPSET (BIT(15) + BIT(0))
70 __le16 type; /* enum p54_control_frame_types */
74 } __attribute__ ((packed));
76 #define FREE_AFTER_TX(skb) \
77 ((((struct p54_hdr *) ((struct sk_buff *) skb)->data)-> \
78 flags) == cpu_to_le16(P54_HDR_FLAG_CONTROL_OPSET))
80 struct p54_edcf_queue_param {
85 } __attribute__ ((packed));
87 struct p54_rssi_linear_approximation {
94 struct p54_cal_database {
102 #define EEPROM_READBACK_LEN 0x3fc
104 #define ISL38XX_DEV_FIRMWARE_ADDR 0x20000
106 #define FW_FMAC 0x464d4143
107 #define FW_LM86 0x4c4d3836
108 #define FW_LM87 0x4c4d3837
109 #define FW_LM20 0x4c4d3230
119 #ifdef CONFIG_MAC80211_LEDS
121 #define P54_LED_MAX_NAME_LEN 31
124 struct ieee80211_hw *hw_dev;
125 struct led_classdev led_dev;
126 char name[P54_LED_MAX_NAME_LEN + 1];
129 unsigned int registered;
132 #endif /* CONFIG_MAC80211_LEDS */
135 struct ieee80211_hw *hw;
138 struct sk_buff_head tx_queue;
139 void (*tx)(struct ieee80211_hw *dev, struct sk_buff *skb);
140 int (*open)(struct ieee80211_hw *dev);
141 void (*stop)(struct ieee80211_hw *dev);
146 struct mutex conf_mutex;
147 u8 mac_addr[ETH_ALEN];
149 u8 rx_diversity_mask;
150 u8 tx_diversity_mask;
151 struct pda_iq_autocal_entry *iq_autocal;
152 unsigned int iq_autocal_len;
153 struct p54_cal_database *output_limit;
154 struct p54_cal_database *curve_data;
155 struct p54_rssi_linear_approximation rssical_db[IEEE80211_NUM_BANDS];
156 unsigned int filter_flags;
160 unsigned int tx_hdr_len;
162 unsigned int fw_interface;
163 unsigned int output_power;
169 struct ieee80211_tx_queue_stats tx_stats[8];
170 struct p54_edcf_queue_param qos_params[8];
171 struct ieee80211_low_level_stats stats;
172 struct delayed_work work;
173 struct sk_buff *cached_beacon;
176 struct completion eeprom_comp;
180 #ifdef CONFIG_MAC80211_LEDS
181 struct p54_led_dev assoc_led;
182 struct p54_led_dev tx_led;
183 #endif /* CONFIG_MAC80211_LEDS */
184 u16 softled_state; /* bit field of glowing LEDs */
187 int p54_rx(struct ieee80211_hw *dev, struct sk_buff *skb);
188 void p54_free_skb(struct ieee80211_hw *dev, struct sk_buff *skb);
189 int p54_parse_firmware(struct ieee80211_hw *dev, const struct firmware *fw);
190 int p54_parse_eeprom(struct ieee80211_hw *dev, void *eeprom, int len);
191 int p54_read_eeprom(struct ieee80211_hw *dev);
192 struct ieee80211_hw *p54_init_common(size_t priv_data_len);
193 int p54_register_common(struct ieee80211_hw *dev, struct device *pdev);
194 void p54_free_common(struct ieee80211_hw *dev);