8 #define PFX KBUILD_MODNAME ": "
10 static inline u32
agnx_read32(void __iomem
*mem_region
, u32 offset
)
12 return ioread32(mem_region
+ offset
);
15 static inline void agnx_write32(void __iomem
*mem_region
, u32 offset
, u32 val
)
17 iowrite32(val
, mem_region
+ offset
);
20 /* static const struct ieee80211_rate agnx_rates_80211b[] = { */
23 /* .flags = IEEE80211_RATE_CCK }, */
26 /* .hw_value = -0x14, */
27 /* .flags = IEEE80211_RATE_CCK_2 }, */
31 /* .flags = IEEE80211_RATE_CCK_2 }, */
35 /* .flags = IEEE80211_RATE_CCK_2 } */
39 static const struct ieee80211_rate agnx_rates_80211g
[] = {
40 /* { .bitrate = 10, .hw_value = 1, .flags = IEEE80211_RATE_SHORT_PREAMBLE }, */
41 /* { .bitrate = 20, .hw_value = 2, .flags = IEEE80211_RATE_SHORT_PREAMBLE }, */
42 /* { .bitrate = 55, .hw_value = 3, .flags = IEEE80211_RATE_SHORT_PREAMBLE }, */
43 /* { .bitrate = 110, .hw_value = 4, .flags = IEEE80211_RATE_SHORT_PREAMBLE }, */
44 { .bitrate
= 10, .hw_value
= 1, },
45 { .bitrate
= 20, .hw_value
= 2, },
46 { .bitrate
= 55, .hw_value
= 3, },
47 { .bitrate
= 110, .hw_value
= 4,},
49 { .bitrate
= 60, .hw_value
= 0xB, },
50 { .bitrate
= 90, .hw_value
= 0xF, },
51 { .bitrate
= 120, .hw_value
= 0xA },
52 { .bitrate
= 180, .hw_value
= 0xE, },
53 /* { .bitrate = 240, .hw_value = 0xd, }, */
54 { .bitrate
= 360, .hw_value
= 0xD, },
55 { .bitrate
= 480, .hw_value
= 0x8, },
56 { .bitrate
= 540, .hw_value
= 0xC, },
59 static const struct ieee80211_channel agnx_channels
[] = {
60 { .center_freq
= 2412, .hw_value
= 1, },
61 { .center_freq
= 2417, .hw_value
= 2, },
62 { .center_freq
= 2422, .hw_value
= 3, },
63 { .center_freq
= 2427, .hw_value
= 4, },
64 { .center_freq
= 2432, .hw_value
= 5, },
65 { .center_freq
= 2437, .hw_value
= 6, },
66 { .center_freq
= 2442, .hw_value
= 7, },
67 { .center_freq
= 2447, .hw_value
= 8, },
68 { .center_freq
= 2452, .hw_value
= 9, },
69 { .center_freq
= 2457, .hw_value
= 10, },
70 { .center_freq
= 2462, .hw_value
= 11, },
71 { .center_freq
= 2467, .hw_value
= 12, },
72 { .center_freq
= 2472, .hw_value
= 13, },
73 { .center_freq
= 2484, .hw_value
= 14, },
76 #define NUM_DRIVE_MODES 2
77 /* Agnx operate mode */
81 AGNX_MODE_80211A_MIMO
,
82 AGNX_MODE_80211B_SHORT
,
83 AGNX_MODE_80211B_LONG
,
86 AGNX_MODE_80211G_MIMO
,
97 struct ieee80211_hw
*hw
;
101 unsigned int init_status
;
103 void __iomem
*ctl
; /* pointer to base ram address */
104 void __iomem
*data
; /* pointer to mem region #2 */
107 struct agnx_ring txm
;
108 struct agnx_ring txd
;
113 struct delayed_work periodic_work
; /* Periodic tasks like recalibrate */
114 struct ieee80211_low_level_stats stats
;
116 /* unsigned int phymode; */
121 u8 mac_addr
[ETH_ALEN
];
124 struct ieee80211_supported_band band
;
128 #define AGNX_CHAINS_MAX 6
129 #define AGNX_PERIODIC_DELAY 60000 /* unit: ms */
130 #define LOCAL_STAID 0 /* the station entry for the card itself */
131 #define BSSID_STAID 1 /* the station entry for the bsssid AP */
132 #define spi_delay() udelay(40)
133 #define eeprom_delay() udelay(40)
134 #define routing_table_delay() udelay(50)
136 /* PDU pool MEM region #2 */
137 #define AGNX_PDUPOOL 0x40000 /* PDU pool */
138 #define AGNX_PDUPOOL_SIZE 0x8000 /* PDU pool size*/
139 #define AGNX_PDU_TX_WQ 0x41000 /* PDU list TX workqueue */
140 #define AGNX_PDU_FREE 0x41800 /* Free Pool */
141 #define PDU_SIZE 0x80 /* Free Pool node size */
142 #define PDU_FREE_CNT 0xd0 /* Free pool node count */
146 extern void rf_chips_init(struct agnx_priv
*priv
);
147 extern void spi_rc_write(void __iomem
*mem_region
, u32 chip_ids
, u32 sw
);
148 extern void calibrate_oscillator(struct agnx_priv
*priv
);
149 extern void do_calibration(struct agnx_priv
*priv
);
150 extern void antenna_calibrate(struct agnx_priv
*priv
);
151 extern void __antenna_calibrate(struct agnx_priv
*priv
);
152 extern void print_offsets(struct agnx_priv
*priv
);
153 extern int agnx_set_channel(struct agnx_priv
*priv
, unsigned int channel
);