1 /*- 2 * Copyright (c) 2008 Weongyo Jeong <weongyo@FreeBSD.org> 3 * 4 * Permission to use, copy, modify, and distribute this software for any 5 * purpose with or without fee is hereby granted, provided that the above 6 * copyright notice and this permission notice appear in all copies. 7 * 8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 15 */ 16 17 #include <sys/cdefs.h> 18 __FBSDID("$FreeBSD$"); 19 #include <sys/param.h> 20 #include <sys/sockio.h> 21 #include <sys/sysctl.h> 22 #include <sys/lock.h> 23 #include <sys/mutex.h> 24 #include <sys/mbuf.h> 25 #include <sys/kernel.h> 26 #include <sys/socket.h> 27 #include <sys/systm.h> 28 #include <sys/malloc.h> 29 #include <sys/module.h> 30 #include <sys/bus.h> 31 #include <sys/endian.h> 32 #include <sys/kdb.h> 33 34 #include <machine/bus.h> 35 #include <machine/resource.h> 36 #include <sys/rman.h> 37 38 #include <net/if.h> 39 #include <net/if_var.h> 40 #include <net/if_arp.h> 41 #include <net/ethernet.h> 42 #include <net/if_dl.h> 43 #include <net/if_media.h> 44 #include <net/if_types.h> 45 46 #ifdef INET 47 #include <netinet/in.h> 48 #include <netinet/in_systm.h> 49 #include <netinet/in_var.h> 50 #include <netinet/if_ether.h> 51 #include <netinet/ip.h> 52 #endif 53 54 #include <net80211/ieee80211_var.h> 55 #include <net80211/ieee80211_regdomain.h> 56 #include <net80211/ieee80211_radiotap.h> 57 58 #include <dev/usb/usb.h> 59 #include <dev/usb/usbdi.h> 60 #include "usbdevs.h" 61 62 #include <dev/usb/wlan/if_urtwreg.h> 63 #include <dev/usb/wlan/if_urtwvar.h> 64 65 static SYSCTL_NODE(_hw_usb, OID_AUTO, urtw, CTLFLAG_RW, 0, "USB Realtek 8187L"); 66 #ifdef URTW_DEBUG 67 int urtw_debug = 0; 68 SYSCTL_INT(_hw_usb_urtw, OID_AUTO, debug, CTLFLAG_RW | CTLFLAG_TUN, &urtw_debug, 0, 69 "control debugging printfs"); 70 TUNABLE_INT("hw.usb.urtw.debug", &urtw_debug); 71 enum { 72 URTW_DEBUG_XMIT = 0x00000001, /* basic xmit operation */ 73 URTW_DEBUG_RECV = 0x00000002, /* basic recv operation */ 74 URTW_DEBUG_RESET = 0x00000004, /* reset processing */ 75 URTW_DEBUG_TX_PROC = 0x00000008, /* tx ISR proc */ 76 URTW_DEBUG_RX_PROC = 0x00000010, /* rx ISR proc */ 77 URTW_DEBUG_STATE = 0x00000020, /* 802.11 state transitions */ 78 URTW_DEBUG_STAT = 0x00000040, /* statistic */ 79 URTW_DEBUG_INIT = 0x00000080, /* initialization of dev */ 80 URTW_DEBUG_TXSTATUS = 0x00000100, /* tx status */ 81 URTW_DEBUG_ANY = 0xffffffff 82 }; 83 #define DPRINTF(sc, m, fmt, ...) do { \ 84 if (sc->sc_debug & (m)) \ 85 printf(fmt, __VA_ARGS__); \ 86 } while (0) 87 #else 88 #define DPRINTF(sc, m, fmt, ...) do { \ 89 (void) sc; \ 90 } while (0) 91 #endif 92 static int urtw_preamble_mode = URTW_PREAMBLE_MODE_LONG; 93 SYSCTL_INT(_hw_usb_urtw, OID_AUTO, preamble_mode, CTLFLAG_RW | CTLFLAG_TUN, 94 &urtw_preamble_mode, 0, "set the preable mode (long or short)"); 95 TUNABLE_INT("hw.usb.urtw.preamble_mode", &urtw_preamble_mode); 96 97 /* recognized device vendors/products */ 98 #define urtw_lookup(v, p) \ 99 ((const struct urtw_type *)usb_lookup(urtw_devs, v, p)) 100 #define URTW_DEV_B(v,p) \ 101 { USB_VPI(USB_VENDOR_##v, USB_PRODUCT_##v##_##p, URTW_REV_RTL8187B) } 102 #define URTW_DEV_L(v,p) \ 103 { USB_VPI(USB_VENDOR_##v, USB_PRODUCT_##v##_##p, URTW_REV_RTL8187L) } 104 #define URTW_REV_RTL8187B 0 105 #define URTW_REV_RTL8187L 1 106 static const STRUCT_USB_HOST_ID urtw_devs[] = { 107 URTW_DEV_B(NETGEAR, WG111V3), 108 URTW_DEV_B(REALTEK, RTL8187B_0), 109 URTW_DEV_B(REALTEK, RTL8187B_1), 110 URTW_DEV_B(REALTEK, RTL8187B_2), 111 URTW_DEV_B(SITECOMEU, WL168V4), 112 URTW_DEV_L(ASUS, P5B_WIFI), 113 URTW_DEV_L(BELKIN, F5D7050E), 114 URTW_DEV_L(LINKSYS4, WUSB54GCV2), 115 URTW_DEV_L(NETGEAR, WG111V2), 116 URTW_DEV_L(REALTEK, RTL8187), 117 URTW_DEV_L(SITECOMEU, WL168V1), 118 URTW_DEV_L(SURECOM, EP9001G2A), 119 { USB_VPI(USB_VENDOR_OVISLINK, 0x8187, URTW_REV_RTL8187L) }, 120 { USB_VPI(USB_VENDOR_DICKSMITH, 0x9401, URTW_REV_RTL8187L) }, 121 { USB_VPI(USB_VENDOR_HP, 0xca02, URTW_REV_RTL8187L) }, 122 { USB_VPI(USB_VENDOR_LOGITEC, 0x010c, URTW_REV_RTL8187L) }, 123 { USB_VPI(USB_VENDOR_NETGEAR, 0x6100, URTW_REV_RTL8187L) }, 124 { USB_VPI(USB_VENDOR_SPHAIRON, 0x0150, URTW_REV_RTL8187L) }, 125 { USB_VPI(USB_VENDOR_QCOM, 0x6232, URTW_REV_RTL8187L) }, 126 #undef URTW_DEV_L 127 #undef URTW_DEV_B 128 }; 129 130 #define urtw_read8_m(sc, val, data) do { \ 131 error = urtw_read8_c(sc, val, data); \ 132 if (error != 0) \ 133 goto fail; \ 134 } while (0) 135 #define urtw_write8_m(sc, val, data) do { \ 136 error = urtw_write8_c(sc, val, data); \ 137 if (error != 0) \ 138 goto fail; \ 139 } while (0) 140 #define urtw_read16_m(sc, val, data) do { \ 141 error = urtw_read16_c(sc, val, data); \ 142 if (error != 0) \ 143 goto fail; \ 144 } while (0) 145 #define urtw_write16_m(sc, val, data) do { \ 146 error = urtw_write16_c(sc, val, data); \ 147 if (error != 0) \ 148 goto fail; \ 149 } while (0) 150 #define urtw_read32_m(sc, val, data) do { \ 151 error = urtw_read32_c(sc, val, data); \ 152 if (error != 0) \ 153 goto fail; \ 154 } while (0) 155 #define urtw_write32_m(sc, val, data) do { \ 156 error = urtw_write32_c(sc, val, data); \ 157 if (error != 0) \ 158 goto fail; \ 159 } while (0) 160 #define urtw_8187_write_phy_ofdm(sc, val, data) do { \ 161 error = urtw_8187_write_phy_ofdm_c(sc, val, data); \ 162 if (error != 0) \ 163 goto fail; \ 164 } while (0) 165 #define urtw_8187_write_phy_cck(sc, val, data) do { \ 166 error = urtw_8187_write_phy_cck_c(sc, val, data); \ 167 if (error != 0) \ 168 goto fail; \ 169 } while (0) 170 #define urtw_8225_write(sc, val, data) do { \ 171 error = urtw_8225_write_c(sc, val, data); \ 172 if (error != 0) \ 173 goto fail; \ 174 } while (0) 175 176 struct urtw_pair { 177 uint32_t reg; 178 uint32_t val; 179 }; 180 181 static uint8_t urtw_8225_agc[] = { 182 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9d, 0x9c, 0x9b, 183 0x9a, 0x99, 0x98, 0x97, 0x96, 0x95, 0x94, 0x93, 0x92, 0x91, 0x90, 184 0x8f, 0x8e, 0x8d, 0x8c, 0x8b, 0x8a, 0x89, 0x88, 0x87, 0x86, 0x85, 185 0x84, 0x83, 0x82, 0x81, 0x80, 0x3f, 0x3e, 0x3d, 0x3c, 0x3b, 0x3a, 186 0x39, 0x38, 0x37, 0x36, 0x35, 0x34, 0x33, 0x32, 0x31, 0x30, 0x2f, 187 0x2e, 0x2d, 0x2c, 0x2b, 0x2a, 0x29, 0x28, 0x27, 0x26, 0x25, 0x24, 188 0x23, 0x22, 0x21, 0x20, 0x1f, 0x1e, 0x1d, 0x1c, 0x1b, 0x1a, 0x19, 189 0x18, 0x17, 0x16, 0x15, 0x14, 0x13, 0x12, 0x11, 0x10, 0x0f, 0x0e, 190 0x0d, 0x0c, 0x0b, 0x0a, 0x09, 0x08, 0x07, 0x06, 0x05, 0x04, 0x03, 191 0x02, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 192 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 193 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01 194 }; 195 196 static uint8_t urtw_8225z2_agc[] = { 197 0x5e, 0x5e, 0x5e, 0x5e, 0x5d, 0x5b, 0x59, 0x57, 0x55, 0x53, 0x51, 198 0x4f, 0x4d, 0x4b, 0x49, 0x47, 0x45, 0x43, 0x41, 0x3f, 0x3d, 0x3b, 199 0x39, 0x37, 0x35, 0x33, 0x31, 0x2f, 0x2d, 0x2b, 0x29, 0x27, 0x25, 200 0x23, 0x21, 0x1f, 0x1d, 0x1b, 0x19, 0x17, 0x15, 0x13, 0x11, 0x0f, 201 0x0d, 0x0b, 0x09, 0x07, 0x05, 0x03, 0x01, 0x01, 0x01, 0x01, 0x01, 202 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x19, 0x19, 203 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x19, 0x20, 0x21, 0x22, 0x23, 204 0x24, 0x25, 0x26, 0x26, 0x27, 0x27, 0x28, 0x28, 0x29, 0x2a, 0x2a, 205 0x2a, 0x2b, 0x2b, 0x2b, 0x2c, 0x2c, 0x2c, 0x2d, 0x2d, 0x2d, 0x2d, 206 0x2e, 0x2e, 0x2e, 0x2e, 0x2f, 0x2f, 0x2f, 0x30, 0x30, 0x31, 0x31, 207 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 208 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31 209 }; 210 211 static uint32_t urtw_8225_channel[] = { 212 0x0000, /* dummy channel 0 */ 213 0x085c, /* 1 */ 214 0x08dc, /* 2 */ 215 0x095c, /* 3 */ 216 0x09dc, /* 4 */ 217 0x0a5c, /* 5 */ 218 0x0adc, /* 6 */ 219 0x0b5c, /* 7 */ 220 0x0bdc, /* 8 */ 221 0x0c5c, /* 9 */ 222 0x0cdc, /* 10 */ 223 0x0d5c, /* 11 */ 224 0x0ddc, /* 12 */ 225 0x0e5c, /* 13 */ 226 0x0f72, /* 14 */ 227 }; 228 229 static uint8_t urtw_8225_gain[] = { 230 0x23, 0x88, 0x7c, 0xa5, /* -82dbm */ 231 0x23, 0x88, 0x7c, 0xb5, /* -82dbm */ 232 0x23, 0x88, 0x7c, 0xc5, /* -82dbm */ 233 0x33, 0x80, 0x79, 0xc5, /* -78dbm */ 234 0x43, 0x78, 0x76, 0xc5, /* -74dbm */ 235 0x53, 0x60, 0x73, 0xc5, /* -70dbm */ 236 0x63, 0x58, 0x70, 0xc5, /* -66dbm */ 237 }; 238 239 static struct urtw_pair urtw_8225_rf_part1[] = { 240 { 0x00, 0x0067 }, { 0x01, 0x0fe0 }, { 0x02, 0x044d }, { 0x03, 0x0441 }, 241 { 0x04, 0x0486 }, { 0x05, 0x0bc0 }, { 0x06, 0x0ae6 }, { 0x07, 0x082a }, 242 { 0x08, 0x001f }, { 0x09, 0x0334 }, { 0x0a, 0x0fd4 }, { 0x0b, 0x0391 }, 243 { 0x0c, 0x0050 }, { 0x0d, 0x06db }, { 0x0e, 0x0029 }, { 0x0f, 0x0914 }, 244 }; 245 246 static struct urtw_pair urtw_8225_rf_part2[] = { 247 { 0x00, 0x01 }, { 0x01, 0x02 }, { 0x02, 0x42 }, { 0x03, 0x00 }, 248 { 0x04, 0x00 }, { 0x05, 0x00 }, { 0x06, 0x40 }, { 0x07, 0x00 }, 249 { 0x08, 0x40 }, { 0x09, 0xfe }, { 0x0a, 0x09 }, { 0x0b, 0x80 }, 250 { 0x0c, 0x01 }, { 0x0e, 0xd3 }, { 0x0f, 0x38 }, { 0x10, 0x84 }, 251 { 0x11, 0x06 }, { 0x12, 0x20 }, { 0x13, 0x20 }, { 0x14, 0x00 }, 252 { 0x15, 0x40 }, { 0x16, 0x00 }, { 0x17, 0x40 }, { 0x18, 0xef }, 253 { 0x19, 0x19 }, { 0x1a, 0x20 }, { 0x1b, 0x76 }, { 0x1c, 0x04 }, 254 { 0x1e, 0x95 }, { 0x1f, 0x75 }, { 0x20, 0x1f }, { 0x21, 0x27 }, 255 { 0x22, 0x16 }, { 0x24, 0x46 }, { 0x25, 0x20 }, { 0x26, 0x90 }, 256 { 0x27, 0x88 } 257 }; 258 259 static struct urtw_pair urtw_8225_rf_part3[] = { 260 { 0x00, 0x98 }, { 0x03, 0x20 }, { 0x04, 0x7e }, { 0x05, 0x12 }, 261 { 0x06, 0xfc }, { 0x07, 0x78 }, { 0x08, 0x2e }, { 0x10, 0x9b }, 262 { 0x11, 0x88 }, { 0x12, 0x47 }, { 0x13, 0xd0 }, { 0x19, 0x00 }, 263 { 0x1a, 0xa0 }, { 0x1b, 0x08 }, { 0x40, 0x86 }, { 0x41, 0x8d }, 264 { 0x42, 0x15 }, { 0x43, 0x18 }, { 0x44, 0x1f }, { 0x45, 0x1e }, 265 { 0x46, 0x1a }, { 0x47, 0x15 }, { 0x48, 0x10 }, { 0x49, 0x0a }, 266 { 0x4a, 0x05 }, { 0x4b, 0x02 }, { 0x4c, 0x05 } 267 }; 268 269 static uint16_t urtw_8225_rxgain[] = { 270 0x0400, 0x0401, 0x0402, 0x0403, 0x0404, 0x0405, 0x0408, 0x0409, 271 0x040a, 0x040b, 0x0502, 0x0503, 0x0504, 0x0505, 0x0540, 0x0541, 272 0x0542, 0x0543, 0x0544, 0x0545, 0x0580, 0x0581, 0x0582, 0x0583, 273 0x0584, 0x0585, 0x0588, 0x0589, 0x058a, 0x058b, 0x0643, 0x0644, 274 0x0645, 0x0680, 0x0681, 0x0682, 0x0683, 0x0684, 0x0685, 0x0688, 275 0x0689, 0x068a, 0x068b, 0x068c, 0x0742, 0x0743, 0x0744, 0x0745, 276 0x0780, 0x0781, 0x0782, 0x0783, 0x0784, 0x0785, 0x0788, 0x0789, 277 0x078a, 0x078b, 0x078c, 0x078d, 0x0790, 0x0791, 0x0792, 0x0793, 278 0x0794, 0x0795, 0x0798, 0x0799, 0x079a, 0x079b, 0x079c, 0x079d, 279 0x07a0, 0x07a1, 0x07a2, 0x07a3, 0x07a4, 0x07a5, 0x07a8, 0x07a9, 280 0x07aa, 0x07ab, 0x07ac, 0x07ad, 0x07b0, 0x07b1, 0x07b2, 0x07b3, 281 0x07b4, 0x07b5, 0x07b8, 0x07b9, 0x07ba, 0x07bb, 0x07bb 282 }; 283 284 static uint8_t urtw_8225_threshold[] = { 285 0x8d, 0x8d, 0x8d, 0x8d, 0x9d, 0xad, 0xbd, 286 }; 287 288 static uint8_t urtw_8225_tx_gain_cck_ofdm[] = { 289 0x02, 0x06, 0x0e, 0x1e, 0x3e, 0x7e 290 }; 291 292 static uint8_t urtw_8225_txpwr_cck[] = { 293 0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02, 294 0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02, 295 0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02, 296 0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02, 297 0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03, 298 0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03 299 }; 300 301 static uint8_t urtw_8225_txpwr_cck_ch14[] = { 302 0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00, 303 0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00, 304 0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00, 305 0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00, 306 0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00, 307 0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00 308 }; 309 310 static uint8_t urtw_8225_txpwr_ofdm[]={ 311 0x80, 0x90, 0xa2, 0xb5, 0xcb, 0xe4 312 }; 313 314 static uint8_t urtw_8225v2_gain_bg[]={ 315 0x23, 0x15, 0xa5, /* -82-1dbm */ 316 0x23, 0x15, 0xb5, /* -82-2dbm */ 317 0x23, 0x15, 0xc5, /* -82-3dbm */ 318 0x33, 0x15, 0xc5, /* -78dbm */ 319 0x43, 0x15, 0xc5, /* -74dbm */ 320 0x53, 0x15, 0xc5, /* -70dbm */ 321 0x63, 0x15, 0xc5, /* -66dbm */ 322 }; 323 324 static struct urtw_pair urtw_8225v2_rf_part1[] = { 325 { 0x00, 0x02bf }, { 0x01, 0x0ee0 }, { 0x02, 0x044d }, { 0x03, 0x0441 }, 326 { 0x04, 0x08c3 }, { 0x05, 0x0c72 }, { 0x06, 0x00e6 }, { 0x07, 0x082a }, 327 { 0x08, 0x003f }, { 0x09, 0x0335 }, { 0x0a, 0x09d4 }, { 0x0b, 0x07bb }, 328 { 0x0c, 0x0850 }, { 0x0d, 0x0cdf }, { 0x0e, 0x002b }, { 0x0f, 0x0114 } 329 }; 330 331 static struct urtw_pair urtw_8225v2b_rf_part0[] = { 332 { 0x00, 0x00b7 }, { 0x01, 0x0ee0 }, { 0x02, 0x044d }, { 0x03, 0x0441 }, 333 { 0x04, 0x08c3 }, { 0x05, 0x0c72 }, { 0x06, 0x00e6 }, { 0x07, 0x082a }, 334 { 0x08, 0x003f }, { 0x09, 0x0335 }, { 0x0a, 0x09d4 }, { 0x0b, 0x07bb }, 335 { 0x0c, 0x0850 }, { 0x0d, 0x0cdf }, { 0x0e, 0x002b }, { 0x0f, 0x0114 } 336 }; 337 338 static struct urtw_pair urtw_8225v2b_rf_part1[] = { 339 {0x0f0, 0x32}, {0x0f1, 0x32}, {0x0f2, 0x00}, 340 {0x0f3, 0x00}, {0x0f4, 0x32}, {0x0f5, 0x43}, 341 {0x0f6, 0x00}, {0x0f7, 0x00}, {0x0f8, 0x46}, 342 {0x0f9, 0xa4}, {0x0fa, 0x00}, {0x0fb, 0x00}, 343 {0x0fc, 0x96}, {0x0fd, 0xa4}, {0x0fe, 0x00}, 344 {0x0ff, 0x00}, {0x158, 0x4b}, {0x159, 0x00}, 345 {0x15a, 0x4b}, {0x15b, 0x00}, {0x160, 0x4b}, 346 {0x161, 0x09}, {0x162, 0x4b}, {0x163, 0x09}, 347 {0x1ce, 0x0f}, {0x1cf, 0x00}, {0x1e0, 0xff}, 348 {0x1e1, 0x0f}, {0x1e2, 0x00}, {0x1f0, 0x4e}, 349 {0x1f1, 0x01}, {0x1f2, 0x02}, {0x1f3, 0x03}, 350 {0x1f4, 0x04}, {0x1f5, 0x05}, {0x1f6, 0x06}, 351 {0x1f7, 0x07}, {0x1f8, 0x08}, {0x24e, 0x00}, 352 {0x20c, 0x04}, {0x221, 0x61}, {0x222, 0x68}, 353 {0x223, 0x6f}, {0x224, 0x76}, {0x225, 0x7d}, 354 {0x226, 0x84}, {0x227, 0x8d}, {0x24d, 0x08}, 355 {0x250, 0x05}, {0x251, 0xf5}, {0x252, 0x04}, 356 {0x253, 0xa0}, {0x254, 0x1f}, {0x255, 0x23}, 357 {0x256, 0x45}, {0x257, 0x67}, {0x258, 0x08}, 358 {0x259, 0x08}, {0x25a, 0x08}, {0x25b, 0x08}, 359 {0x260, 0x08}, {0x261, 0x08}, {0x262, 0x08}, 360 {0x263, 0x08}, {0x264, 0xcf}, {0x272, 0x56}, 361 {0x273, 0x9a}, {0x034, 0xf0}, {0x035, 0x0f}, 362 {0x05b, 0x40}, {0x084, 0x88}, {0x085, 0x24}, 363 {0x088, 0x54}, {0x08b, 0xb8}, {0x08c, 0x07}, 364 {0x08d, 0x00}, {0x094, 0x1b}, {0x095, 0x12}, 365 {0x096, 0x00}, {0x097, 0x06}, {0x09d, 0x1a}, 366 {0x09f, 0x10}, {0x0b4, 0x22}, {0x0be, 0x80}, 367 {0x0db, 0x00}, {0x0ee, 0x00}, {0x091, 0x03}, 368 {0x24c, 0x00}, {0x39f, 0x00}, {0x08c, 0x01}, 369 {0x08d, 0x10}, {0x08e, 0x08}, {0x08f, 0x00} 370 }; 371 372 static struct urtw_pair urtw_8225v2_rf_part2[] = { 373 { 0x00, 0x01 }, { 0x01, 0x02 }, { 0x02, 0x42 }, { 0x03, 0x00 }, 374 { 0x04, 0x00 }, { 0x05, 0x00 }, { 0x06, 0x40 }, { 0x07, 0x00 }, 375 { 0x08, 0x40 }, { 0x09, 0xfe }, { 0x0a, 0x08 }, { 0x0b, 0x80 }, 376 { 0x0c, 0x01 }, { 0x0d, 0x43 }, { 0x0e, 0xd3 }, { 0x0f, 0x38 }, 377 { 0x10, 0x84 }, { 0x11, 0x07 }, { 0x12, 0x20 }, { 0x13, 0x20 }, 378 { 0x14, 0x00 }, { 0x15, 0x40 }, { 0x16, 0x00 }, { 0x17, 0x40 }, 379 { 0x18, 0xef }, { 0x19, 0x19 }, { 0x1a, 0x20 }, { 0x1b, 0x15 }, 380 { 0x1c, 0x04 }, { 0x1d, 0xc5 }, { 0x1e, 0x95 }, { 0x1f, 0x75 }, 381 { 0x20, 0x1f }, { 0x21, 0x17 }, { 0x22, 0x16 }, { 0x23, 0x80 }, 382 { 0x24, 0x46 }, { 0x25, 0x00 }, { 0x26, 0x90 }, { 0x27, 0x88 } 383 }; 384 385 static struct urtw_pair urtw_8225v2b_rf_part2[] = { 386 { 0x00, 0x10 }, { 0x01, 0x0d }, { 0x02, 0x01 }, { 0x03, 0x00 }, 387 { 0x04, 0x14 }, { 0x05, 0xfb }, { 0x06, 0xfb }, { 0x07, 0x60 }, 388 { 0x08, 0x00 }, { 0x09, 0x60 }, { 0x0a, 0x00 }, { 0x0b, 0x00 }, 389 { 0x0c, 0x00 }, { 0x0d, 0x5c }, { 0x0e, 0x00 }, { 0x0f, 0x00 }, 390 { 0x10, 0x40 }, { 0x11, 0x00 }, { 0x12, 0x40 }, { 0x13, 0x00 }, 391 { 0x14, 0x00 }, { 0x15, 0x00 }, { 0x16, 0xa8 }, { 0x17, 0x26 }, 392 { 0x18, 0x32 }, { 0x19, 0x33 }, { 0x1a, 0x07 }, { 0x1b, 0xa5 }, 393 { 0x1c, 0x6f }, { 0x1d, 0x55 }, { 0x1e, 0xc8 }, { 0x1f, 0xb3 }, 394 { 0x20, 0x0a }, { 0x21, 0xe1 }, { 0x22, 0x2C }, { 0x23, 0x8a }, 395 { 0x24, 0x86 }, { 0x25, 0x83 }, { 0x26, 0x34 }, { 0x27, 0x0f }, 396 { 0x28, 0x4f }, { 0x29, 0x24 }, { 0x2a, 0x6f }, { 0x2b, 0xc2 }, 397 { 0x2c, 0x6b }, { 0x2d, 0x40 }, { 0x2e, 0x80 }, { 0x2f, 0x00 }, 398 { 0x30, 0xc0 }, { 0x31, 0xc1 }, { 0x32, 0x58 }, { 0x33, 0xf1 }, 399 { 0x34, 0x00 }, { 0x35, 0xe4 }, { 0x36, 0x90 }, { 0x37, 0x3e }, 400 { 0x38, 0x6d }, { 0x39, 0x3c }, { 0x3a, 0xfb }, { 0x3b, 0x07 } 401 }; 402 403 static struct urtw_pair urtw_8225v2_rf_part3[] = { 404 { 0x00, 0x98 }, { 0x03, 0x20 }, { 0x04, 0x7e }, { 0x05, 0x12 }, 405 { 0x06, 0xfc }, { 0x07, 0x78 }, { 0x08, 0x2e }, { 0x09, 0x11 }, 406 { 0x0a, 0x17 }, { 0x0b, 0x11 }, { 0x10, 0x9b }, { 0x11, 0x88 }, 407 { 0x12, 0x47 }, { 0x13, 0xd0 }, { 0x19, 0x00 }, { 0x1a, 0xa0 }, 408 { 0x1b, 0x08 }, { 0x1d, 0x00 }, { 0x40, 0x86 }, { 0x41, 0x9d }, 409 { 0x42, 0x15 }, { 0x43, 0x18 }, { 0x44, 0x36 }, { 0x45, 0x35 }, 410 { 0x46, 0x2e }, { 0x47, 0x25 }, { 0x48, 0x1c }, { 0x49, 0x12 }, 411 { 0x4a, 0x09 }, { 0x4b, 0x04 }, { 0x4c, 0x05 } 412 }; 413 414 static uint16_t urtw_8225v2_rxgain[] = { 415 0x0000, 0x0001, 0x0002, 0x0003, 0x0004, 0x0005, 0x0008, 0x0009, 416 0x000a, 0x000b, 0x0102, 0x0103, 0x0104, 0x0105, 0x0140, 0x0141, 417 0x0142, 0x0143, 0x0144, 0x0145, 0x0180, 0x0181, 0x0182, 0x0183, 418 0x0184, 0x0185, 0x0188, 0x0189, 0x018a, 0x018b, 0x0243, 0x0244, 419 0x0245, 0x0280, 0x0281, 0x0282, 0x0283, 0x0284, 0x0285, 0x0288, 420 0x0289, 0x028a, 0x028b, 0x028c, 0x0342, 0x0343, 0x0344, 0x0345, 421 0x0380, 0x0381, 0x0382, 0x0383, 0x0384, 0x0385, 0x0388, 0x0389, 422 0x038a, 0x038b, 0x038c, 0x038d, 0x0390, 0x0391, 0x0392, 0x0393, 423 0x0394, 0x0395, 0x0398, 0x0399, 0x039a, 0x039b, 0x039c, 0x039d, 424 0x03a0, 0x03a1, 0x03a2, 0x03a3, 0x03a4, 0x03a5, 0x03a8, 0x03a9, 425 0x03aa, 0x03ab, 0x03ac, 0x03ad, 0x03b0, 0x03b1, 0x03b2, 0x03b3, 426 0x03b4, 0x03b5, 0x03b8, 0x03b9, 0x03ba, 0x03bb, 0x03bb 427 }; 428 429 static uint16_t urtw_8225v2b_rxgain[] = { 430 0x0400, 0x0401, 0x0402, 0x0403, 0x0404, 0x0405, 0x0408, 0x0409, 431 0x040a, 0x040b, 0x0502, 0x0503, 0x0504, 0x0505, 0x0540, 0x0541, 432 0x0542, 0x0543, 0x0544, 0x0545, 0x0580, 0x0581, 0x0582, 0x0583, 433 0x0584, 0x0585, 0x0588, 0x0589, 0x058a, 0x058b, 0x0643, 0x0644, 434 0x0645, 0x0680, 0x0681, 0x0682, 0x0683, 0x0684, 0x0685, 0x0688, 435 0x0689, 0x068a, 0x068b, 0x068c, 0x0742, 0x0743, 0x0744, 0x0745, 436 0x0780, 0x0781, 0x0782, 0x0783, 0x0784, 0x0785, 0x0788, 0x0789, 437 0x078a, 0x078b, 0x078c, 0x078d, 0x0790, 0x0791, 0x0792, 0x0793, 438 0x0794, 0x0795, 0x0798, 0x0799, 0x079a, 0x079b, 0x079c, 0x079d, 439 0x07a0, 0x07a1, 0x07a2, 0x07a3, 0x07a4, 0x07a5, 0x07a8, 0x07a9, 440 0x03aa, 0x03ab, 0x03ac, 0x03ad, 0x03b0, 0x03b1, 0x03b2, 0x03b3, 441 0x03b4, 0x03b5, 0x03b8, 0x03b9, 0x03ba, 0x03bb, 0x03bb 442 }; 443 444 static uint8_t urtw_8225v2_tx_gain_cck_ofdm[] = { 445 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 446 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 447 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 448 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 449 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 450 0x1e, 0x1f, 0x20, 0x21, 0x22, 0x23, 451 }; 452 453 static uint8_t urtw_8225v2_txpwr_cck[] = { 454 0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04 455 }; 456 457 static uint8_t urtw_8225v2_txpwr_cck_ch14[] = { 458 0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00 459 }; 460 461 static uint8_t urtw_8225v2b_txpwr_cck[] = { 462 0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04, 463 0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03, 464 0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03, 465 0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03 466 }; 467 468 static uint8_t urtw_8225v2b_txpwr_cck_ch14[] = { 469 0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00, 470 0x30, 0x2f, 0x29, 0x15, 0x00, 0x00, 0x00, 0x00, 471 0x30, 0x2f, 0x29, 0x15, 0x00, 0x00, 0x00, 0x00, 472 0x30, 0x2f, 0x29, 0x15, 0x00, 0x00, 0x00, 0x00 473 }; 474 475 static struct urtw_pair urtw_ratetable[] = { 476 { 2, 0 }, { 4, 1 }, { 11, 2 }, { 12, 4 }, { 18, 5 }, 477 { 22, 3 }, { 24, 6 }, { 36, 7 }, { 48, 8 }, { 72, 9 }, 478 { 96, 10 }, { 108, 11 } 479 }; 480 481 #if 0 482 static const uint8_t urtw_8187b_reg_table[][3] = { 483 { 0xf0, 0x32, 0 }, { 0xf1, 0x32, 0 }, { 0xf2, 0x00, 0 }, 484 { 0xf3, 0x00, 0 }, { 0xf4, 0x32, 0 }, { 0xf5, 0x43, 0 }, 485 { 0xf6, 0x00, 0 }, { 0xf7, 0x00, 0 }, { 0xf8, 0x46, 0 }, 486 { 0xf9, 0xa4, 0 }, { 0xfa, 0x00, 0 }, { 0xfb, 0x00, 0 }, 487 { 0xfc, 0x96, 0 }, { 0xfd, 0xa4, 0 }, { 0xfe, 0x00, 0 }, 488 { 0xff, 0x00, 0 }, { 0x58, 0x4b, 1 }, { 0x59, 0x00, 1 }, 489 { 0x5a, 0x4b, 1 }, { 0x5b, 0x00, 1 }, { 0x60, 0x4b, 1 }, 490 { 0x61, 0x09, 1 }, { 0x62, 0x4b, 1 }, { 0x63, 0x09, 1 }, 491 { 0xce, 0x0f, 1 }, { 0xcf, 0x00, 1 }, { 0xe0, 0xff, 1 }, 492 { 0xe1, 0x0f, 1 }, { 0xe2, 0x00, 1 }, { 0xf0, 0x4e, 1 }, 493 { 0xf1, 0x01, 1 }, { 0xf2, 0x02, 1 }, { 0xf3, 0x03, 1 }, 494 { 0xf4, 0x04, 1 }, { 0xf5, 0x05, 1 }, { 0xf6, 0x06, 1 }, 495 { 0xf7, 0x07, 1 }, { 0xf8, 0x08, 1 }, { 0x4e, 0x00, 2 }, 496 { 0x0c, 0x04, 2 }, { 0x21, 0x61, 2 }, { 0x22, 0x68, 2 }, 497 { 0x23, 0x6f, 2 }, { 0x24, 0x76, 2 }, { 0x25, 0x7d, 2 }, 498 { 0x26, 0x84, 2 }, { 0x27, 0x8d, 2 }, { 0x4d, 0x08, 2 }, 499 { 0x50, 0x05, 2 }, { 0x51, 0xf5, 2 }, { 0x52, 0x04, 2 }, 500 { 0x53, 0xa0, 2 }, { 0x54, 0x1f, 2 }, { 0x55, 0x23, 2 }, 501 { 0x56, 0x45, 2 }, { 0x57, 0x67, 2 }, { 0x58, 0x08, 2 }, 502 { 0x59, 0x08, 2 }, { 0x5a, 0x08, 2 }, { 0x5b, 0x08, 2 }, 503 { 0x60, 0x08, 2 }, { 0x61, 0x08, 2 }, { 0x62, 0x08, 2 }, 504 { 0x63, 0x08, 2 }, { 0x64, 0xcf, 2 }, { 0x72, 0x56, 2 }, 505 { 0x73, 0x9a, 2 }, { 0x34, 0xf0, 0 }, { 0x35, 0x0f, 0 }, 506 { 0x5b, 0x40, 0 }, { 0x84, 0x88, 0 }, { 0x85, 0x24, 0 }, 507 { 0x88, 0x54, 0 }, { 0x8b, 0xb8, 0 }, { 0x8c, 0x07, 0 }, 508 { 0x8d, 0x00, 0 }, { 0x94, 0x1b, 0 }, { 0x95, 0x12, 0 }, 509 { 0x96, 0x00, 0 }, { 0x97, 0x06, 0 }, { 0x9d, 0x1a, 0 }, 510 { 0x9f, 0x10, 0 }, { 0xb4, 0x22, 0 }, { 0xbe, 0x80, 0 }, 511 { 0xdb, 0x00, 0 }, { 0xee, 0x00, 0 }, { 0x91, 0x03, 0 }, 512 { 0x4c, 0x00, 2 }, { 0x9f, 0x00, 3 }, { 0x8c, 0x01, 0 }, 513 { 0x8d, 0x10, 0 }, { 0x8e, 0x08, 0 }, { 0x8f, 0x00, 0 } 514 }; 515 #endif 516 517 static usb_callback_t urtw_bulk_rx_callback; 518 static usb_callback_t urtw_bulk_tx_callback; 519 static usb_callback_t urtw_bulk_tx_status_callback; 520 521 static const struct usb_config urtw_8187b_usbconfig[URTW_8187B_N_XFERS] = { 522 [URTW_8187B_BULK_RX] = { 523 .type = UE_BULK, 524 .endpoint = 0x83, 525 .direction = UE_DIR_IN, 526 .bufsize = MCLBYTES, 527 .flags = { 528 .ext_buffer = 1, 529 .pipe_bof = 1, 530 .short_xfer_ok = 1 531 }, 532 .callback = urtw_bulk_rx_callback 533 }, 534 [URTW_8187B_BULK_TX_STATUS] = { 535 .type = UE_BULK, 536 .endpoint = 0x89, 537 .direction = UE_DIR_IN, 538 .bufsize = sizeof(uint64_t), 539 .flags = { 540 .pipe_bof = 1, 541 .short_xfer_ok = 1 542 }, 543 .callback = urtw_bulk_tx_status_callback 544 }, 545 [URTW_8187B_BULK_TX_BE] = { 546 .type = UE_BULK, 547 .endpoint = URTW_8187B_TXPIPE_BE, 548 .direction = UE_DIR_OUT, 549 .bufsize = URTW_TX_MAXSIZE * URTW_TX_DATA_LIST_COUNT, 550 .flags = { 551 .force_short_xfer = 1, 552 .pipe_bof = 1, 553 }, 554 .callback = urtw_bulk_tx_callback, 555 .timeout = URTW_DATA_TIMEOUT 556 }, 557 [URTW_8187B_BULK_TX_BK] = { 558 .type = UE_BULK, 559 .endpoint = URTW_8187B_TXPIPE_BK, 560 .direction = UE_DIR_OUT, 561 .bufsize = URTW_TX_MAXSIZE, 562 .flags = { 563 .ext_buffer = 1, 564 .force_short_xfer = 1, 565 .pipe_bof = 1, 566 }, 567 .callback = urtw_bulk_tx_callback, 568 .timeout = URTW_DATA_TIMEOUT 569 }, 570 [URTW_8187B_BULK_TX_VI] = { 571 .type = UE_BULK, 572 .endpoint = URTW_8187B_TXPIPE_VI, 573 .direction = UE_DIR_OUT, 574 .bufsize = URTW_TX_MAXSIZE, 575 .flags = { 576 .ext_buffer = 1, 577 .force_short_xfer = 1, 578 .pipe_bof = 1, 579 }, 580 .callback = urtw_bulk_tx_callback, 581 .timeout = URTW_DATA_TIMEOUT 582 }, 583 [URTW_8187B_BULK_TX_VO] = { 584 .type = UE_BULK, 585 .endpoint = URTW_8187B_TXPIPE_VO, 586 .direction = UE_DIR_OUT, 587 .bufsize = URTW_TX_MAXSIZE, 588 .flags = { 589 .ext_buffer = 1, 590 .force_short_xfer = 1, 591 .pipe_bof = 1, 592 }, 593 .callback = urtw_bulk_tx_callback, 594 .timeout = URTW_DATA_TIMEOUT 595 }, 596 [URTW_8187B_BULK_TX_EP12] = { 597 .type = UE_BULK, 598 .endpoint = 0xc, 599 .direction = UE_DIR_OUT, 600 .bufsize = URTW_TX_MAXSIZE, 601 .flags = { 602 .ext_buffer = 1, 603 .force_short_xfer = 1, 604 .pipe_bof = 1, 605 }, 606 .callback = urtw_bulk_tx_callback, 607 .timeout = URTW_DATA_TIMEOUT 608 } 609 }; 610 611 static const struct usb_config urtw_8187l_usbconfig[URTW_8187L_N_XFERS] = { 612 [URTW_8187L_BULK_RX] = { 613 .type = UE_BULK, 614 .endpoint = 0x81, 615 .direction = UE_DIR_IN, 616 .bufsize = MCLBYTES, 617 .flags = { 618 .ext_buffer = 1, 619 .pipe_bof = 1, 620 .short_xfer_ok = 1 621 }, 622 .callback = urtw_bulk_rx_callback 623 }, 624 [URTW_8187L_BULK_TX_LOW] = { 625 .type = UE_BULK, 626 .endpoint = 0x2, 627 .direction = UE_DIR_OUT, 628 .bufsize = URTW_TX_MAXSIZE * URTW_TX_DATA_LIST_COUNT, 629 .flags = { 630 .force_short_xfer = 1, 631 .pipe_bof = 1, 632 }, 633 .callback = urtw_bulk_tx_callback, 634 .timeout = URTW_DATA_TIMEOUT 635 }, 636 [URTW_8187L_BULK_TX_NORMAL] = { 637 .type = UE_BULK, 638 .endpoint = 0x3, 639 .direction = UE_DIR_OUT, 640 .bufsize = URTW_TX_MAXSIZE, 641 .flags = { 642 .ext_buffer = 1, 643 .force_short_xfer = 1, 644 .pipe_bof = 1, 645 }, 646 .callback = urtw_bulk_tx_callback, 647 .timeout = URTW_DATA_TIMEOUT 648 }, 649 }; 650 651 static struct ieee80211vap *urtw_vap_create(struct ieee80211com *, 652 const char [IFNAMSIZ], int, enum ieee80211_opmode, 653 int, const uint8_t [IEEE80211_ADDR_LEN], 654 const uint8_t [IEEE80211_ADDR_LEN]); 655 static void urtw_vap_delete(struct ieee80211vap *); 656 static void urtw_init(void *); 657 static void urtw_stop(struct ifnet *); 658 static void urtw_stop_locked(struct ifnet *); 659 static int urtw_ioctl(struct ifnet *, u_long, caddr_t); 660 static void urtw_start(struct ifnet *); 661 static int urtw_alloc_rx_data_list(struct urtw_softc *); 662 static int urtw_alloc_tx_data_list(struct urtw_softc *); 663 static int urtw_raw_xmit(struct ieee80211_node *, struct mbuf *, 664 const struct ieee80211_bpf_params *); 665 static void urtw_scan_start(struct ieee80211com *); 666 static void urtw_scan_end(struct ieee80211com *); 667 static void urtw_set_channel(struct ieee80211com *); 668 static void urtw_update_mcast(struct ifnet *); 669 static int urtw_tx_start(struct urtw_softc *, 670 struct ieee80211_node *, struct mbuf *, 671 struct urtw_data *, int); 672 static int urtw_newstate(struct ieee80211vap *, 673 enum ieee80211_state, int); 674 static void urtw_led_ch(void *); 675 static void urtw_ledtask(void *, int); 676 static void urtw_watchdog(void *); 677 static void urtw_set_multi(void *); 678 static int urtw_isbmode(uint16_t); 679 static uint16_t urtw_rate2rtl(uint32_t); 680 static uint16_t urtw_rtl2rate(uint32_t); 681 static usb_error_t urtw_set_rate(struct urtw_softc *); 682 static usb_error_t urtw_update_msr(struct urtw_softc *); 683 static usb_error_t urtw_read8_c(struct urtw_softc *, int, uint8_t *); 684 static usb_error_t urtw_read16_c(struct urtw_softc *, int, uint16_t *); 685 static usb_error_t urtw_read32_c(struct urtw_softc *, int, uint32_t *); 686 static usb_error_t urtw_write8_c(struct urtw_softc *, int, uint8_t); 687 static usb_error_t urtw_write16_c(struct urtw_softc *, int, uint16_t); 688 static usb_error_t urtw_write32_c(struct urtw_softc *, int, uint32_t); 689 static usb_error_t urtw_eprom_cs(struct urtw_softc *, int); 690 static usb_error_t urtw_eprom_ck(struct urtw_softc *); 691 static usb_error_t urtw_eprom_sendbits(struct urtw_softc *, int16_t *, 692 int); 693 static usb_error_t urtw_eprom_read32(struct urtw_softc *, uint32_t, 694 uint32_t *); 695 static usb_error_t urtw_eprom_readbit(struct urtw_softc *, int16_t *); 696 static usb_error_t urtw_eprom_writebit(struct urtw_softc *, int16_t); 697 static usb_error_t urtw_get_macaddr(struct urtw_softc *); 698 static usb_error_t urtw_get_txpwr(struct urtw_softc *); 699 static usb_error_t urtw_get_rfchip(struct urtw_softc *); 700 static usb_error_t urtw_led_init(struct urtw_softc *); 701 static usb_error_t urtw_8185_rf_pins_enable(struct urtw_softc *); 702 static usb_error_t urtw_8185_tx_antenna(struct urtw_softc *, uint8_t); 703 static usb_error_t urtw_8187_write_phy(struct urtw_softc *, uint8_t, 704 uint32_t); 705 static usb_error_t urtw_8187_write_phy_ofdm_c(struct urtw_softc *, 706 uint8_t, uint32_t); 707 static usb_error_t urtw_8187_write_phy_cck_c(struct urtw_softc *, uint8_t, 708 uint32_t); 709 static usb_error_t urtw_8225_setgain(struct urtw_softc *, int16_t); 710 static usb_error_t urtw_8225_usb_init(struct urtw_softc *); 711 static usb_error_t urtw_8225_write_c(struct urtw_softc *, uint8_t, 712 uint16_t); 713 static usb_error_t urtw_8225_write_s16(struct urtw_softc *, uint8_t, int, 714 uint16_t *); 715 static usb_error_t urtw_8225_read(struct urtw_softc *, uint8_t, 716 uint32_t *); 717 static usb_error_t urtw_8225_rf_init(struct urtw_softc *); 718 static usb_error_t urtw_8225_rf_set_chan(struct urtw_softc *, int); 719 static usb_error_t urtw_8225_rf_set_sens(struct urtw_softc *, int); 720 static usb_error_t urtw_8225_set_txpwrlvl(struct urtw_softc *, int); 721 static usb_error_t urtw_8225_rf_stop(struct urtw_softc *); 722 static usb_error_t urtw_8225v2_rf_init(struct urtw_softc *); 723 static usb_error_t urtw_8225v2_rf_set_chan(struct urtw_softc *, int); 724 static usb_error_t urtw_8225v2_set_txpwrlvl(struct urtw_softc *, int); 725 static usb_error_t urtw_8225v2_setgain(struct urtw_softc *, int16_t); 726 static usb_error_t urtw_8225_isv2(struct urtw_softc *, int *); 727 static usb_error_t urtw_8225v2b_rf_init(struct urtw_softc *); 728 static usb_error_t urtw_8225v2b_rf_set_chan(struct urtw_softc *, int); 729 static usb_error_t urtw_read8e(struct urtw_softc *, int, uint8_t *); 730 static usb_error_t urtw_write8e(struct urtw_softc *, int, uint8_t); 731 static usb_error_t urtw_8180_set_anaparam(struct urtw_softc *, uint32_t); 732 static usb_error_t urtw_8185_set_anaparam2(struct urtw_softc *, uint32_t); 733 static usb_error_t urtw_intr_enable(struct urtw_softc *); 734 static usb_error_t urtw_intr_disable(struct urtw_softc *); 735 static usb_error_t urtw_reset(struct urtw_softc *); 736 static usb_error_t urtw_led_on(struct urtw_softc *, int); 737 static usb_error_t urtw_led_ctl(struct urtw_softc *, int); 738 static usb_error_t urtw_led_blink(struct urtw_softc *); 739 static usb_error_t urtw_led_mode0(struct urtw_softc *, int); 740 static usb_error_t urtw_led_mode1(struct urtw_softc *, int); 741 static usb_error_t urtw_led_mode2(struct urtw_softc *, int); 742 static usb_error_t urtw_led_mode3(struct urtw_softc *, int); 743 static usb_error_t urtw_rx_setconf(struct urtw_softc *); 744 static usb_error_t urtw_rx_enable(struct urtw_softc *); 745 static usb_error_t urtw_tx_enable(struct urtw_softc *sc); 746 static void urtw_free_tx_data_list(struct urtw_softc *); 747 static void urtw_free_rx_data_list(struct urtw_softc *); 748 static void urtw_free_data_list(struct urtw_softc *, 749 struct urtw_data data[], int, int); 750 static usb_error_t urtw_adapter_start(struct urtw_softc *); 751 static usb_error_t urtw_adapter_start_b(struct urtw_softc *); 752 static usb_error_t urtw_set_mode(struct urtw_softc *, uint32_t); 753 static usb_error_t urtw_8187b_cmd_reset(struct urtw_softc *); 754 static usb_error_t urtw_do_request(struct urtw_softc *, 755 struct usb_device_request *, void *); 756 static usb_error_t urtw_8225v2b_set_txpwrlvl(struct urtw_softc *, int); 757 static usb_error_t urtw_led_off(struct urtw_softc *, int); 758 static void urtw_abort_xfers(struct urtw_softc *); 759 static struct urtw_data * 760 urtw_getbuf(struct urtw_softc *sc); 761 static int urtw_compute_txtime(uint16_t, uint16_t, uint8_t, 762 uint8_t); 763 static void urtw_updateslot(struct ifnet *); 764 static void urtw_updateslottask(void *, int); 765 static void urtw_sysctl_node(struct urtw_softc *); 766 767 static int 768 urtw_match(device_t dev) 769 { 770 struct usb_attach_arg *uaa = device_get_ivars(dev); 771 772 if (uaa->usb_mode != USB_MODE_HOST) 773 return (ENXIO); 774 if (uaa->info.bConfigIndex != URTW_CONFIG_INDEX) 775 return (ENXIO); 776 if (uaa->info.bIfaceIndex != URTW_IFACE_INDEX) 777 return (ENXIO); 778 779 return (usbd_lookup_id_by_uaa(urtw_devs, sizeof(urtw_devs), uaa)); 780 } 781 782 static int 783 urtw_attach(device_t dev) 784 { 785 const struct usb_config *setup_start; 786 int ret = ENXIO; 787 struct urtw_softc *sc = device_get_softc(dev); 788 struct usb_attach_arg *uaa = device_get_ivars(dev); 789 struct ieee80211com *ic; 790 struct ifnet *ifp; 791 uint8_t bands, iface_index = URTW_IFACE_INDEX; /* XXX */ 792 uint16_t n_setup; 793 uint32_t data; 794 usb_error_t error; 795 796 device_set_usb_desc(dev); 797 798 sc->sc_dev = dev; 799 sc->sc_udev = uaa->device; 800 if (USB_GET_DRIVER_INFO(uaa) == URTW_REV_RTL8187B) 801 sc->sc_flags |= URTW_RTL8187B; 802 #ifdef URTW_DEBUG 803 sc->sc_debug = urtw_debug; 804 #endif 805 806 mtx_init(&sc->sc_mtx, device_get_nameunit(sc->sc_dev), MTX_NETWORK_LOCK, 807 MTX_DEF); 808 usb_callout_init_mtx(&sc->sc_led_ch, &sc->sc_mtx, 0); 809 TASK_INIT(&sc->sc_led_task, 0, urtw_ledtask, sc); 810 TASK_INIT(&sc->sc_updateslot_task, 0, urtw_updateslottask, sc); 811 callout_init(&sc->sc_watchdog_ch, 0); 812 813 if (sc->sc_flags & URTW_RTL8187B) { 814 setup_start = urtw_8187b_usbconfig; 815 n_setup = URTW_8187B_N_XFERS; 816 } else { 817 setup_start = urtw_8187l_usbconfig; 818 n_setup = URTW_8187L_N_XFERS; 819 } 820 821 error = usbd_transfer_setup(uaa->device, &iface_index, sc->sc_xfer, 822 setup_start, n_setup, sc, &sc->sc_mtx); 823 if (error) { 824 device_printf(dev, "could not allocate USB transfers, " 825 "err=%s\n", usbd_errstr(error)); 826 ret = ENXIO; 827 goto fail0; 828 } 829 830 if (sc->sc_flags & URTW_RTL8187B) { 831 sc->sc_tx_dma_buf = 832 usbd_xfer_get_frame_buffer(sc->sc_xfer[ 833 URTW_8187B_BULK_TX_BE], 0); 834 } else { 835 sc->sc_tx_dma_buf = 836 usbd_xfer_get_frame_buffer(sc->sc_xfer[ 837 URTW_8187L_BULK_TX_LOW], 0); 838 } 839 840 URTW_LOCK(sc); 841 842 urtw_read32_m(sc, URTW_RX, &data); 843 sc->sc_epromtype = (data & URTW_RX_9356SEL) ? URTW_EEPROM_93C56 : 844 URTW_EEPROM_93C46; 845 846 error = urtw_get_rfchip(sc); 847 if (error != 0) 848 goto fail; 849 error = urtw_get_macaddr(sc); 850 if (error != 0) 851 goto fail; 852 error = urtw_get_txpwr(sc); 853 if (error != 0) 854 goto fail; 855 error = urtw_led_init(sc); 856 if (error != 0) 857 goto fail; 858 859 URTW_UNLOCK(sc); 860 861 sc->sc_rts_retry = URTW_DEFAULT_RTS_RETRY; 862 sc->sc_tx_retry = URTW_DEFAULT_TX_RETRY; 863 sc->sc_currate = 3; 864 sc->sc_preamble_mode = urtw_preamble_mode; 865 866 ifp = sc->sc_ifp = if_alloc(IFT_IEEE80211); 867 if (ifp == NULL) { 868 device_printf(sc->sc_dev, "can not allocate ifnet\n"); 869 ret = ENOMEM; 870 goto fail1; 871 } 872 873 ifp->if_softc = sc; 874 if_initname(ifp, "urtw", device_get_unit(sc->sc_dev)); 875 ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; 876 ifp->if_init = urtw_init; 877 ifp->if_ioctl = urtw_ioctl; 878 ifp->if_start = urtw_start; 879 /* XXX URTW_TX_DATA_LIST_COUNT */ 880 IFQ_SET_MAXLEN(&ifp->if_snd, ifqmaxlen); 881 ifp->if_snd.ifq_drv_maxlen = ifqmaxlen; 882 IFQ_SET_READY(&ifp->if_snd); 883 884 ic = ifp->if_l2com; 885 ic->ic_ifp = ifp; 886 ic->ic_phytype = IEEE80211_T_OFDM; /* not only, but not used */ 887 ic->ic_opmode = IEEE80211_M_STA; /* default to BSS mode */ 888 889 /* set device capabilities */ 890 ic->ic_caps = 891 IEEE80211_C_STA | /* station mode */ 892 IEEE80211_C_MONITOR | /* monitor mode supported */ 893 IEEE80211_C_TXPMGT | /* tx power management */ 894 IEEE80211_C_SHPREAMBLE | /* short preamble supported */ 895 IEEE80211_C_SHSLOT | /* short slot time supported */ 896 IEEE80211_C_BGSCAN | /* capable of bg scanning */ 897 IEEE80211_C_WPA; /* 802.11i */ 898 899 bands = 0; 900 setbit(&bands, IEEE80211_MODE_11B); 901 setbit(&bands, IEEE80211_MODE_11G); 902 ieee80211_init_channels(ic, NULL, &bands); 903 904 ieee80211_ifattach(ic, sc->sc_bssid); 905 ic->ic_raw_xmit = urtw_raw_xmit; 906 ic->ic_scan_start = urtw_scan_start; 907 ic->ic_scan_end = urtw_scan_end; 908 ic->ic_set_channel = urtw_set_channel; 909 ic->ic_updateslot = urtw_updateslot; 910 ic->ic_vap_create = urtw_vap_create; 911 ic->ic_vap_delete = urtw_vap_delete; 912 ic->ic_update_mcast = urtw_update_mcast; 913 914 ieee80211_radiotap_attach(ic, 915 &sc->sc_txtap.wt_ihdr, sizeof(sc->sc_txtap), 916 URTW_TX_RADIOTAP_PRESENT, 917 &sc->sc_rxtap.wr_ihdr, sizeof(sc->sc_rxtap), 918 URTW_RX_RADIOTAP_PRESENT); 919 920 urtw_sysctl_node(sc); 921 922 if (bootverbose) 923 ieee80211_announce(ic); 924 return (0); 925 926 fail: URTW_UNLOCK(sc); 927 fail1: usbd_transfer_unsetup(sc->sc_xfer, (sc->sc_flags & URTW_RTL8187B) ? 928 URTW_8187B_N_XFERS : URTW_8187L_N_XFERS); 929 fail0: 930 return (ret); 931 } 932 933 static int 934 urtw_detach(device_t dev) 935 { 936 struct urtw_softc *sc = device_get_softc(dev); 937 struct ifnet *ifp = sc->sc_ifp; 938 struct ieee80211com *ic = ifp->if_l2com; 939 unsigned int x; 940 unsigned int n_xfers; 941 942 /* Prevent further ioctls */ 943 URTW_LOCK(sc); 944 sc->sc_flags |= URTW_DETACHED; 945 URTW_UNLOCK(sc); 946 947 urtw_stop(ifp); 948 949 ieee80211_draintask(ic, &sc->sc_updateslot_task); 950 ieee80211_draintask(ic, &sc->sc_led_task); 951 952 usb_callout_drain(&sc->sc_led_ch); 953 callout_drain(&sc->sc_watchdog_ch); 954 955 n_xfers = (sc->sc_flags & URTW_RTL8187B) ? 956 URTW_8187B_N_XFERS : URTW_8187L_N_XFERS; 957 958 /* prevent further allocations from RX/TX data lists */ 959 URTW_LOCK(sc); 960 STAILQ_INIT(&sc->sc_tx_active); 961 STAILQ_INIT(&sc->sc_tx_inactive); 962 STAILQ_INIT(&sc->sc_tx_pending); 963 964 STAILQ_INIT(&sc->sc_rx_active); 965 STAILQ_INIT(&sc->sc_rx_inactive); 966 URTW_UNLOCK(sc); 967 968 /* drain USB transfers */ 969 for (x = 0; x != n_xfers; x++) 970 usbd_transfer_drain(sc->sc_xfer[x]); 971 972 /* free data buffers */ 973 URTW_LOCK(sc); 974 urtw_free_tx_data_list(sc); 975 urtw_free_rx_data_list(sc); 976 URTW_UNLOCK(sc); 977 978 /* free USB transfers and some data buffers */ 979 usbd_transfer_unsetup(sc->sc_xfer, n_xfers); 980 981 ieee80211_ifdetach(ic); 982 if_free(ifp); 983 mtx_destroy(&sc->sc_mtx); 984 return (0); 985 } 986 987 static void 988 urtw_free_tx_data_list(struct urtw_softc *sc) 989 { 990 urtw_free_data_list(sc, sc->sc_tx, URTW_TX_DATA_LIST_COUNT, 0); 991 } 992 993 static void 994 urtw_free_rx_data_list(struct urtw_softc *sc) 995 { 996 urtw_free_data_list(sc, sc->sc_rx, URTW_RX_DATA_LIST_COUNT, 1); 997 } 998 999 static void 1000 urtw_free_data_list(struct urtw_softc *sc, struct urtw_data data[], int ndata, 1001 int fillmbuf) 1002 { 1003 int i; 1004 1005 for (i = 0; i < ndata; i++) { 1006 struct urtw_data *dp = &data[i]; 1007 1008 if (fillmbuf == 1) { 1009 if (dp->m != NULL) { 1010 m_freem(dp->m); 1011 dp->m = NULL; 1012 dp->buf = NULL; 1013 } 1014 } else { 1015 dp->buf = NULL; 1016 } 1017 if (dp->ni != NULL) { 1018 ieee80211_free_node(dp->ni); 1019 dp->ni = NULL; 1020 } 1021 } 1022 } 1023 1024 static struct ieee80211vap * 1025 urtw_vap_create(struct ieee80211com *ic, const char name[IFNAMSIZ], int unit, 1026 enum ieee80211_opmode opmode, int flags, 1027 const uint8_t bssid[IEEE80211_ADDR_LEN], 1028 const uint8_t mac[IEEE80211_ADDR_LEN]) 1029 { 1030 struct urtw_vap *uvp; 1031 struct ieee80211vap *vap; 1032 1033 if (!TAILQ_EMPTY(&ic->ic_vaps)) /* only one at a time */ 1034 return (NULL); 1035 uvp = (struct urtw_vap *) malloc(sizeof(struct urtw_vap), 1036 M_80211_VAP, M_NOWAIT | M_ZERO); 1037 if (uvp == NULL) 1038 return (NULL); 1039 vap = &uvp->vap; 1040 /* enable s/w bmiss handling for sta mode */ 1041 1042 if (ieee80211_vap_setup(ic, vap, name, unit, opmode, 1043 flags | IEEE80211_CLONE_NOBEACONS, bssid, mac) != 0) { 1044 /* out of memory */ 1045 free(uvp, M_80211_VAP); 1046 return (NULL); 1047 } 1048 1049 /* override state transition machine */ 1050 uvp->newstate = vap->iv_newstate; 1051 vap->iv_newstate = urtw_newstate; 1052 1053 /* complete setup */ 1054 ieee80211_vap_attach(vap, ieee80211_media_change, 1055 ieee80211_media_status); 1056 ic->ic_opmode = opmode; 1057 return (vap); 1058 } 1059 1060 static void 1061 urtw_vap_delete(struct ieee80211vap *vap) 1062 { 1063 struct urtw_vap *uvp = URTW_VAP(vap); 1064 1065 ieee80211_vap_detach(vap); 1066 free(uvp, M_80211_VAP); 1067 } 1068 1069 static void 1070 urtw_init_locked(void *arg) 1071 { 1072 int ret; 1073 struct urtw_softc *sc = arg; 1074 struct ifnet *ifp = sc->sc_ifp; 1075 usb_error_t error; 1076 1077 if (ifp->if_drv_flags & IFF_DRV_RUNNING) 1078 urtw_stop_locked(ifp); 1079 1080 error = (sc->sc_flags & URTW_RTL8187B) ? urtw_adapter_start_b(sc) : 1081 urtw_adapter_start(sc); 1082 if (error != 0) 1083 goto fail; 1084 1085 /* reset softc variables */ 1086 sc->sc_txtimer = 0; 1087 1088 if (!(sc->sc_flags & URTW_INIT_ONCE)) { 1089 ret = urtw_alloc_rx_data_list(sc); 1090 if (ret != 0) 1091 goto fail; 1092 ret = urtw_alloc_tx_data_list(sc); 1093 if (ret != 0) 1094 goto fail; 1095 sc->sc_flags |= URTW_INIT_ONCE; 1096 } 1097 1098 error = urtw_rx_enable(sc); 1099 if (error != 0) 1100 goto fail; 1101 error = urtw_tx_enable(sc); 1102 if (error != 0) 1103 goto fail; 1104 1105 if (sc->sc_flags & URTW_RTL8187B) 1106 usbd_transfer_start(sc->sc_xfer[URTW_8187B_BULK_TX_STATUS]); 1107 1108 ifp->if_drv_flags &= ~IFF_DRV_OACTIVE; 1109 ifp->if_drv_flags |= IFF_DRV_RUNNING; 1110 1111 callout_reset(&sc->sc_watchdog_ch, hz, urtw_watchdog, sc); 1112 fail: 1113 return; 1114 } 1115 1116 static void 1117 urtw_init(void *arg) 1118 { 1119 struct urtw_softc *sc = arg; 1120 1121 URTW_LOCK(sc); 1122 urtw_init_locked(arg); 1123 URTW_UNLOCK(sc); 1124 } 1125 1126 static usb_error_t 1127 urtw_adapter_start_b(struct urtw_softc *sc) 1128 { 1129 #define N(a) ((int)(sizeof(a) / sizeof((a)[0]))) 1130 uint8_t data8; 1131 usb_error_t error; 1132 1133 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 1134 if (error) 1135 goto fail; 1136 1137 urtw_read8_m(sc, URTW_CONFIG3, &data8); 1138 urtw_write8_m(sc, URTW_CONFIG3, 1139 data8 | URTW_CONFIG3_ANAPARAM_WRITE | URTW_CONFIG3_GNT_SELECT); 1140 urtw_write32_m(sc, URTW_ANAPARAM2, URTW_8187B_8225_ANAPARAM2_ON); 1141 urtw_write32_m(sc, URTW_ANAPARAM, URTW_8187B_8225_ANAPARAM_ON); 1142 urtw_write8_m(sc, URTW_ANAPARAM3, URTW_8187B_8225_ANAPARAM3_ON); 1143 1144 urtw_write8_m(sc, 0x61, 0x10); 1145 urtw_read8_m(sc, 0x62, &data8); 1146 urtw_write8_m(sc, 0x62, data8 & ~(1 << 5)); 1147 urtw_write8_m(sc, 0x62, data8 | (1 << 5)); 1148 1149 urtw_read8_m(sc, URTW_CONFIG3, &data8); 1150 data8 &= ~URTW_CONFIG3_ANAPARAM_WRITE; 1151 urtw_write8_m(sc, URTW_CONFIG3, data8); 1152 1153 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 1154 if (error) 1155 goto fail; 1156 1157 error = urtw_8187b_cmd_reset(sc); 1158 if (error) 1159 goto fail; 1160 1161 error = sc->sc_rf_init(sc); 1162 if (error != 0) 1163 goto fail; 1164 urtw_write8_m(sc, URTW_CMD, URTW_CMD_RX_ENABLE | URTW_CMD_TX_ENABLE); 1165 1166 /* fix RTL8187B RX stall */ 1167 error = urtw_intr_enable(sc); 1168 if (error) 1169 goto fail; 1170 1171 error = urtw_write8e(sc, 0x41, 0xf4); 1172 if (error) 1173 goto fail; 1174 error = urtw_write8e(sc, 0x40, 0x00); 1175 if (error) 1176 goto fail; 1177 error = urtw_write8e(sc, 0x42, 0x00); 1178 if (error) 1179 goto fail; 1180 error = urtw_write8e(sc, 0x42, 0x01); 1181 if (error) 1182 goto fail; 1183 error = urtw_write8e(sc, 0x40, 0x0f); 1184 if (error) 1185 goto fail; 1186 error = urtw_write8e(sc, 0x42, 0x00); 1187 if (error) 1188 goto fail; 1189 error = urtw_write8e(sc, 0x42, 0x01); 1190 if (error) 1191 goto fail; 1192 1193 urtw_read8_m(sc, 0xdb, &data8); 1194 urtw_write8_m(sc, 0xdb, data8 | (1 << 2)); 1195 urtw_write16_m(sc, 0x372, 0x59fa); 1196 urtw_write16_m(sc, 0x374, 0x59d2); 1197 urtw_write16_m(sc, 0x376, 0x59d2); 1198 urtw_write16_m(sc, 0x378, 0x19fa); 1199 urtw_write16_m(sc, 0x37a, 0x19fa); 1200 urtw_write16_m(sc, 0x37c, 0x00d0); 1201 urtw_write8_m(sc, 0x61, 0); 1202 1203 urtw_write8_m(sc, 0x180, 0x0f); 1204 urtw_write8_m(sc, 0x183, 0x03); 1205 urtw_write8_m(sc, 0xda, 0x10); 1206 urtw_write8_m(sc, 0x24d, 0x08); 1207 urtw_write32_m(sc, URTW_HSSI_PARA, 0x0600321b); 1208 1209 urtw_write16_m(sc, 0x1ec, 0x800); /* RX MAX SIZE */ 1210 fail: 1211 return (error); 1212 #undef N 1213 } 1214 1215 static usb_error_t 1216 urtw_adapter_start(struct urtw_softc *sc) 1217 { 1218 usb_error_t error; 1219 1220 error = urtw_reset(sc); 1221 if (error) 1222 goto fail; 1223 1224 urtw_write8_m(sc, URTW_ADDR_MAGIC1, 0); 1225 urtw_write8_m(sc, URTW_GPIO, 0); 1226 1227 /* for led */ 1228 urtw_write8_m(sc, URTW_ADDR_MAGIC1, 4); 1229 error = urtw_led_ctl(sc, URTW_LED_CTL_POWER_ON); 1230 if (error != 0) 1231 goto fail; 1232 1233 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 1234 if (error) 1235 goto fail; 1236 /* applying MAC address again. */ 1237 urtw_write32_m(sc, URTW_MAC0, ((uint32_t *)sc->sc_bssid)[0]); 1238 urtw_write16_m(sc, URTW_MAC4, ((uint32_t *)sc->sc_bssid)[1] & 0xffff); 1239 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 1240 if (error) 1241 goto fail; 1242 1243 error = urtw_update_msr(sc); 1244 if (error) 1245 goto fail; 1246 1247 urtw_write32_m(sc, URTW_INT_TIMEOUT, 0); 1248 urtw_write8_m(sc, URTW_WPA_CONFIG, 0); 1249 urtw_write8_m(sc, URTW_RATE_FALLBACK, URTW_RATE_FALLBACK_ENABLE | 0x1); 1250 error = urtw_set_rate(sc); 1251 if (error != 0) 1252 goto fail; 1253 1254 error = sc->sc_rf_init(sc); 1255 if (error != 0) 1256 goto fail; 1257 if (sc->sc_rf_set_sens != NULL) 1258 sc->sc_rf_set_sens(sc, sc->sc_sens); 1259 1260 /* XXX correct? to call write16 */ 1261 urtw_write16_m(sc, URTW_PSR, 1); 1262 urtw_write16_m(sc, URTW_ADDR_MAGIC2, 0x10); 1263 urtw_write8_m(sc, URTW_TALLY_SEL, 0x80); 1264 urtw_write8_m(sc, URTW_ADDR_MAGIC3, 0x60); 1265 /* XXX correct? to call write16 */ 1266 urtw_write16_m(sc, URTW_PSR, 0); 1267 urtw_write8_m(sc, URTW_ADDR_MAGIC1, 4); 1268 1269 error = urtw_intr_enable(sc); 1270 if (error != 0) 1271 goto fail; 1272 1273 fail: 1274 return (error); 1275 } 1276 1277 static usb_error_t 1278 urtw_set_mode(struct urtw_softc *sc, uint32_t mode) 1279 { 1280 uint8_t data; 1281 usb_error_t error; 1282 1283 urtw_read8_m(sc, URTW_EPROM_CMD, &data); 1284 data = (data & ~URTW_EPROM_CMD_MASK) | (mode << URTW_EPROM_CMD_SHIFT); 1285 data = data & ~(URTW_EPROM_CS | URTW_EPROM_CK); 1286 urtw_write8_m(sc, URTW_EPROM_CMD, data); 1287 fail: 1288 return (error); 1289 } 1290 1291 static usb_error_t 1292 urtw_8187b_cmd_reset(struct urtw_softc *sc) 1293 { 1294 int i; 1295 uint8_t data8; 1296 usb_error_t error; 1297 1298 /* XXX the code can be duplicate with urtw_reset(). */ 1299 urtw_read8_m(sc, URTW_CMD, &data8); 1300 data8 = (data8 & 0x2) | URTW_CMD_RST; 1301 urtw_write8_m(sc, URTW_CMD, data8); 1302 1303 for (i = 0; i < 20; i++) { 1304 usb_pause_mtx(&sc->sc_mtx, 2); 1305 urtw_read8_m(sc, URTW_CMD, &data8); 1306 if (!(data8 & URTW_CMD_RST)) 1307 break; 1308 } 1309 if (i >= 20) { 1310 device_printf(sc->sc_dev, "reset timeout\n"); 1311 goto fail; 1312 } 1313 fail: 1314 return (error); 1315 } 1316 1317 static usb_error_t 1318 urtw_do_request(struct urtw_softc *sc, 1319 struct usb_device_request *req, void *data) 1320 { 1321 usb_error_t err; 1322 int ntries = 10; 1323 1324 URTW_ASSERT_LOCKED(sc); 1325 1326 while (ntries--) { 1327 err = usbd_do_request_flags(sc->sc_udev, &sc->sc_mtx, 1328 req, data, 0, NULL, 250 /* ms */); 1329 if (err == 0) 1330 break; 1331 1332 DPRINTF(sc, URTW_DEBUG_INIT, 1333 "Control request failed, %s (retrying)\n", 1334 usbd_errstr(err)); 1335 usb_pause_mtx(&sc->sc_mtx, hz / 100); 1336 } 1337 return (err); 1338 } 1339 1340 static void 1341 urtw_stop_locked(struct ifnet *ifp) 1342 { 1343 struct urtw_softc *sc = ifp->if_softc; 1344 uint8_t data8; 1345 usb_error_t error; 1346 1347 ifp->if_drv_flags &= ~(IFF_DRV_RUNNING | IFF_DRV_OACTIVE); 1348 1349 error = urtw_intr_disable(sc); 1350 if (error) 1351 goto fail; 1352 urtw_read8_m(sc, URTW_CMD, &data8); 1353 data8 &= ~(URTW_CMD_RX_ENABLE | URTW_CMD_TX_ENABLE); 1354 urtw_write8_m(sc, URTW_CMD, data8); 1355 1356 error = sc->sc_rf_stop(sc); 1357 if (error != 0) 1358 goto fail; 1359 1360 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 1361 if (error) 1362 goto fail; 1363 urtw_read8_m(sc, URTW_CONFIG4, &data8); 1364 urtw_write8_m(sc, URTW_CONFIG4, data8 | URTW_CONFIG4_VCOOFF); 1365 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 1366 if (error) 1367 goto fail; 1368 fail: 1369 if (error) 1370 device_printf(sc->sc_dev, "failed to stop (%s)\n", 1371 usbd_errstr(error)); 1372 1373 usb_callout_stop(&sc->sc_led_ch); 1374 callout_stop(&sc->sc_watchdog_ch); 1375 1376 urtw_abort_xfers(sc); 1377 } 1378 1379 static void 1380 urtw_stop(struct ifnet *ifp) 1381 { 1382 struct urtw_softc *sc = ifp->if_softc; 1383 1384 URTW_LOCK(sc); 1385 urtw_stop_locked(ifp); 1386 URTW_UNLOCK(sc); 1387 } 1388 1389 static void 1390 urtw_abort_xfers(struct urtw_softc *sc) 1391 { 1392 int i, max; 1393 1394 URTW_ASSERT_LOCKED(sc); 1395 1396 max = (sc->sc_flags & URTW_RTL8187B) ? URTW_8187B_N_XFERS : 1397 URTW_8187L_N_XFERS; 1398 1399 /* abort any pending transfers */ 1400 for (i = 0; i < max; i++) 1401 usbd_transfer_stop(sc->sc_xfer[i]); 1402 } 1403 1404 static int 1405 urtw_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) 1406 { 1407 struct urtw_softc *sc = ifp->if_softc; 1408 struct ieee80211com *ic = ifp->if_l2com; 1409 struct ifreq *ifr = (struct ifreq *) data; 1410 int error; 1411 int startall = 0; 1412 1413 URTW_LOCK(sc); 1414 error = (sc->sc_flags & URTW_DETACHED) ? ENXIO : 0; 1415 URTW_UNLOCK(sc); 1416 if (error) 1417 return (error); 1418 1419 switch (cmd) { 1420 case SIOCSIFFLAGS: 1421 if (ifp->if_flags & IFF_UP) { 1422 if (ifp->if_drv_flags & IFF_DRV_RUNNING) { 1423 if ((ifp->if_flags ^ sc->sc_if_flags) & 1424 (IFF_ALLMULTI | IFF_PROMISC)) 1425 urtw_set_multi(sc); 1426 } else { 1427 urtw_init(ifp->if_softc); 1428 startall = 1; 1429 } 1430 } else { 1431 if (ifp->if_drv_flags & IFF_DRV_RUNNING) 1432 urtw_stop(ifp); 1433 } 1434 sc->sc_if_flags = ifp->if_flags; 1435 if (startall) 1436 ieee80211_start_all(ic); 1437 break; 1438 case SIOCGIFMEDIA: 1439 error = ifmedia_ioctl(ifp, ifr, &ic->ic_media, cmd); 1440 break; 1441 case SIOCGIFADDR: 1442 error = ether_ioctl(ifp, cmd, data); 1443 break; 1444 default: 1445 error = EINVAL; 1446 break; 1447 } 1448 return (error); 1449 } 1450 1451 static void 1452 urtw_start(struct ifnet *ifp) 1453 { 1454 struct urtw_data *bf; 1455 struct urtw_softc *sc = ifp->if_softc; 1456 struct ieee80211_node *ni; 1457 struct mbuf *m; 1458 1459 if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0) 1460 return; 1461 1462 URTW_LOCK(sc); 1463 for (;;) { 1464 IFQ_DRV_DEQUEUE(&ifp->if_snd, m); 1465 if (m == NULL) 1466 break; 1467 bf = urtw_getbuf(sc); 1468 if (bf == NULL) { 1469 IFQ_DRV_PREPEND(&ifp->if_snd, m); 1470 break; 1471 } 1472 1473 ni = (struct ieee80211_node *)m->m_pkthdr.rcvif; 1474 m->m_pkthdr.rcvif = NULL; 1475 1476 if (urtw_tx_start(sc, ni, m, bf, URTW_PRIORITY_NORMAL) != 0) { 1477 ifp->if_oerrors++; 1478 STAILQ_INSERT_HEAD(&sc->sc_tx_inactive, bf, next); 1479 ieee80211_free_node(ni); 1480 break; 1481 } 1482 1483 sc->sc_txtimer = 5; 1484 callout_reset(&sc->sc_watchdog_ch, hz, urtw_watchdog, sc); 1485 } 1486 URTW_UNLOCK(sc); 1487 } 1488 1489 static int 1490 urtw_alloc_data_list(struct urtw_softc *sc, struct urtw_data data[], 1491 int ndata, int maxsz, void *dma_buf) 1492 { 1493 int i, error; 1494 1495 for (i = 0; i < ndata; i++) { 1496 struct urtw_data *dp = &data[i]; 1497 1498 dp->sc = sc; 1499 if (dma_buf == NULL) { 1500 dp->m = m_getcl(M_NOWAIT, MT_DATA, M_PKTHDR); 1501 if (dp->m == NULL) { 1502 device_printf(sc->sc_dev, 1503 "could not allocate rx mbuf\n"); 1504 error = ENOMEM; 1505 goto fail; 1506 } 1507 dp->buf = mtod(dp->m, uint8_t *); 1508 } else { 1509 dp->m = NULL; 1510 dp->buf = ((uint8_t *)dma_buf) + 1511 (i * maxsz); 1512 } 1513 dp->ni = NULL; 1514 } 1515 return (0); 1516 1517 fail: urtw_free_data_list(sc, data, ndata, 1); 1518 return (error); 1519 } 1520 1521 static int 1522 urtw_alloc_rx_data_list(struct urtw_softc *sc) 1523 { 1524 int error, i; 1525 1526 error = urtw_alloc_data_list(sc, 1527 sc->sc_rx, URTW_RX_DATA_LIST_COUNT, 1528 MCLBYTES, NULL /* mbufs */); 1529 if (error != 0) 1530 return (error); 1531 1532 STAILQ_INIT(&sc->sc_rx_active); 1533 STAILQ_INIT(&sc->sc_rx_inactive); 1534 1535 for (i = 0; i < URTW_RX_DATA_LIST_COUNT; i++) 1536 STAILQ_INSERT_HEAD(&sc->sc_rx_inactive, &sc->sc_rx[i], next); 1537 1538 return (0); 1539 } 1540 1541 static int 1542 urtw_alloc_tx_data_list(struct urtw_softc *sc) 1543 { 1544 int error, i; 1545 1546 error = urtw_alloc_data_list(sc, 1547 sc->sc_tx, URTW_TX_DATA_LIST_COUNT, URTW_TX_MAXSIZE, 1548 sc->sc_tx_dma_buf /* no mbufs */); 1549 if (error != 0) 1550 return (error); 1551 1552 STAILQ_INIT(&sc->sc_tx_active); 1553 STAILQ_INIT(&sc->sc_tx_inactive); 1554 STAILQ_INIT(&sc->sc_tx_pending); 1555 1556 for (i = 0; i < URTW_TX_DATA_LIST_COUNT; i++) 1557 STAILQ_INSERT_HEAD(&sc->sc_tx_inactive, &sc->sc_tx[i], 1558 next); 1559 1560 return (0); 1561 } 1562 1563 static int 1564 urtw_raw_xmit(struct ieee80211_node *ni, struct mbuf *m, 1565 const struct ieee80211_bpf_params *params) 1566 { 1567 struct ieee80211com *ic = ni->ni_ic; 1568 struct ifnet *ifp = ic->ic_ifp; 1569 struct urtw_data *bf; 1570 struct urtw_softc *sc = ifp->if_softc; 1571 1572 /* prevent management frames from being sent if we're not ready */ 1573 if (!(ifp->if_drv_flags & IFF_DRV_RUNNING)) { 1574 m_freem(m); 1575 ieee80211_free_node(ni); 1576 return ENETDOWN; 1577 } 1578 URTW_LOCK(sc); 1579 bf = urtw_getbuf(sc); 1580 if (bf == NULL) { 1581 ieee80211_free_node(ni); 1582 m_freem(m); 1583 URTW_UNLOCK(sc); 1584 return (ENOBUFS); /* XXX */ 1585 } 1586 1587 ifp->if_opackets++; 1588 if (urtw_tx_start(sc, ni, m, bf, URTW_PRIORITY_LOW) != 0) { 1589 ieee80211_free_node(ni); 1590 ifp->if_oerrors++; 1591 STAILQ_INSERT_HEAD(&sc->sc_tx_inactive, bf, next); 1592 URTW_UNLOCK(sc); 1593 return (EIO); 1594 } 1595 URTW_UNLOCK(sc); 1596 1597 sc->sc_txtimer = 5; 1598 return (0); 1599 } 1600 1601 static void 1602 urtw_scan_start(struct ieee80211com *ic) 1603 { 1604 1605 /* XXX do nothing? */ 1606 } 1607 1608 static void 1609 urtw_scan_end(struct ieee80211com *ic) 1610 { 1611 1612 /* XXX do nothing? */ 1613 } 1614 1615 static void 1616 urtw_set_channel(struct ieee80211com *ic) 1617 { 1618 struct urtw_softc *sc = ic->ic_ifp->if_softc; 1619 struct ifnet *ifp = sc->sc_ifp; 1620 uint32_t data, orig; 1621 usb_error_t error; 1622 1623 /* 1624 * if the user set a channel explicitly using ifconfig(8) this function 1625 * can be called earlier than we're expected that in some cases the 1626 * initialization would be failed if setting a channel is called before 1627 * the init have done. 1628 */ 1629 if (!(ifp->if_drv_flags & IFF_DRV_RUNNING)) 1630 return; 1631 1632 if (sc->sc_curchan != NULL && sc->sc_curchan == ic->ic_curchan) 1633 return; 1634 1635 URTW_LOCK(sc); 1636 1637 /* 1638 * during changing th channel we need to temporarily be disable 1639 * TX. 1640 */ 1641 urtw_read32_m(sc, URTW_TX_CONF, &orig); 1642 data = orig & ~URTW_TX_LOOPBACK_MASK; 1643 urtw_write32_m(sc, URTW_TX_CONF, data | URTW_TX_LOOPBACK_MAC); 1644 1645 error = sc->sc_rf_set_chan(sc, ieee80211_chan2ieee(ic, ic->ic_curchan)); 1646 if (error != 0) 1647 goto fail; 1648 usb_pause_mtx(&sc->sc_mtx, 10); 1649 urtw_write32_m(sc, URTW_TX_CONF, orig); 1650 1651 urtw_write16_m(sc, URTW_ATIM_WND, 2); 1652 urtw_write16_m(sc, URTW_ATIM_TR_ITV, 100); 1653 urtw_write16_m(sc, URTW_BEACON_INTERVAL, 100); 1654 urtw_write16_m(sc, URTW_BEACON_INTERVAL_TIME, 100); 1655 1656 fail: 1657 URTW_UNLOCK(sc); 1658 1659 sc->sc_curchan = ic->ic_curchan; 1660 1661 if (error != 0) 1662 device_printf(sc->sc_dev, "could not change the channel\n"); 1663 } 1664 1665 static void 1666 urtw_update_mcast(struct ifnet *ifp) 1667 { 1668 1669 /* XXX do nothing? */ 1670 } 1671 1672 static int 1673 urtw_tx_start(struct urtw_softc *sc, struct ieee80211_node *ni, struct mbuf *m0, 1674 struct urtw_data *data, int prior) 1675 { 1676 struct ifnet *ifp = sc->sc_ifp; 1677 struct ieee80211_frame *wh = mtod(m0, struct ieee80211_frame *); 1678 struct ieee80211_key *k; 1679 const struct ieee80211_txparam *tp; 1680 struct ieee80211com *ic = ifp->if_l2com; 1681 struct ieee80211vap *vap = ni->ni_vap; 1682 struct usb_xfer *rtl8187b_pipes[URTW_8187B_TXPIPE_MAX] = { 1683 sc->sc_xfer[URTW_8187B_BULK_TX_BE], 1684 sc->sc_xfer[URTW_8187B_BULK_TX_BK], 1685 sc->sc_xfer[URTW_8187B_BULK_TX_VI], 1686 sc->sc_xfer[URTW_8187B_BULK_TX_VO] 1687 }; 1688 struct usb_xfer *xfer; 1689 int dur = 0, rtsdur = 0, rtsenable = 0, ctsenable = 0, rate, 1690 pkttime = 0, txdur = 0, isshort = 0, xferlen; 1691 uint16_t acktime, rtstime, ctstime; 1692 uint32_t flags; 1693 usb_error_t error; 1694 1695 URTW_ASSERT_LOCKED(sc); 1696 1697 /* 1698 * Software crypto. 1699 */ 1700 if (wh->i_fc[1] & IEEE80211_FC1_PROTECTED) { 1701 k = ieee80211_crypto_encap(ni, m0); 1702 if (k == NULL) { 1703 device_printf(sc->sc_dev, 1704 "ieee80211_crypto_encap returns NULL.\n"); 1705 /* XXX we don't expect the fragmented frames */ 1706 m_freem(m0); 1707 return (ENOBUFS); 1708 } 1709 1710 /* in case packet header moved, reset pointer */ 1711 wh = mtod(m0, struct ieee80211_frame *); 1712 } 1713 1714 if (ieee80211_radiotap_active_vap(vap)) { 1715 struct urtw_tx_radiotap_header *tap = &sc->sc_txtap; 1716 1717 /* XXX Are variables correct? */ 1718 tap->wt_flags = 0; 1719 tap->wt_chan_freq = htole16(ic->ic_curchan->ic_freq); 1720 tap->wt_chan_flags = htole16(ic->ic_curchan->ic_flags); 1721 1722 ieee80211_radiotap_tx(vap, m0); 1723 } 1724 1725 if ((wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) == IEEE80211_FC0_TYPE_MGT || 1726 (wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) == IEEE80211_FC0_TYPE_CTL) { 1727 tp = &vap->iv_txparms[ieee80211_chan2mode(ic->ic_curchan)]; 1728 rate = tp->mgmtrate; 1729 } else { 1730 tp = &vap->iv_txparms[ieee80211_chan2mode(ni->ni_chan)]; 1731 /* for data frames */ 1732 if (IEEE80211_IS_MULTICAST(wh->i_addr1)) 1733 rate = tp->mcastrate; 1734 else if (tp->ucastrate != IEEE80211_FIXED_RATE_NONE) 1735 rate = tp->ucastrate; 1736 else 1737 rate = urtw_rtl2rate(sc->sc_currate); 1738 } 1739 1740 sc->sc_stats.txrates[sc->sc_currate]++; 1741 1742 if (IEEE80211_IS_MULTICAST(wh->i_addr1)) 1743 txdur = pkttime = urtw_compute_txtime(m0->m_pkthdr.len + 1744 IEEE80211_CRC_LEN, rate, 0, 0); 1745 else { 1746 acktime = urtw_compute_txtime(14, 2,0, 0); 1747 if ((m0->m_pkthdr.len + 4) > vap->iv_rtsthreshold) { 1748 rtsenable = 1; 1749 ctsenable = 0; 1750 rtstime = urtw_compute_txtime(URTW_ACKCTS_LEN, 2, 0, 0); 1751 ctstime = urtw_compute_txtime(14, 2, 0, 0); 1752 pkttime = urtw_compute_txtime(m0->m_pkthdr.len + 1753 IEEE80211_CRC_LEN, rate, 0, isshort); 1754 rtsdur = ctstime + pkttime + acktime + 1755 3 * URTW_ASIFS_TIME; 1756 txdur = rtstime + rtsdur; 1757 } else { 1758 rtsenable = ctsenable = rtsdur = 0; 1759 pkttime = urtw_compute_txtime(m0->m_pkthdr.len + 1760 IEEE80211_CRC_LEN, rate, 0, isshort); 1761 txdur = pkttime + URTW_ASIFS_TIME + acktime; 1762 } 1763 1764 if (wh->i_fc[1] & IEEE80211_FC1_MORE_FRAG) 1765 dur = urtw_compute_txtime(m0->m_pkthdr.len + 1766 IEEE80211_CRC_LEN, rate, 0, isshort) + 1767 3 * URTW_ASIFS_TIME + 1768 2 * acktime; 1769 else 1770 dur = URTW_ASIFS_TIME + acktime; 1771 } 1772 USETW(wh->i_dur, dur); 1773 1774 xferlen = m0->m_pkthdr.len; 1775 xferlen += (sc->sc_flags & URTW_RTL8187B) ? (4 * 8) : (4 * 3); 1776 if ((0 == xferlen % 64) || (0 == xferlen % 512)) 1777 xferlen += 1; 1778 1779 memset(data->buf, 0, URTW_TX_MAXSIZE); 1780 flags = m0->m_pkthdr.len & 0xfff; 1781 flags |= URTW_TX_FLAG_NO_ENC; 1782 if ((ic->ic_flags & IEEE80211_F_SHPREAMBLE) && 1783 (ni->ni_capinfo & IEEE80211_CAPINFO_SHORT_PREAMBLE) && 1784 (sc->sc_preamble_mode == URTW_PREAMBLE_MODE_SHORT) && 1785 (sc->sc_currate != 0)) 1786 flags |= URTW_TX_FLAG_SPLCP; 1787 if (wh->i_fc[1] & IEEE80211_FC1_MORE_FRAG) 1788 flags |= URTW_TX_FLAG_MOREFRAG; 1789 1790 flags |= (sc->sc_currate & 0xf) << URTW_TX_FLAG_TXRATE_SHIFT; 1791 1792 if (sc->sc_flags & URTW_RTL8187B) { 1793 struct urtw_8187b_txhdr *tx; 1794 1795 tx = (struct urtw_8187b_txhdr *)data->buf; 1796 if (ctsenable) 1797 flags |= URTW_TX_FLAG_CTS; 1798 if (rtsenable) { 1799 flags |= URTW_TX_FLAG_RTS; 1800 flags |= (urtw_rate2rtl(11) & 0xf) << 1801 URTW_TX_FLAG_RTSRATE_SHIFT; 1802 tx->rtsdur = rtsdur; 1803 } 1804 tx->flag = htole32(flags); 1805 tx->txdur = txdur; 1806 if ((wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) == 1807 IEEE80211_FC0_TYPE_MGT && 1808 (wh->i_fc[0] & IEEE80211_FC0_SUBTYPE_MASK) == 1809 IEEE80211_FC0_SUBTYPE_PROBE_RESP) 1810 tx->retry = 1; 1811 else 1812 tx->retry = URTW_TX_MAXRETRY; 1813 m_copydata(m0, 0, m0->m_pkthdr.len, (uint8_t *)(tx + 1)); 1814 } else { 1815 struct urtw_8187l_txhdr *tx; 1816 1817 tx = (struct urtw_8187l_txhdr *)data->buf; 1818 if (rtsenable) { 1819 flags |= URTW_TX_FLAG_RTS; 1820 tx->rtsdur = rtsdur; 1821 } 1822 flags |= (urtw_rate2rtl(11) & 0xf) << URTW_TX_FLAG_RTSRATE_SHIFT; 1823 tx->flag = htole32(flags); 1824 tx->retry = 3; /* CW minimum */ 1825 tx->retry = 7 << 4; /* CW maximum */ 1826 tx->retry = URTW_TX_MAXRETRY << 8; /* retry limitation */ 1827 m_copydata(m0, 0, m0->m_pkthdr.len, (uint8_t *)(tx + 1)); 1828 } 1829 1830 data->buflen = xferlen; 1831 data->ni = ni; 1832 data->m = m0; 1833 1834 if (sc->sc_flags & URTW_RTL8187B) { 1835 switch (wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) { 1836 case IEEE80211_FC0_TYPE_CTL: 1837 case IEEE80211_FC0_TYPE_MGT: 1838 xfer = sc->sc_xfer[URTW_8187B_BULK_TX_EP12]; 1839 break; 1840 default: 1841 KASSERT(M_WME_GETAC(m0) < URTW_8187B_TXPIPE_MAX, 1842 ("unsupported WME pipe %d", M_WME_GETAC(m0))); 1843 xfer = rtl8187b_pipes[M_WME_GETAC(m0)]; 1844 break; 1845 } 1846 } else 1847 xfer = (prior == URTW_PRIORITY_LOW) ? 1848 sc->sc_xfer[URTW_8187L_BULK_TX_LOW] : 1849 sc->sc_xfer[URTW_8187L_BULK_TX_NORMAL]; 1850 1851 STAILQ_INSERT_TAIL(&sc->sc_tx_pending, data, next); 1852 usbd_transfer_start(xfer); 1853 1854 error = urtw_led_ctl(sc, URTW_LED_CTL_TX); 1855 if (error != 0) 1856 device_printf(sc->sc_dev, "could not control LED (%d)\n", 1857 error); 1858 return (0); 1859 } 1860 1861 static int 1862 urtw_newstate(struct ieee80211vap *vap, enum ieee80211_state nstate, int arg) 1863 { 1864 struct ieee80211com *ic = vap->iv_ic; 1865 struct urtw_softc *sc = ic->ic_ifp->if_softc; 1866 struct urtw_vap *uvp = URTW_VAP(vap); 1867 struct ieee80211_node *ni; 1868 usb_error_t error = 0; 1869 1870 DPRINTF(sc, URTW_DEBUG_STATE, "%s: %s -> %s\n", __func__, 1871 ieee80211_state_name[vap->iv_state], 1872 ieee80211_state_name[nstate]); 1873 1874 sc->sc_state = nstate; 1875 1876 IEEE80211_UNLOCK(ic); 1877 URTW_LOCK(sc); 1878 usb_callout_stop(&sc->sc_led_ch); 1879 callout_stop(&sc->sc_watchdog_ch); 1880 1881 switch (nstate) { 1882 case IEEE80211_S_INIT: 1883 case IEEE80211_S_SCAN: 1884 case IEEE80211_S_AUTH: 1885 case IEEE80211_S_ASSOC: 1886 break; 1887 case IEEE80211_S_RUN: 1888 ni = ieee80211_ref_node(vap->iv_bss); 1889 /* setting bssid. */ 1890 urtw_write32_m(sc, URTW_BSSID, ((uint32_t *)ni->ni_bssid)[0]); 1891 urtw_write16_m(sc, URTW_BSSID + 4, 1892 ((uint16_t *)ni->ni_bssid)[2]); 1893 urtw_update_msr(sc); 1894 /* XXX maybe the below would be incorrect. */ 1895 urtw_write16_m(sc, URTW_ATIM_WND, 2); 1896 urtw_write16_m(sc, URTW_ATIM_TR_ITV, 100); 1897 urtw_write16_m(sc, URTW_BEACON_INTERVAL, 0x64); 1898 urtw_write16_m(sc, URTW_BEACON_INTERVAL_TIME, 100); 1899 error = urtw_led_ctl(sc, URTW_LED_CTL_LINK); 1900 if (error != 0) 1901 device_printf(sc->sc_dev, 1902 "could not control LED (%d)\n", error); 1903 ieee80211_free_node(ni); 1904 break; 1905 default: 1906 break; 1907 } 1908 fail: 1909 URTW_UNLOCK(sc); 1910 IEEE80211_LOCK(ic); 1911 return (uvp->newstate(vap, nstate, arg)); 1912 } 1913 1914 static void 1915 urtw_watchdog(void *arg) 1916 { 1917 struct urtw_softc *sc = arg; 1918 struct ifnet *ifp = sc->sc_ifp; 1919 1920 if (sc->sc_txtimer > 0) { 1921 if (--sc->sc_txtimer == 0) { 1922 device_printf(sc->sc_dev, "device timeout\n"); 1923 ifp->if_oerrors++; 1924 return; 1925 } 1926 callout_reset(&sc->sc_watchdog_ch, hz, urtw_watchdog, sc); 1927 } 1928 } 1929 1930 static void 1931 urtw_set_multi(void *arg) 1932 { 1933 struct urtw_softc *sc = arg; 1934 struct ifnet *ifp = sc->sc_ifp; 1935 1936 if (!(ifp->if_flags & IFF_UP)) 1937 return; 1938 1939 /* 1940 * XXX don't know how to set a device. Lack of docs. Just try to set 1941 * IFF_ALLMULTI flag here. 1942 */ 1943 ifp->if_flags |= IFF_ALLMULTI; 1944 } 1945 1946 static usb_error_t 1947 urtw_set_rate(struct urtw_softc *sc) 1948 { 1949 int i, basic_rate, min_rr_rate, max_rr_rate; 1950 uint16_t data; 1951 usb_error_t error; 1952 1953 basic_rate = urtw_rate2rtl(48); 1954 min_rr_rate = urtw_rate2rtl(12); 1955 max_rr_rate = urtw_rate2rtl(48); 1956 1957 urtw_write8_m(sc, URTW_RESP_RATE, 1958 max_rr_rate << URTW_RESP_MAX_RATE_SHIFT | 1959 min_rr_rate << URTW_RESP_MIN_RATE_SHIFT); 1960 1961 urtw_read16_m(sc, URTW_BRSR, &data); 1962 data &= ~URTW_BRSR_MBR_8185; 1963 1964 for (i = 0; i <= basic_rate; i++) 1965 data |= (1 << i); 1966 1967 urtw_write16_m(sc, URTW_BRSR, data); 1968 fail: 1969 return (error); 1970 } 1971 1972 static uint16_t 1973 urtw_rate2rtl(uint32_t rate) 1974 { 1975 #define N(a) ((int)(sizeof(a) / sizeof((a)[0]))) 1976 int i; 1977 1978 for (i = 0; i < N(urtw_ratetable); i++) { 1979 if (rate == urtw_ratetable[i].reg) 1980 return urtw_ratetable[i].val; 1981 } 1982 1983 return (3); 1984 #undef N 1985 } 1986 1987 static uint16_t 1988 urtw_rtl2rate(uint32_t rate) 1989 { 1990 #define N(a) ((int)(sizeof(a) / sizeof((a)[0]))) 1991 int i; 1992 1993 for (i = 0; i < N(urtw_ratetable); i++) { 1994 if (rate == urtw_ratetable[i].val) 1995 return urtw_ratetable[i].reg; 1996 } 1997 1998 return (0); 1999 #undef N 2000 } 2001 2002 static usb_error_t 2003 urtw_update_msr(struct urtw_softc *sc) 2004 { 2005 struct ifnet *ifp = sc->sc_ifp; 2006 struct ieee80211com *ic = ifp->if_l2com; 2007 uint8_t data; 2008 usb_error_t error; 2009 2010 urtw_read8_m(sc, URTW_MSR, &data); 2011 data &= ~URTW_MSR_LINK_MASK; 2012 2013 if (sc->sc_state == IEEE80211_S_RUN) { 2014 switch (ic->ic_opmode) { 2015 case IEEE80211_M_STA: 2016 case IEEE80211_M_MONITOR: 2017 data |= URTW_MSR_LINK_STA; 2018 if (sc->sc_flags & URTW_RTL8187B) 2019 data |= URTW_MSR_LINK_ENEDCA; 2020 break; 2021 case IEEE80211_M_IBSS: 2022 data |= URTW_MSR_LINK_ADHOC; 2023 break; 2024 case IEEE80211_M_HOSTAP: 2025 data |= URTW_MSR_LINK_HOSTAP; 2026 break; 2027 default: 2028 DPRINTF(sc, URTW_DEBUG_STATE, 2029 "unsupported operation mode 0x%x\n", 2030 ic->ic_opmode); 2031 error = USB_ERR_INVAL; 2032 goto fail; 2033 } 2034 } else 2035 data |= URTW_MSR_LINK_NONE; 2036 2037 urtw_write8_m(sc, URTW_MSR, data); 2038 fail: 2039 return (error); 2040 } 2041 2042 static usb_error_t 2043 urtw_read8_c(struct urtw_softc *sc, int val, uint8_t *data) 2044 { 2045 struct usb_device_request req; 2046 usb_error_t error; 2047 2048 URTW_ASSERT_LOCKED(sc); 2049 2050 req.bmRequestType = UT_READ_VENDOR_DEVICE; 2051 req.bRequest = URTW_8187_GETREGS_REQ; 2052 USETW(req.wValue, (val & 0xff) | 0xff00); 2053 USETW(req.wIndex, (val >> 8) & 0x3); 2054 USETW(req.wLength, sizeof(uint8_t)); 2055 2056 error = urtw_do_request(sc, &req, data); 2057 return (error); 2058 } 2059 2060 static usb_error_t 2061 urtw_read16_c(struct urtw_softc *sc, int val, uint16_t *data) 2062 { 2063 struct usb_device_request req; 2064 usb_error_t error; 2065 2066 URTW_ASSERT_LOCKED(sc); 2067 2068 req.bmRequestType = UT_READ_VENDOR_DEVICE; 2069 req.bRequest = URTW_8187_GETREGS_REQ; 2070 USETW(req.wValue, (val & 0xff) | 0xff00); 2071 USETW(req.wIndex, (val >> 8) & 0x3); 2072 USETW(req.wLength, sizeof(uint16_t)); 2073 2074 error = urtw_do_request(sc, &req, data); 2075 return (error); 2076 } 2077 2078 static usb_error_t 2079 urtw_read32_c(struct urtw_softc *sc, int val, uint32_t *data) 2080 { 2081 struct usb_device_request req; 2082 usb_error_t error; 2083 2084 URTW_ASSERT_LOCKED(sc); 2085 2086 req.bmRequestType = UT_READ_VENDOR_DEVICE; 2087 req.bRequest = URTW_8187_GETREGS_REQ; 2088 USETW(req.wValue, (val & 0xff) | 0xff00); 2089 USETW(req.wIndex, (val >> 8) & 0x3); 2090 USETW(req.wLength, sizeof(uint32_t)); 2091 2092 error = urtw_do_request(sc, &req, data); 2093 return (error); 2094 } 2095 2096 static usb_error_t 2097 urtw_write8_c(struct urtw_softc *sc, int val, uint8_t data) 2098 { 2099 struct usb_device_request req; 2100 2101 URTW_ASSERT_LOCKED(sc); 2102 2103 req.bmRequestType = UT_WRITE_VENDOR_DEVICE; 2104 req.bRequest = URTW_8187_SETREGS_REQ; 2105 USETW(req.wValue, (val & 0xff) | 0xff00); 2106 USETW(req.wIndex, (val >> 8) & 0x3); 2107 USETW(req.wLength, sizeof(uint8_t)); 2108 2109 return (urtw_do_request(sc, &req, &data)); 2110 } 2111 2112 static usb_error_t 2113 urtw_write16_c(struct urtw_softc *sc, int val, uint16_t data) 2114 { 2115 struct usb_device_request req; 2116 2117 URTW_ASSERT_LOCKED(sc); 2118 2119 req.bmRequestType = UT_WRITE_VENDOR_DEVICE; 2120 req.bRequest = URTW_8187_SETREGS_REQ; 2121 USETW(req.wValue, (val & 0xff) | 0xff00); 2122 USETW(req.wIndex, (val >> 8) & 0x3); 2123 USETW(req.wLength, sizeof(uint16_t)); 2124 2125 return (urtw_do_request(sc, &req, &data)); 2126 } 2127 2128 static usb_error_t 2129 urtw_write32_c(struct urtw_softc *sc, int val, uint32_t data) 2130 { 2131 struct usb_device_request req; 2132 2133 URTW_ASSERT_LOCKED(sc); 2134 2135 req.bmRequestType = UT_WRITE_VENDOR_DEVICE; 2136 req.bRequest = URTW_8187_SETREGS_REQ; 2137 USETW(req.wValue, (val & 0xff) | 0xff00); 2138 USETW(req.wIndex, (val >> 8) & 0x3); 2139 USETW(req.wLength, sizeof(uint32_t)); 2140 2141 return (urtw_do_request(sc, &req, &data)); 2142 } 2143 2144 static usb_error_t 2145 urtw_get_macaddr(struct urtw_softc *sc) 2146 { 2147 uint32_t data; 2148 usb_error_t error; 2149 2150 error = urtw_eprom_read32(sc, URTW_EPROM_MACADDR, &data); 2151 if (error != 0) 2152 goto fail; 2153 sc->sc_bssid[0] = data & 0xff; 2154 sc->sc_bssid[1] = (data & 0xff00) >> 8; 2155 error = urtw_eprom_read32(sc, URTW_EPROM_MACADDR + 1, &data); 2156 if (error != 0) 2157 goto fail; 2158 sc->sc_bssid[2] = data & 0xff; 2159 sc->sc_bssid[3] = (data & 0xff00) >> 8; 2160 error = urtw_eprom_read32(sc, URTW_EPROM_MACADDR + 2, &data); 2161 if (error != 0) 2162 goto fail; 2163 sc->sc_bssid[4] = data & 0xff; 2164 sc->sc_bssid[5] = (data & 0xff00) >> 8; 2165 fail: 2166 return (error); 2167 } 2168 2169 static usb_error_t 2170 urtw_eprom_read32(struct urtw_softc *sc, uint32_t addr, uint32_t *data) 2171 { 2172 #define URTW_READCMD_LEN 3 2173 int addrlen, i; 2174 int16_t addrstr[8], data16, readcmd[] = { 1, 1, 0 }; 2175 usb_error_t error; 2176 2177 /* NB: make sure the buffer is initialized */ 2178 *data = 0; 2179 2180 /* enable EPROM programming */ 2181 urtw_write8_m(sc, URTW_EPROM_CMD, URTW_EPROM_CMD_PROGRAM_MODE); 2182 DELAY(URTW_EPROM_DELAY); 2183 2184 error = urtw_eprom_cs(sc, URTW_EPROM_ENABLE); 2185 if (error != 0) 2186 goto fail; 2187 error = urtw_eprom_ck(sc); 2188 if (error != 0) 2189 goto fail; 2190 error = urtw_eprom_sendbits(sc, readcmd, URTW_READCMD_LEN); 2191 if (error != 0) 2192 goto fail; 2193 if (sc->sc_epromtype == URTW_EEPROM_93C56) { 2194 addrlen = 8; 2195 addrstr[0] = addr & (1 << 7); 2196 addrstr[1] = addr & (1 << 6); 2197 addrstr[2] = addr & (1 << 5); 2198 addrstr[3] = addr & (1 << 4); 2199 addrstr[4] = addr & (1 << 3); 2200 addrstr[5] = addr & (1 << 2); 2201 addrstr[6] = addr & (1 << 1); 2202 addrstr[7] = addr & (1 << 0); 2203 } else { 2204 addrlen=6; 2205 addrstr[0] = addr & (1 << 5); 2206 addrstr[1] = addr & (1 << 4); 2207 addrstr[2] = addr & (1 << 3); 2208 addrstr[3] = addr & (1 << 2); 2209 addrstr[4] = addr & (1 << 1); 2210 addrstr[5] = addr & (1 << 0); 2211 } 2212 error = urtw_eprom_sendbits(sc, addrstr, addrlen); 2213 if (error != 0) 2214 goto fail; 2215 2216 error = urtw_eprom_writebit(sc, 0); 2217 if (error != 0) 2218 goto fail; 2219 2220 for (i = 0; i < 16; i++) { 2221 error = urtw_eprom_ck(sc); 2222 if (error != 0) 2223 goto fail; 2224 error = urtw_eprom_readbit(sc, &data16); 2225 if (error != 0) 2226 goto fail; 2227 2228 (*data) |= (data16 << (15 - i)); 2229 } 2230 2231 error = urtw_eprom_cs(sc, URTW_EPROM_DISABLE); 2232 if (error != 0) 2233 goto fail; 2234 error = urtw_eprom_ck(sc); 2235 if (error != 0) 2236 goto fail; 2237 2238 /* now disable EPROM programming */ 2239 urtw_write8_m(sc, URTW_EPROM_CMD, URTW_EPROM_CMD_NORMAL_MODE); 2240 fail: 2241 return (error); 2242 #undef URTW_READCMD_LEN 2243 } 2244 2245 static usb_error_t 2246 urtw_eprom_cs(struct urtw_softc *sc, int able) 2247 { 2248 uint8_t data; 2249 usb_error_t error; 2250 2251 urtw_read8_m(sc, URTW_EPROM_CMD, &data); 2252 if (able == URTW_EPROM_ENABLE) 2253 urtw_write8_m(sc, URTW_EPROM_CMD, data | URTW_EPROM_CS); 2254 else 2255 urtw_write8_m(sc, URTW_EPROM_CMD, data & ~URTW_EPROM_CS); 2256 DELAY(URTW_EPROM_DELAY); 2257 fail: 2258 return (error); 2259 } 2260 2261 static usb_error_t 2262 urtw_eprom_ck(struct urtw_softc *sc) 2263 { 2264 uint8_t data; 2265 usb_error_t error; 2266 2267 /* masking */ 2268 urtw_read8_m(sc, URTW_EPROM_CMD, &data); 2269 urtw_write8_m(sc, URTW_EPROM_CMD, data | URTW_EPROM_CK); 2270 DELAY(URTW_EPROM_DELAY); 2271 /* unmasking */ 2272 urtw_read8_m(sc, URTW_EPROM_CMD, &data); 2273 urtw_write8_m(sc, URTW_EPROM_CMD, data & ~URTW_EPROM_CK); 2274 DELAY(URTW_EPROM_DELAY); 2275 fail: 2276 return (error); 2277 } 2278 2279 static usb_error_t 2280 urtw_eprom_readbit(struct urtw_softc *sc, int16_t *data) 2281 { 2282 uint8_t data8; 2283 usb_error_t error; 2284 2285 urtw_read8_m(sc, URTW_EPROM_CMD, &data8); 2286 *data = (data8 & URTW_EPROM_READBIT) ? 1 : 0; 2287 DELAY(URTW_EPROM_DELAY); 2288 2289 fail: 2290 return (error); 2291 } 2292 2293 static usb_error_t 2294 urtw_eprom_writebit(struct urtw_softc *sc, int16_t bit) 2295 { 2296 uint8_t data; 2297 usb_error_t error; 2298 2299 urtw_read8_m(sc, URTW_EPROM_CMD, &data); 2300 if (bit != 0) 2301 urtw_write8_m(sc, URTW_EPROM_CMD, data | URTW_EPROM_WRITEBIT); 2302 else 2303 urtw_write8_m(sc, URTW_EPROM_CMD, data & ~URTW_EPROM_WRITEBIT); 2304 DELAY(URTW_EPROM_DELAY); 2305 fail: 2306 return (error); 2307 } 2308 2309 static usb_error_t 2310 urtw_eprom_sendbits(struct urtw_softc *sc, int16_t *buf, int buflen) 2311 { 2312 int i = 0; 2313 usb_error_t error = 0; 2314 2315 for (i = 0; i < buflen; i++) { 2316 error = urtw_eprom_writebit(sc, buf[i]); 2317 if (error != 0) 2318 goto fail; 2319 error = urtw_eprom_ck(sc); 2320 if (error != 0) 2321 goto fail; 2322 } 2323 fail: 2324 return (error); 2325 } 2326 2327 2328 static usb_error_t 2329 urtw_get_txpwr(struct urtw_softc *sc) 2330 { 2331 int i, j; 2332 uint32_t data; 2333 usb_error_t error; 2334 2335 error = urtw_eprom_read32(sc, URTW_EPROM_TXPW_BASE, &data); 2336 if (error != 0) 2337 goto fail; 2338 sc->sc_txpwr_cck_base = data & 0xf; 2339 sc->sc_txpwr_ofdm_base = (data >> 4) & 0xf; 2340 2341 for (i = 1, j = 0; i < 6; i += 2, j++) { 2342 error = urtw_eprom_read32(sc, URTW_EPROM_TXPW0 + j, &data); 2343 if (error != 0) 2344 goto fail; 2345 sc->sc_txpwr_cck[i] = data & 0xf; 2346 sc->sc_txpwr_cck[i + 1] = (data & 0xf00) >> 8; 2347 sc->sc_txpwr_ofdm[i] = (data & 0xf0) >> 4; 2348 sc->sc_txpwr_ofdm[i + 1] = (data & 0xf000) >> 12; 2349 } 2350 for (i = 1, j = 0; i < 4; i += 2, j++) { 2351 error = urtw_eprom_read32(sc, URTW_EPROM_TXPW1 + j, &data); 2352 if (error != 0) 2353 goto fail; 2354 sc->sc_txpwr_cck[i + 6] = data & 0xf; 2355 sc->sc_txpwr_cck[i + 6 + 1] = (data & 0xf00) >> 8; 2356 sc->sc_txpwr_ofdm[i + 6] = (data & 0xf0) >> 4; 2357 sc->sc_txpwr_ofdm[i + 6 + 1] = (data & 0xf000) >> 12; 2358 } 2359 if (sc->sc_flags & URTW_RTL8187B) { 2360 error = urtw_eprom_read32(sc, URTW_EPROM_TXPW2, &data); 2361 if (error != 0) 2362 goto fail; 2363 sc->sc_txpwr_cck[1 + 6 + 4] = data & 0xf; 2364 sc->sc_txpwr_ofdm[1 + 6 + 4] = (data & 0xf0) >> 4; 2365 error = urtw_eprom_read32(sc, 0x0a, &data); 2366 if (error != 0) 2367 goto fail; 2368 sc->sc_txpwr_cck[2 + 6 + 4] = data & 0xf; 2369 sc->sc_txpwr_ofdm[2 + 6 + 4] = (data & 0xf0) >> 4; 2370 error = urtw_eprom_read32(sc, 0x1c, &data); 2371 if (error != 0) 2372 goto fail; 2373 sc->sc_txpwr_cck[3 + 6 + 4] = data & 0xf; 2374 sc->sc_txpwr_cck[3 + 6 + 4 + 1] = (data & 0xf00) >> 8; 2375 sc->sc_txpwr_ofdm[3 + 6 + 4] = (data & 0xf0) >> 4; 2376 sc->sc_txpwr_ofdm[3 + 6 + 4 + 1] = (data & 0xf000) >> 12; 2377 } else { 2378 for (i = 1, j = 0; i < 4; i += 2, j++) { 2379 error = urtw_eprom_read32(sc, URTW_EPROM_TXPW2 + j, 2380 &data); 2381 if (error != 0) 2382 goto fail; 2383 sc->sc_txpwr_cck[i + 6 + 4] = data & 0xf; 2384 sc->sc_txpwr_cck[i + 6 + 4 + 1] = (data & 0xf00) >> 8; 2385 sc->sc_txpwr_ofdm[i + 6 + 4] = (data & 0xf0) >> 4; 2386 sc->sc_txpwr_ofdm[i + 6 + 4 + 1] = (data & 0xf000) >> 12; 2387 } 2388 } 2389 fail: 2390 return (error); 2391 } 2392 2393 2394 static usb_error_t 2395 urtw_get_rfchip(struct urtw_softc *sc) 2396 { 2397 int ret; 2398 uint8_t data8; 2399 uint32_t data; 2400 usb_error_t error; 2401 2402 if (sc->sc_flags & URTW_RTL8187B) { 2403 urtw_read8_m(sc, 0xe1, &data8); 2404 switch (data8) { 2405 case 0: 2406 sc->sc_flags |= URTW_RTL8187B_REV_B; 2407 break; 2408 case 1: 2409 sc->sc_flags |= URTW_RTL8187B_REV_D; 2410 break; 2411 case 2: 2412 sc->sc_flags |= URTW_RTL8187B_REV_E; 2413 break; 2414 default: 2415 device_printf(sc->sc_dev, "unknown type: %#x\n", data8); 2416 sc->sc_flags |= URTW_RTL8187B_REV_B; 2417 break; 2418 } 2419 } else { 2420 urtw_read32_m(sc, URTW_TX_CONF, &data); 2421 switch (data & URTW_TX_HWMASK) { 2422 case URTW_TX_R8187vD_B: 2423 sc->sc_flags |= URTW_RTL8187B; 2424 break; 2425 case URTW_TX_R8187vD: 2426 break; 2427 default: 2428 device_printf(sc->sc_dev, "unknown RTL8187L type: %#x\n", 2429 data & URTW_TX_HWMASK); 2430 break; 2431 } 2432 } 2433 2434 error = urtw_eprom_read32(sc, URTW_EPROM_RFCHIPID, &data); 2435 if (error != 0) 2436 goto fail; 2437 switch (data & 0xff) { 2438 case URTW_EPROM_RFCHIPID_RTL8225U: 2439 error = urtw_8225_isv2(sc, &ret); 2440 if (error != 0) 2441 goto fail; 2442 if (ret == 0) { 2443 sc->sc_rf_init = urtw_8225_rf_init; 2444 sc->sc_rf_set_sens = urtw_8225_rf_set_sens; 2445 sc->sc_rf_set_chan = urtw_8225_rf_set_chan; 2446 sc->sc_rf_stop = urtw_8225_rf_stop; 2447 } else { 2448 sc->sc_rf_init = urtw_8225v2_rf_init; 2449 sc->sc_rf_set_chan = urtw_8225v2_rf_set_chan; 2450 sc->sc_rf_stop = urtw_8225_rf_stop; 2451 } 2452 sc->sc_max_sens = URTW_8225_RF_MAX_SENS; 2453 sc->sc_sens = URTW_8225_RF_DEF_SENS; 2454 break; 2455 case URTW_EPROM_RFCHIPID_RTL8225Z2: 2456 sc->sc_rf_init = urtw_8225v2b_rf_init; 2457 sc->sc_rf_set_chan = urtw_8225v2b_rf_set_chan; 2458 sc->sc_max_sens = URTW_8225_RF_MAX_SENS; 2459 sc->sc_sens = URTW_8225_RF_DEF_SENS; 2460 sc->sc_rf_stop = urtw_8225_rf_stop; 2461 break; 2462 default: 2463 DPRINTF(sc, URTW_DEBUG_STATE, 2464 "unsupported RF chip %d\n", data & 0xff); 2465 error = USB_ERR_INVAL; 2466 goto fail; 2467 } 2468 2469 device_printf(sc->sc_dev, "%s rf %s hwrev %s\n", 2470 (sc->sc_flags & URTW_RTL8187B) ? "rtl8187b" : "rtl8187l", 2471 ((data & 0xff) == URTW_EPROM_RFCHIPID_RTL8225U) ? "rtl8225u" : 2472 "rtl8225z2", 2473 (sc->sc_flags & URTW_RTL8187B) ? ((data8 == 0) ? "b" : 2474 (data8 == 1) ? "d" : "e") : "none"); 2475 2476 fail: 2477 return (error); 2478 } 2479 2480 2481 static usb_error_t 2482 urtw_led_init(struct urtw_softc *sc) 2483 { 2484 uint32_t rev; 2485 usb_error_t error; 2486 2487 urtw_read8_m(sc, URTW_PSR, &sc->sc_psr); 2488 error = urtw_eprom_read32(sc, URTW_EPROM_SWREV, &rev); 2489 if (error != 0) 2490 goto fail; 2491 2492 switch (rev & URTW_EPROM_CID_MASK) { 2493 case URTW_EPROM_CID_ALPHA0: 2494 sc->sc_strategy = URTW_SW_LED_MODE1; 2495 break; 2496 case URTW_EPROM_CID_SERCOMM_PS: 2497 sc->sc_strategy = URTW_SW_LED_MODE3; 2498 break; 2499 case URTW_EPROM_CID_HW_LED: 2500 sc->sc_strategy = URTW_HW_LED; 2501 break; 2502 case URTW_EPROM_CID_RSVD0: 2503 case URTW_EPROM_CID_RSVD1: 2504 default: 2505 sc->sc_strategy = URTW_SW_LED_MODE0; 2506 break; 2507 } 2508 2509 sc->sc_gpio_ledpin = URTW_LED_PIN_GPIO0; 2510 2511 fail: 2512 return (error); 2513 } 2514 2515 2516 static usb_error_t 2517 urtw_8225_rf_init(struct urtw_softc *sc) 2518 { 2519 #define N(a) ((int)(sizeof(a) / sizeof((a)[0]))) 2520 int i; 2521 uint16_t data; 2522 usb_error_t error; 2523 2524 error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON); 2525 if (error) 2526 goto fail; 2527 2528 error = urtw_8225_usb_init(sc); 2529 if (error) 2530 goto fail; 2531 2532 urtw_write32_m(sc, URTW_RF_TIMING, 0x000a8008); 2533 urtw_read16_m(sc, URTW_BRSR, &data); /* XXX ??? */ 2534 urtw_write16_m(sc, URTW_BRSR, 0xffff); 2535 urtw_write32_m(sc, URTW_RF_PARA, 0x100044); 2536 2537 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 2538 if (error) 2539 goto fail; 2540 urtw_write8_m(sc, URTW_CONFIG3, 0x44); 2541 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 2542 if (error) 2543 goto fail; 2544 2545 error = urtw_8185_rf_pins_enable(sc); 2546 if (error) 2547 goto fail; 2548 usb_pause_mtx(&sc->sc_mtx, 1000); 2549 2550 for (i = 0; i < N(urtw_8225_rf_part1); i++) { 2551 urtw_8225_write(sc, urtw_8225_rf_part1[i].reg, 2552 urtw_8225_rf_part1[i].val); 2553 usb_pause_mtx(&sc->sc_mtx, 1); 2554 } 2555 usb_pause_mtx(&sc->sc_mtx, 100); 2556 urtw_8225_write(sc, 2557 URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC1); 2558 usb_pause_mtx(&sc->sc_mtx, 200); 2559 urtw_8225_write(sc, 2560 URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC2); 2561 usb_pause_mtx(&sc->sc_mtx, 200); 2562 urtw_8225_write(sc, 2563 URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC3); 2564 2565 for (i = 0; i < 95; i++) { 2566 urtw_8225_write(sc, URTW_8225_ADDR_1_MAGIC, (uint8_t)(i + 1)); 2567 urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, urtw_8225_rxgain[i]); 2568 } 2569 2570 urtw_8225_write(sc, 2571 URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC4); 2572 urtw_8225_write(sc, 2573 URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC5); 2574 2575 for (i = 0; i < 128; i++) { 2576 urtw_8187_write_phy_ofdm(sc, 0xb, urtw_8225_agc[i]); 2577 usb_pause_mtx(&sc->sc_mtx, 1); 2578 urtw_8187_write_phy_ofdm(sc, 0xa, (uint8_t)i + 0x80); 2579 usb_pause_mtx(&sc->sc_mtx, 1); 2580 } 2581 2582 for (i = 0; i < N(urtw_8225_rf_part2); i++) { 2583 urtw_8187_write_phy_ofdm(sc, urtw_8225_rf_part2[i].reg, 2584 urtw_8225_rf_part2[i].val); 2585 usb_pause_mtx(&sc->sc_mtx, 1); 2586 } 2587 2588 error = urtw_8225_setgain(sc, 4); 2589 if (error) 2590 goto fail; 2591 2592 for (i = 0; i < N(urtw_8225_rf_part3); i++) { 2593 urtw_8187_write_phy_cck(sc, urtw_8225_rf_part3[i].reg, 2594 urtw_8225_rf_part3[i].val); 2595 usb_pause_mtx(&sc->sc_mtx, 1); 2596 } 2597 2598 urtw_write8_m(sc, URTW_TESTR, 0x0d); 2599 2600 error = urtw_8225_set_txpwrlvl(sc, 1); 2601 if (error) 2602 goto fail; 2603 2604 urtw_8187_write_phy_cck(sc, 0x10, 0x9b); 2605 usb_pause_mtx(&sc->sc_mtx, 1); 2606 urtw_8187_write_phy_ofdm(sc, 0x26, 0x90); 2607 usb_pause_mtx(&sc->sc_mtx, 1); 2608 2609 /* TX ant A, 0x0 for B */ 2610 error = urtw_8185_tx_antenna(sc, 0x3); 2611 if (error) 2612 goto fail; 2613 urtw_write32_m(sc, URTW_HSSI_PARA, 0x3dc00002); 2614 2615 error = urtw_8225_rf_set_chan(sc, 1); 2616 fail: 2617 return (error); 2618 #undef N 2619 } 2620 2621 static usb_error_t 2622 urtw_8185_rf_pins_enable(struct urtw_softc *sc) 2623 { 2624 usb_error_t error = 0; 2625 2626 urtw_write16_m(sc, URTW_RF_PINS_ENABLE, 0x1ff7); 2627 fail: 2628 return (error); 2629 } 2630 2631 static usb_error_t 2632 urtw_8185_tx_antenna(struct urtw_softc *sc, uint8_t ant) 2633 { 2634 usb_error_t error; 2635 2636 urtw_write8_m(sc, URTW_TX_ANTENNA, ant); 2637 usb_pause_mtx(&sc->sc_mtx, 1); 2638 fail: 2639 return (error); 2640 } 2641 2642 static usb_error_t 2643 urtw_8187_write_phy_ofdm_c(struct urtw_softc *sc, uint8_t addr, uint32_t data) 2644 { 2645 2646 data = data & 0xff; 2647 return urtw_8187_write_phy(sc, addr, data); 2648 } 2649 2650 static usb_error_t 2651 urtw_8187_write_phy_cck_c(struct urtw_softc *sc, uint8_t addr, uint32_t data) 2652 { 2653 2654 data = data & 0xff; 2655 return urtw_8187_write_phy(sc, addr, data | 0x10000); 2656 } 2657 2658 static usb_error_t 2659 urtw_8187_write_phy(struct urtw_softc *sc, uint8_t addr, uint32_t data) 2660 { 2661 uint32_t phyw; 2662 usb_error_t error; 2663 2664 phyw = ((data << 8) | (addr | 0x80)); 2665 urtw_write8_m(sc, URTW_PHY_MAGIC4, ((phyw & 0xff000000) >> 24)); 2666 urtw_write8_m(sc, URTW_PHY_MAGIC3, ((phyw & 0x00ff0000) >> 16)); 2667 urtw_write8_m(sc, URTW_PHY_MAGIC2, ((phyw & 0x0000ff00) >> 8)); 2668 urtw_write8_m(sc, URTW_PHY_MAGIC1, ((phyw & 0x000000ff))); 2669 usb_pause_mtx(&sc->sc_mtx, 1); 2670 fail: 2671 return (error); 2672 } 2673 2674 static usb_error_t 2675 urtw_8225_setgain(struct urtw_softc *sc, int16_t gain) 2676 { 2677 usb_error_t error; 2678 2679 urtw_8187_write_phy_ofdm(sc, 0x0d, urtw_8225_gain[gain * 4]); 2680 urtw_8187_write_phy_ofdm(sc, 0x1b, urtw_8225_gain[gain * 4 + 2]); 2681 urtw_8187_write_phy_ofdm(sc, 0x1d, urtw_8225_gain[gain * 4 + 3]); 2682 urtw_8187_write_phy_ofdm(sc, 0x23, urtw_8225_gain[gain * 4 + 1]); 2683 fail: 2684 return (error); 2685 } 2686 2687 static usb_error_t 2688 urtw_8225_usb_init(struct urtw_softc *sc) 2689 { 2690 uint8_t data; 2691 usb_error_t error; 2692 2693 urtw_write8_m(sc, URTW_RF_PINS_SELECT + 1, 0); 2694 urtw_write8_m(sc, URTW_GPIO, 0); 2695 error = urtw_read8e(sc, 0x53, &data); 2696 if (error) 2697 goto fail; 2698 error = urtw_write8e(sc, 0x53, data | (1 << 7)); 2699 if (error) 2700 goto fail; 2701 urtw_write8_m(sc, URTW_RF_PINS_SELECT + 1, 4); 2702 urtw_write8_m(sc, URTW_GPIO, 0x20); 2703 urtw_write8_m(sc, URTW_GP_ENABLE, 0); 2704 2705 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 0x80); 2706 urtw_write16_m(sc, URTW_RF_PINS_SELECT, 0x80); 2707 urtw_write16_m(sc, URTW_RF_PINS_ENABLE, 0x80); 2708 2709 usb_pause_mtx(&sc->sc_mtx, 500); 2710 fail: 2711 return (error); 2712 } 2713 2714 static usb_error_t 2715 urtw_8225_write_c(struct urtw_softc *sc, uint8_t addr, uint16_t data) 2716 { 2717 uint16_t d80, d82, d84; 2718 usb_error_t error; 2719 2720 urtw_read16_m(sc, URTW_RF_PINS_OUTPUT, &d80); 2721 d80 &= URTW_RF_PINS_MAGIC1; 2722 urtw_read16_m(sc, URTW_RF_PINS_ENABLE, &d82); 2723 urtw_read16_m(sc, URTW_RF_PINS_SELECT, &d84); 2724 d84 &= URTW_RF_PINS_MAGIC2; 2725 urtw_write16_m(sc, URTW_RF_PINS_ENABLE, d82 | URTW_RF_PINS_MAGIC3); 2726 urtw_write16_m(sc, URTW_RF_PINS_SELECT, d84 | URTW_RF_PINS_MAGIC3); 2727 DELAY(10); 2728 2729 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80 | URTW_BB_HOST_BANG_EN); 2730 DELAY(2); 2731 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80); 2732 DELAY(10); 2733 2734 error = urtw_8225_write_s16(sc, addr, 0x8225, &data); 2735 if (error != 0) 2736 goto fail; 2737 2738 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80 | URTW_BB_HOST_BANG_EN); 2739 DELAY(10); 2740 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, d80 | URTW_BB_HOST_BANG_EN); 2741 urtw_write16_m(sc, URTW_RF_PINS_SELECT, d84); 2742 usb_pause_mtx(&sc->sc_mtx, 2); 2743 fail: 2744 return (error); 2745 } 2746 2747 static usb_error_t 2748 urtw_8225_write_s16(struct urtw_softc *sc, uint8_t addr, int index, 2749 uint16_t *data) 2750 { 2751 uint8_t buf[2]; 2752 uint16_t data16; 2753 struct usb_device_request req; 2754 usb_error_t error = 0; 2755 2756 data16 = *data; 2757 2758 req.bmRequestType = UT_WRITE_VENDOR_DEVICE; 2759 req.bRequest = URTW_8187_SETREGS_REQ; 2760 USETW(req.wValue, addr); 2761 USETW(req.wIndex, index); 2762 USETW(req.wLength, sizeof(uint16_t)); 2763 buf[0] = (data16 & 0x00ff); 2764 buf[1] = (data16 & 0xff00) >> 8; 2765 2766 error = urtw_do_request(sc, &req, buf); 2767 2768 return (error); 2769 } 2770 2771 static usb_error_t 2772 urtw_8225_rf_set_chan(struct urtw_softc *sc, int chan) 2773 { 2774 usb_error_t error; 2775 2776 error = urtw_8225_set_txpwrlvl(sc, chan); 2777 if (error) 2778 goto fail; 2779 urtw_8225_write(sc, URTW_8225_ADDR_7_MAGIC, urtw_8225_channel[chan]); 2780 usb_pause_mtx(&sc->sc_mtx, 10); 2781 fail: 2782 return (error); 2783 } 2784 2785 static usb_error_t 2786 urtw_8225_rf_set_sens(struct urtw_softc *sc, int sens) 2787 { 2788 usb_error_t error; 2789 2790 if (sens < 0 || sens > 6) 2791 return -1; 2792 2793 if (sens > 4) 2794 urtw_8225_write(sc, 2795 URTW_8225_ADDR_C_MAGIC, URTW_8225_ADDR_C_DATA_MAGIC1); 2796 else 2797 urtw_8225_write(sc, 2798 URTW_8225_ADDR_C_MAGIC, URTW_8225_ADDR_C_DATA_MAGIC2); 2799 2800 sens = 6 - sens; 2801 error = urtw_8225_setgain(sc, sens); 2802 if (error) 2803 goto fail; 2804 2805 urtw_8187_write_phy_cck(sc, 0x41, urtw_8225_threshold[sens]); 2806 2807 fail: 2808 return (error); 2809 } 2810 2811 static usb_error_t 2812 urtw_8225_set_txpwrlvl(struct urtw_softc *sc, int chan) 2813 { 2814 int i, idx, set; 2815 uint8_t *cck_pwltable; 2816 uint8_t cck_pwrlvl_max, ofdm_pwrlvl_min, ofdm_pwrlvl_max; 2817 uint8_t cck_pwrlvl = sc->sc_txpwr_cck[chan] & 0xff; 2818 uint8_t ofdm_pwrlvl = sc->sc_txpwr_ofdm[chan] & 0xff; 2819 usb_error_t error; 2820 2821 cck_pwrlvl_max = 11; 2822 ofdm_pwrlvl_max = 25; /* 12 -> 25 */ 2823 ofdm_pwrlvl_min = 10; 2824 2825 /* CCK power setting */ 2826 cck_pwrlvl = (cck_pwrlvl > cck_pwrlvl_max) ? cck_pwrlvl_max : cck_pwrlvl; 2827 idx = cck_pwrlvl % 6; 2828 set = cck_pwrlvl / 6; 2829 cck_pwltable = (chan == 14) ? urtw_8225_txpwr_cck_ch14 : 2830 urtw_8225_txpwr_cck; 2831 2832 urtw_write8_m(sc, URTW_TX_GAIN_CCK, 2833 urtw_8225_tx_gain_cck_ofdm[set] >> 1); 2834 for (i = 0; i < 8; i++) { 2835 urtw_8187_write_phy_cck(sc, 0x44 + i, 2836 cck_pwltable[idx * 8 + i]); 2837 } 2838 usb_pause_mtx(&sc->sc_mtx, 1); 2839 2840 /* OFDM power setting */ 2841 ofdm_pwrlvl = (ofdm_pwrlvl > (ofdm_pwrlvl_max - ofdm_pwrlvl_min)) ? 2842 ofdm_pwrlvl_max : ofdm_pwrlvl + ofdm_pwrlvl_min; 2843 ofdm_pwrlvl = (ofdm_pwrlvl > 35) ? 35 : ofdm_pwrlvl; 2844 2845 idx = ofdm_pwrlvl % 6; 2846 set = ofdm_pwrlvl / 6; 2847 2848 error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON); 2849 if (error) 2850 goto fail; 2851 urtw_8187_write_phy_ofdm(sc, 2, 0x42); 2852 urtw_8187_write_phy_ofdm(sc, 6, 0); 2853 urtw_8187_write_phy_ofdm(sc, 8, 0); 2854 2855 urtw_write8_m(sc, URTW_TX_GAIN_OFDM, 2856 urtw_8225_tx_gain_cck_ofdm[set] >> 1); 2857 urtw_8187_write_phy_ofdm(sc, 0x5, urtw_8225_txpwr_ofdm[idx]); 2858 urtw_8187_write_phy_ofdm(sc, 0x7, urtw_8225_txpwr_ofdm[idx]); 2859 usb_pause_mtx(&sc->sc_mtx, 1); 2860 fail: 2861 return (error); 2862 } 2863 2864 2865 static usb_error_t 2866 urtw_8225_rf_stop(struct urtw_softc *sc) 2867 { 2868 uint8_t data; 2869 usb_error_t error; 2870 2871 urtw_8225_write(sc, 0x4, 0x1f); 2872 2873 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 2874 if (error) 2875 goto fail; 2876 2877 urtw_read8_m(sc, URTW_CONFIG3, &data); 2878 urtw_write8_m(sc, URTW_CONFIG3, data | URTW_CONFIG3_ANAPARAM_WRITE); 2879 if (sc->sc_flags & URTW_RTL8187B) { 2880 urtw_write32_m(sc, URTW_ANAPARAM2, 2881 URTW_8187B_8225_ANAPARAM2_OFF); 2882 urtw_write32_m(sc, URTW_ANAPARAM, URTW_8187B_8225_ANAPARAM_OFF); 2883 urtw_write32_m(sc, URTW_ANAPARAM3, 2884 URTW_8187B_8225_ANAPARAM3_OFF); 2885 } else { 2886 urtw_write32_m(sc, URTW_ANAPARAM2, URTW_8225_ANAPARAM2_OFF); 2887 urtw_write32_m(sc, URTW_ANAPARAM, URTW_8225_ANAPARAM_OFF); 2888 } 2889 2890 urtw_write8_m(sc, URTW_CONFIG3, data & ~URTW_CONFIG3_ANAPARAM_WRITE); 2891 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 2892 if (error) 2893 goto fail; 2894 2895 fail: 2896 return (error); 2897 } 2898 2899 static usb_error_t 2900 urtw_8225v2_rf_init(struct urtw_softc *sc) 2901 { 2902 #define N(a) ((int)(sizeof(a) / sizeof((a)[0]))) 2903 int i; 2904 uint16_t data; 2905 uint32_t data32; 2906 usb_error_t error; 2907 2908 error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON); 2909 if (error) 2910 goto fail; 2911 2912 error = urtw_8225_usb_init(sc); 2913 if (error) 2914 goto fail; 2915 2916 urtw_write32_m(sc, URTW_RF_TIMING, 0x000a8008); 2917 urtw_read16_m(sc, URTW_BRSR, &data); /* XXX ??? */ 2918 urtw_write16_m(sc, URTW_BRSR, 0xffff); 2919 urtw_write32_m(sc, URTW_RF_PARA, 0x100044); 2920 2921 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 2922 if (error) 2923 goto fail; 2924 urtw_write8_m(sc, URTW_CONFIG3, 0x44); 2925 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 2926 if (error) 2927 goto fail; 2928 2929 error = urtw_8185_rf_pins_enable(sc); 2930 if (error) 2931 goto fail; 2932 2933 usb_pause_mtx(&sc->sc_mtx, 500); 2934 2935 for (i = 0; i < N(urtw_8225v2_rf_part1); i++) { 2936 urtw_8225_write(sc, urtw_8225v2_rf_part1[i].reg, 2937 urtw_8225v2_rf_part1[i].val); 2938 } 2939 usb_pause_mtx(&sc->sc_mtx, 50); 2940 2941 urtw_8225_write(sc, 2942 URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC1); 2943 2944 for (i = 0; i < 95; i++) { 2945 urtw_8225_write(sc, URTW_8225_ADDR_1_MAGIC, (uint8_t)(i + 1)); 2946 urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, 2947 urtw_8225v2_rxgain[i]); 2948 } 2949 2950 urtw_8225_write(sc, 2951 URTW_8225_ADDR_3_MAGIC, URTW_8225_ADDR_3_DATA_MAGIC1); 2952 urtw_8225_write(sc, 2953 URTW_8225_ADDR_5_MAGIC, URTW_8225_ADDR_5_DATA_MAGIC1); 2954 urtw_8225_write(sc, 2955 URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC2); 2956 urtw_8225_write(sc, 2957 URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC1); 2958 usb_pause_mtx(&sc->sc_mtx, 100); 2959 urtw_8225_write(sc, 2960 URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC2); 2961 usb_pause_mtx(&sc->sc_mtx, 100); 2962 2963 error = urtw_8225_read(sc, URTW_8225_ADDR_6_MAGIC, &data32); 2964 if (error != 0) 2965 goto fail; 2966 if (data32 != URTW_8225_ADDR_6_DATA_MAGIC1) 2967 device_printf(sc->sc_dev, "expect 0xe6!! (0x%x)\n", data32); 2968 if (!(data32 & URTW_8225_ADDR_6_DATA_MAGIC2)) { 2969 urtw_8225_write(sc, 2970 URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC1); 2971 usb_pause_mtx(&sc->sc_mtx, 100); 2972 urtw_8225_write(sc, 2973 URTW_8225_ADDR_2_MAGIC, URTW_8225_ADDR_2_DATA_MAGIC2); 2974 usb_pause_mtx(&sc->sc_mtx, 50); 2975 error = urtw_8225_read(sc, URTW_8225_ADDR_6_MAGIC, &data32); 2976 if (error != 0) 2977 goto fail; 2978 if (!(data32 & URTW_8225_ADDR_6_DATA_MAGIC2)) 2979 device_printf(sc->sc_dev, "RF calibration failed\n"); 2980 } 2981 usb_pause_mtx(&sc->sc_mtx, 100); 2982 2983 urtw_8225_write(sc, 2984 URTW_8225_ADDR_0_MAGIC, URTW_8225_ADDR_0_DATA_MAGIC6); 2985 for (i = 0; i < 128; i++) { 2986 urtw_8187_write_phy_ofdm(sc, 0xb, urtw_8225_agc[i]); 2987 urtw_8187_write_phy_ofdm(sc, 0xa, (uint8_t)i + 0x80); 2988 } 2989 2990 for (i = 0; i < N(urtw_8225v2_rf_part2); i++) { 2991 urtw_8187_write_phy_ofdm(sc, urtw_8225v2_rf_part2[i].reg, 2992 urtw_8225v2_rf_part2[i].val); 2993 } 2994 2995 error = urtw_8225v2_setgain(sc, 4); 2996 if (error) 2997 goto fail; 2998 2999 for (i = 0; i < N(urtw_8225v2_rf_part3); i++) { 3000 urtw_8187_write_phy_cck(sc, urtw_8225v2_rf_part3[i].reg, 3001 urtw_8225v2_rf_part3[i].val); 3002 } 3003 3004 urtw_write8_m(sc, URTW_TESTR, 0x0d); 3005 3006 error = urtw_8225v2_set_txpwrlvl(sc, 1); 3007 if (error) 3008 goto fail; 3009 3010 urtw_8187_write_phy_cck(sc, 0x10, 0x9b); 3011 urtw_8187_write_phy_ofdm(sc, 0x26, 0x90); 3012 3013 /* TX ant A, 0x0 for B */ 3014 error = urtw_8185_tx_antenna(sc, 0x3); 3015 if (error) 3016 goto fail; 3017 urtw_write32_m(sc, URTW_HSSI_PARA, 0x3dc00002); 3018 3019 error = urtw_8225_rf_set_chan(sc, 1); 3020 fail: 3021 return (error); 3022 #undef N 3023 } 3024 3025 static usb_error_t 3026 urtw_8225v2_rf_set_chan(struct urtw_softc *sc, int chan) 3027 { 3028 usb_error_t error; 3029 3030 error = urtw_8225v2_set_txpwrlvl(sc, chan); 3031 if (error) 3032 goto fail; 3033 3034 urtw_8225_write(sc, URTW_8225_ADDR_7_MAGIC, urtw_8225_channel[chan]); 3035 usb_pause_mtx(&sc->sc_mtx, 10); 3036 fail: 3037 return (error); 3038 } 3039 3040 static usb_error_t 3041 urtw_8225_read(struct urtw_softc *sc, uint8_t addr, uint32_t *data) 3042 { 3043 int i; 3044 int16_t bit; 3045 uint8_t rlen = 12, wlen = 6; 3046 uint16_t o1, o2, o3, tmp; 3047 uint32_t d2w = ((uint32_t)(addr & 0x1f)) << 27; 3048 uint32_t mask = 0x80000000, value = 0; 3049 usb_error_t error; 3050 3051 urtw_read16_m(sc, URTW_RF_PINS_OUTPUT, &o1); 3052 urtw_read16_m(sc, URTW_RF_PINS_ENABLE, &o2); 3053 urtw_read16_m(sc, URTW_RF_PINS_SELECT, &o3); 3054 urtw_write16_m(sc, URTW_RF_PINS_ENABLE, o2 | URTW_RF_PINS_MAGIC4); 3055 urtw_write16_m(sc, URTW_RF_PINS_SELECT, o3 | URTW_RF_PINS_MAGIC4); 3056 o1 &= ~URTW_RF_PINS_MAGIC4; 3057 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1 | URTW_BB_HOST_BANG_EN); 3058 DELAY(5); 3059 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1); 3060 DELAY(5); 3061 3062 for (i = 0; i < (wlen / 2); i++, mask = mask >> 1) { 3063 bit = ((d2w & mask) != 0) ? 1 : 0; 3064 3065 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1); 3066 DELAY(2); 3067 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | 3068 URTW_BB_HOST_BANG_CLK); 3069 DELAY(2); 3070 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | 3071 URTW_BB_HOST_BANG_CLK); 3072 DELAY(2); 3073 mask = mask >> 1; 3074 if (i == 2) 3075 break; 3076 bit = ((d2w & mask) != 0) ? 1 : 0; 3077 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | 3078 URTW_BB_HOST_BANG_CLK); 3079 DELAY(2); 3080 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | 3081 URTW_BB_HOST_BANG_CLK); 3082 DELAY(2); 3083 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1); 3084 DELAY(1); 3085 } 3086 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | URTW_BB_HOST_BANG_RW | 3087 URTW_BB_HOST_BANG_CLK); 3088 DELAY(2); 3089 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, bit | o1 | URTW_BB_HOST_BANG_RW); 3090 DELAY(2); 3091 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1 | URTW_BB_HOST_BANG_RW); 3092 DELAY(2); 3093 3094 mask = 0x800; 3095 for (i = 0; i < rlen; i++, mask = mask >> 1) { 3096 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 3097 o1 | URTW_BB_HOST_BANG_RW); 3098 DELAY(2); 3099 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 3100 o1 | URTW_BB_HOST_BANG_RW | URTW_BB_HOST_BANG_CLK); 3101 DELAY(2); 3102 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 3103 o1 | URTW_BB_HOST_BANG_RW | URTW_BB_HOST_BANG_CLK); 3104 DELAY(2); 3105 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 3106 o1 | URTW_BB_HOST_BANG_RW | URTW_BB_HOST_BANG_CLK); 3107 DELAY(2); 3108 3109 urtw_read16_m(sc, URTW_RF_PINS_INPUT, &tmp); 3110 value |= ((tmp & URTW_BB_HOST_BANG_CLK) ? mask : 0); 3111 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 3112 o1 | URTW_BB_HOST_BANG_RW); 3113 DELAY(2); 3114 } 3115 3116 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, o1 | URTW_BB_HOST_BANG_EN | 3117 URTW_BB_HOST_BANG_RW); 3118 DELAY(2); 3119 3120 urtw_write16_m(sc, URTW_RF_PINS_ENABLE, o2); 3121 urtw_write16_m(sc, URTW_RF_PINS_SELECT, o3); 3122 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, URTW_RF_PINS_OUTPUT_MAGIC1); 3123 3124 if (data != NULL) 3125 *data = value; 3126 fail: 3127 return (error); 3128 } 3129 3130 3131 static usb_error_t 3132 urtw_8225v2_set_txpwrlvl(struct urtw_softc *sc, int chan) 3133 { 3134 int i; 3135 uint8_t *cck_pwrtable; 3136 uint8_t cck_pwrlvl_max = 15, ofdm_pwrlvl_max = 25, ofdm_pwrlvl_min = 10; 3137 uint8_t cck_pwrlvl = sc->sc_txpwr_cck[chan] & 0xff; 3138 uint8_t ofdm_pwrlvl = sc->sc_txpwr_ofdm[chan] & 0xff; 3139 usb_error_t error; 3140 3141 /* CCK power setting */ 3142 cck_pwrlvl = (cck_pwrlvl > cck_pwrlvl_max) ? cck_pwrlvl_max : cck_pwrlvl; 3143 cck_pwrlvl += sc->sc_txpwr_cck_base; 3144 cck_pwrlvl = (cck_pwrlvl > 35) ? 35 : cck_pwrlvl; 3145 cck_pwrtable = (chan == 14) ? urtw_8225v2_txpwr_cck_ch14 : 3146 urtw_8225v2_txpwr_cck; 3147 3148 for (i = 0; i < 8; i++) 3149 urtw_8187_write_phy_cck(sc, 0x44 + i, cck_pwrtable[i]); 3150 3151 urtw_write8_m(sc, URTW_TX_GAIN_CCK, 3152 urtw_8225v2_tx_gain_cck_ofdm[cck_pwrlvl]); 3153 usb_pause_mtx(&sc->sc_mtx, 1); 3154 3155 /* OFDM power setting */ 3156 ofdm_pwrlvl = (ofdm_pwrlvl > (ofdm_pwrlvl_max - ofdm_pwrlvl_min)) ? 3157 ofdm_pwrlvl_max : ofdm_pwrlvl + ofdm_pwrlvl_min; 3158 ofdm_pwrlvl += sc->sc_txpwr_ofdm_base; 3159 ofdm_pwrlvl = (ofdm_pwrlvl > 35) ? 35 : ofdm_pwrlvl; 3160 3161 error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON); 3162 if (error) 3163 goto fail; 3164 3165 urtw_8187_write_phy_ofdm(sc, 2, 0x42); 3166 urtw_8187_write_phy_ofdm(sc, 5, 0x0); 3167 urtw_8187_write_phy_ofdm(sc, 6, 0x40); 3168 urtw_8187_write_phy_ofdm(sc, 7, 0x0); 3169 urtw_8187_write_phy_ofdm(sc, 8, 0x40); 3170 3171 urtw_write8_m(sc, URTW_TX_GAIN_OFDM, 3172 urtw_8225v2_tx_gain_cck_ofdm[ofdm_pwrlvl]); 3173 usb_pause_mtx(&sc->sc_mtx, 1); 3174 fail: 3175 return (error); 3176 } 3177 3178 static usb_error_t 3179 urtw_8225v2_setgain(struct urtw_softc *sc, int16_t gain) 3180 { 3181 uint8_t *gainp; 3182 usb_error_t error; 3183 3184 /* XXX for A? */ 3185 gainp = urtw_8225v2_gain_bg; 3186 urtw_8187_write_phy_ofdm(sc, 0x0d, gainp[gain * 3]); 3187 usb_pause_mtx(&sc->sc_mtx, 1); 3188 urtw_8187_write_phy_ofdm(sc, 0x1b, gainp[gain * 3 + 1]); 3189 usb_pause_mtx(&sc->sc_mtx, 1); 3190 urtw_8187_write_phy_ofdm(sc, 0x1d, gainp[gain * 3 + 2]); 3191 usb_pause_mtx(&sc->sc_mtx, 1); 3192 urtw_8187_write_phy_ofdm(sc, 0x21, 0x17); 3193 usb_pause_mtx(&sc->sc_mtx, 1); 3194 fail: 3195 return (error); 3196 } 3197 3198 static usb_error_t 3199 urtw_8225_isv2(struct urtw_softc *sc, int *ret) 3200 { 3201 uint32_t data; 3202 usb_error_t error; 3203 3204 *ret = 1; 3205 3206 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, URTW_RF_PINS_MAGIC5); 3207 urtw_write16_m(sc, URTW_RF_PINS_SELECT, URTW_RF_PINS_MAGIC5); 3208 urtw_write16_m(sc, URTW_RF_PINS_ENABLE, URTW_RF_PINS_MAGIC5); 3209 usb_pause_mtx(&sc->sc_mtx, 500); 3210 3211 urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC, 3212 URTW_8225_ADDR_0_DATA_MAGIC1); 3213 3214 error = urtw_8225_read(sc, URTW_8225_ADDR_8_MAGIC, &data); 3215 if (error != 0) 3216 goto fail; 3217 if (data != URTW_8225_ADDR_8_DATA_MAGIC1) 3218 *ret = 0; 3219 else { 3220 error = urtw_8225_read(sc, URTW_8225_ADDR_9_MAGIC, &data); 3221 if (error != 0) 3222 goto fail; 3223 if (data != URTW_8225_ADDR_9_DATA_MAGIC1) 3224 *ret = 0; 3225 } 3226 3227 urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC, 3228 URTW_8225_ADDR_0_DATA_MAGIC2); 3229 fail: 3230 return (error); 3231 } 3232 3233 static usb_error_t 3234 urtw_8225v2b_rf_init(struct urtw_softc *sc) 3235 { 3236 #define N(a) ((int)(sizeof(a) / sizeof((a)[0]))) 3237 int i; 3238 uint8_t data8; 3239 usb_error_t error; 3240 3241 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 3242 if (error) 3243 goto fail; 3244 3245 /* 3246 * initialize extra registers on 8187 3247 */ 3248 urtw_write16_m(sc, URTW_BRSR_8187B, 0xfff); 3249 3250 /* retry limit */ 3251 urtw_read8_m(sc, URTW_CW_CONF, &data8); 3252 data8 |= URTW_CW_CONF_PERPACKET_RETRY; 3253 urtw_write8_m(sc, URTW_CW_CONF, data8); 3254 3255 /* TX AGC */ 3256 urtw_read8_m(sc, URTW_TX_AGC_CTL, &data8); 3257 data8 |= URTW_TX_AGC_CTL_PERPACKET_GAIN; 3258 urtw_write8_m(sc, URTW_TX_AGC_CTL, data8); 3259 3260 /* Auto Rate Fallback Control */ 3261 #define URTW_ARFR 0x1e0 3262 urtw_write16_m(sc, URTW_ARFR, 0xfff); 3263 urtw_read8_m(sc, URTW_RATE_FALLBACK, &data8); 3264 urtw_write8_m(sc, URTW_RATE_FALLBACK, 3265 data8 | URTW_RATE_FALLBACK_ENABLE); 3266 3267 urtw_read8_m(sc, URTW_MSR, &data8); 3268 urtw_write8_m(sc, URTW_MSR, data8 & 0xf3); 3269 urtw_read8_m(sc, URTW_MSR, &data8); 3270 urtw_write8_m(sc, URTW_MSR, data8 | URTW_MSR_LINK_ENEDCA); 3271 urtw_write8_m(sc, URTW_ACM_CONTROL, sc->sc_acmctl); 3272 3273 urtw_write16_m(sc, URTW_ATIM_WND, 2); 3274 urtw_write16_m(sc, URTW_BEACON_INTERVAL, 100); 3275 #define URTW_FEMR_FOR_8187B 0x1d4 3276 urtw_write16_m(sc, URTW_FEMR_FOR_8187B, 0xffff); 3277 3278 /* led type */ 3279 urtw_read8_m(sc, URTW_CONFIG1, &data8); 3280 data8 = (data8 & 0x3f) | 0x80; 3281 urtw_write8_m(sc, URTW_CONFIG1, data8); 3282 3283 /* applying MAC address again. */ 3284 urtw_write32_m(sc, URTW_MAC0, ((uint32_t *)sc->sc_bssid)[0]); 3285 urtw_write16_m(sc, URTW_MAC4, ((uint32_t *)sc->sc_bssid)[1] & 0xffff); 3286 3287 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 3288 if (error) 3289 goto fail; 3290 3291 urtw_write8_m(sc, URTW_WPA_CONFIG, 0); 3292 3293 /* 3294 * MAC configuration 3295 */ 3296 for (i = 0; i < N(urtw_8225v2b_rf_part1); i++) 3297 urtw_write8_m(sc, urtw_8225v2b_rf_part1[i].reg, 3298 urtw_8225v2b_rf_part1[i].val); 3299 urtw_write16_m(sc, URTW_TID_AC_MAP, 0xfa50); 3300 urtw_write16_m(sc, URTW_INT_MIG, 0x0000); 3301 urtw_write32_m(sc, 0x1f0, 0); 3302 urtw_write32_m(sc, 0x1f4, 0); 3303 urtw_write8_m(sc, 0x1f8, 0); 3304 urtw_write32_m(sc, URTW_RF_TIMING, 0x4001); 3305 3306 #define URTW_RFSW_CTRL 0x272 3307 urtw_write16_m(sc, URTW_RFSW_CTRL, 0x569a); 3308 3309 /* 3310 * initialize PHY 3311 */ 3312 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 3313 if (error) 3314 goto fail; 3315 urtw_read8_m(sc, URTW_CONFIG3, &data8); 3316 urtw_write8_m(sc, URTW_CONFIG3, 3317 data8 | URTW_CONFIG3_ANAPARAM_WRITE); 3318 3319 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 3320 if (error) 3321 goto fail; 3322 3323 /* setup RFE initial timing */ 3324 urtw_write16_m(sc, URTW_RF_PINS_OUTPUT, 0x0480); 3325 urtw_write16_m(sc, URTW_RF_PINS_SELECT, 0x2488); 3326 urtw_write16_m(sc, URTW_RF_PINS_ENABLE, 0x1fff); 3327 usb_pause_mtx(&sc->sc_mtx, 1100); 3328 3329 for (i = 0; i < N(urtw_8225v2b_rf_part0); i++) { 3330 urtw_8225_write(sc, urtw_8225v2b_rf_part0[i].reg, 3331 urtw_8225v2b_rf_part0[i].val); 3332 usb_pause_mtx(&sc->sc_mtx, 1); 3333 } 3334 urtw_8225_write(sc, 0x00, 0x01b7); 3335 3336 for (i = 0; i < 95; i++) { 3337 urtw_8225_write(sc, URTW_8225_ADDR_1_MAGIC, (uint8_t)(i + 1)); 3338 usb_pause_mtx(&sc->sc_mtx, 1); 3339 urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, 3340 urtw_8225v2b_rxgain[i]); 3341 usb_pause_mtx(&sc->sc_mtx, 1); 3342 } 3343 3344 urtw_8225_write(sc, URTW_8225_ADDR_3_MAGIC, 0x080); 3345 usb_pause_mtx(&sc->sc_mtx, 1); 3346 urtw_8225_write(sc, URTW_8225_ADDR_5_MAGIC, 0x004); 3347 usb_pause_mtx(&sc->sc_mtx, 1); 3348 urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC, 0x0b7); 3349 usb_pause_mtx(&sc->sc_mtx, 1); 3350 usb_pause_mtx(&sc->sc_mtx, 3000); 3351 urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, 0xc4d); 3352 usb_pause_mtx(&sc->sc_mtx, 2000); 3353 urtw_8225_write(sc, URTW_8225_ADDR_2_MAGIC, 0x44d); 3354 usb_pause_mtx(&sc->sc_mtx, 1); 3355 urtw_8225_write(sc, URTW_8225_ADDR_0_MAGIC, 0x2bf); 3356 usb_pause_mtx(&sc->sc_mtx, 1); 3357 3358 urtw_write8_m(sc, URTW_TX_GAIN_CCK, 0x03); 3359 urtw_write8_m(sc, URTW_TX_GAIN_OFDM, 0x07); 3360 urtw_write8_m(sc, URTW_TX_ANTENNA, 0x03); 3361 3362 urtw_8187_write_phy_ofdm(sc, 0x80, 0x12); 3363 for (i = 0; i < 128; i++) { 3364 uint32_t addr, data; 3365 3366 data = (urtw_8225z2_agc[i] << 8) | 0x0000008f; 3367 addr = ((i + 0x80) << 8) | 0x0000008e; 3368 3369 urtw_8187_write_phy_ofdm(sc, data & 0x7f, (data >> 8) & 0xff); 3370 urtw_8187_write_phy_ofdm(sc, addr & 0x7f, (addr >> 8) & 0xff); 3371 urtw_8187_write_phy_ofdm(sc, 0x0e, 0x00); 3372 } 3373 urtw_8187_write_phy_ofdm(sc, 0x80, 0x10); 3374 3375 for (i = 0; i < N(urtw_8225v2b_rf_part2); i++) 3376 urtw_8187_write_phy_ofdm(sc, i, urtw_8225v2b_rf_part2[i].val); 3377 3378 urtw_write32_m(sc, URTW_8187B_AC_VO, (7 << 12) | (3 << 8) | 0x1c); 3379 urtw_write32_m(sc, URTW_8187B_AC_VI, (7 << 12) | (3 << 8) | 0x1c); 3380 urtw_write32_m(sc, URTW_8187B_AC_BE, (7 << 12) | (3 << 8) | 0x1c); 3381 urtw_write32_m(sc, URTW_8187B_AC_BK, (7 << 12) | (3 << 8) | 0x1c); 3382 3383 urtw_8187_write_phy_ofdm(sc, 0x97, 0x46); 3384 urtw_8187_write_phy_ofdm(sc, 0xa4, 0xb6); 3385 urtw_8187_write_phy_ofdm(sc, 0x85, 0xfc); 3386 urtw_8187_write_phy_cck(sc, 0xc1, 0x88); 3387 3388 fail: 3389 return (error); 3390 #undef N 3391 } 3392 3393 static usb_error_t 3394 urtw_8225v2b_rf_set_chan(struct urtw_softc *sc, int chan) 3395 { 3396 usb_error_t error; 3397 3398 error = urtw_8225v2b_set_txpwrlvl(sc, chan); 3399 if (error) 3400 goto fail; 3401 3402 urtw_8225_write(sc, URTW_8225_ADDR_7_MAGIC, urtw_8225_channel[chan]); 3403 usb_pause_mtx(&sc->sc_mtx, 10); 3404 fail: 3405 return (error); 3406 } 3407 3408 static usb_error_t 3409 urtw_8225v2b_set_txpwrlvl(struct urtw_softc *sc, int chan) 3410 { 3411 int i; 3412 uint8_t *cck_pwrtable; 3413 uint8_t cck_pwrlvl_max = 15; 3414 uint8_t cck_pwrlvl = sc->sc_txpwr_cck[chan] & 0xff; 3415 uint8_t ofdm_pwrlvl = sc->sc_txpwr_ofdm[chan] & 0xff; 3416 usb_error_t error; 3417 3418 /* CCK power setting */ 3419 cck_pwrlvl = (cck_pwrlvl > cck_pwrlvl_max) ? 3420 ((sc->sc_flags & URTW_RTL8187B_REV_B) ? cck_pwrlvl_max : 22) : 3421 (cck_pwrlvl + ((sc->sc_flags & URTW_RTL8187B_REV_B) ? 0 : 7)); 3422 cck_pwrlvl += sc->sc_txpwr_cck_base; 3423 cck_pwrlvl = (cck_pwrlvl > 35) ? 35 : cck_pwrlvl; 3424 cck_pwrtable = (chan == 14) ? urtw_8225v2b_txpwr_cck_ch14 : 3425 urtw_8225v2b_txpwr_cck; 3426 3427 if (sc->sc_flags & URTW_RTL8187B_REV_B) 3428 cck_pwrtable += (cck_pwrlvl <= 6) ? 0 : 3429 ((cck_pwrlvl <= 11) ? 8 : 16); 3430 else 3431 cck_pwrtable += (cck_pwrlvl <= 5) ? 0 : 3432 ((cck_pwrlvl <= 11) ? 8 : ((cck_pwrlvl <= 17) ? 16 : 24)); 3433 3434 for (i = 0; i < 8; i++) 3435 urtw_8187_write_phy_cck(sc, 0x44 + i, cck_pwrtable[i]); 3436 3437 urtw_write8_m(sc, URTW_TX_GAIN_CCK, 3438 urtw_8225v2_tx_gain_cck_ofdm[cck_pwrlvl] << 1); 3439 usb_pause_mtx(&sc->sc_mtx, 1); 3440 3441 /* OFDM power setting */ 3442 ofdm_pwrlvl = (ofdm_pwrlvl > 15) ? 3443 ((sc->sc_flags & URTW_RTL8187B_REV_B) ? 17 : 25) : 3444 (ofdm_pwrlvl + ((sc->sc_flags & URTW_RTL8187B_REV_B) ? 2 : 10)); 3445 ofdm_pwrlvl += sc->sc_txpwr_ofdm_base; 3446 ofdm_pwrlvl = (ofdm_pwrlvl > 35) ? 35 : ofdm_pwrlvl; 3447 3448 urtw_write8_m(sc, URTW_TX_GAIN_OFDM, 3449 urtw_8225v2_tx_gain_cck_ofdm[ofdm_pwrlvl] << 1); 3450 3451 if (sc->sc_flags & URTW_RTL8187B_REV_B) { 3452 if (ofdm_pwrlvl <= 11) { 3453 urtw_8187_write_phy_ofdm(sc, 0x87, 0x60); 3454 urtw_8187_write_phy_ofdm(sc, 0x89, 0x60); 3455 } else { 3456 urtw_8187_write_phy_ofdm(sc, 0x87, 0x5c); 3457 urtw_8187_write_phy_ofdm(sc, 0x89, 0x5c); 3458 } 3459 } else { 3460 if (ofdm_pwrlvl <= 11) { 3461 urtw_8187_write_phy_ofdm(sc, 0x87, 0x5c); 3462 urtw_8187_write_phy_ofdm(sc, 0x89, 0x5c); 3463 } else if (ofdm_pwrlvl <= 17) { 3464 urtw_8187_write_phy_ofdm(sc, 0x87, 0x54); 3465 urtw_8187_write_phy_ofdm(sc, 0x89, 0x54); 3466 } else { 3467 urtw_8187_write_phy_ofdm(sc, 0x87, 0x50); 3468 urtw_8187_write_phy_ofdm(sc, 0x89, 0x50); 3469 } 3470 } 3471 usb_pause_mtx(&sc->sc_mtx, 1); 3472 fail: 3473 return (error); 3474 } 3475 3476 static usb_error_t 3477 urtw_read8e(struct urtw_softc *sc, int val, uint8_t *data) 3478 { 3479 struct usb_device_request req; 3480 usb_error_t error; 3481 3482 req.bmRequestType = UT_READ_VENDOR_DEVICE; 3483 req.bRequest = URTW_8187_GETREGS_REQ; 3484 USETW(req.wValue, val | 0xfe00); 3485 USETW(req.wIndex, 0); 3486 USETW(req.wLength, sizeof(uint8_t)); 3487 3488 error = urtw_do_request(sc, &req, data); 3489 return (error); 3490 } 3491 3492 static usb_error_t 3493 urtw_write8e(struct urtw_softc *sc, int val, uint8_t data) 3494 { 3495 struct usb_device_request req; 3496 3497 req.bmRequestType = UT_WRITE_VENDOR_DEVICE; 3498 req.bRequest = URTW_8187_SETREGS_REQ; 3499 USETW(req.wValue, val | 0xfe00); 3500 USETW(req.wIndex, 0); 3501 USETW(req.wLength, sizeof(uint8_t)); 3502 3503 return (urtw_do_request(sc, &req, &data)); 3504 } 3505 3506 static usb_error_t 3507 urtw_8180_set_anaparam(struct urtw_softc *sc, uint32_t val) 3508 { 3509 uint8_t data; 3510 usb_error_t error; 3511 3512 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 3513 if (error) 3514 goto fail; 3515 3516 urtw_read8_m(sc, URTW_CONFIG3, &data); 3517 urtw_write8_m(sc, URTW_CONFIG3, data | URTW_CONFIG3_ANAPARAM_WRITE); 3518 urtw_write32_m(sc, URTW_ANAPARAM, val); 3519 urtw_read8_m(sc, URTW_CONFIG3, &data); 3520 urtw_write8_m(sc, URTW_CONFIG3, data & ~URTW_CONFIG3_ANAPARAM_WRITE); 3521 3522 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 3523 if (error) 3524 goto fail; 3525 fail: 3526 return (error); 3527 } 3528 3529 static usb_error_t 3530 urtw_8185_set_anaparam2(struct urtw_softc *sc, uint32_t val) 3531 { 3532 uint8_t data; 3533 usb_error_t error; 3534 3535 error = urtw_set_mode(sc, URTW_EPROM_CMD_CONFIG); 3536 if (error) 3537 goto fail; 3538 3539 urtw_read8_m(sc, URTW_CONFIG3, &data); 3540 urtw_write8_m(sc, URTW_CONFIG3, data | URTW_CONFIG3_ANAPARAM_WRITE); 3541 urtw_write32_m(sc, URTW_ANAPARAM2, val); 3542 urtw_read8_m(sc, URTW_CONFIG3, &data); 3543 urtw_write8_m(sc, URTW_CONFIG3, data & ~URTW_CONFIG3_ANAPARAM_WRITE); 3544 3545 error = urtw_set_mode(sc, URTW_EPROM_CMD_NORMAL); 3546 if (error) 3547 goto fail; 3548 fail: 3549 return (error); 3550 } 3551 3552 static usb_error_t 3553 urtw_intr_enable(struct urtw_softc *sc) 3554 { 3555 usb_error_t error; 3556 3557 urtw_write16_m(sc, URTW_INTR_MASK, 0xffff); 3558 fail: 3559 return (error); 3560 } 3561 3562 static usb_error_t 3563 urtw_intr_disable(struct urtw_softc *sc) 3564 { 3565 usb_error_t error; 3566 3567 urtw_write16_m(sc, URTW_INTR_MASK, 0); 3568 fail: 3569 return (error); 3570 } 3571 3572 static usb_error_t 3573 urtw_reset(struct urtw_softc *sc) 3574 { 3575 uint8_t data; 3576 usb_error_t error; 3577 3578 error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON); 3579 if (error) 3580 goto fail; 3581 error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON); 3582 if (error) 3583 goto fail; 3584 3585 error = urtw_intr_disable(sc); 3586 if (error) 3587 goto fail; 3588 usb_pause_mtx(&sc->sc_mtx, 100); 3589 3590 error = urtw_write8e(sc, 0x18, 0x10); 3591 if (error != 0) 3592 goto fail; 3593 error = urtw_write8e(sc, 0x18, 0x11); 3594 if (error != 0) 3595 goto fail; 3596 error = urtw_write8e(sc, 0x18, 0x00); 3597 if (error != 0) 3598 goto fail; 3599 usb_pause_mtx(&sc->sc_mtx, 100); 3600 3601 urtw_read8_m(sc, URTW_CMD, &data); 3602 data = (data & 0x2) | URTW_CMD_RST; 3603 urtw_write8_m(sc, URTW_CMD, data); 3604 usb_pause_mtx(&sc->sc_mtx, 100); 3605 3606 urtw_read8_m(sc, URTW_CMD, &data); 3607 if (data & URTW_CMD_RST) { 3608 device_printf(sc->sc_dev, "reset timeout\n"); 3609 goto fail; 3610 } 3611 3612 error = urtw_set_mode(sc, URTW_EPROM_CMD_LOAD); 3613 if (error) 3614 goto fail; 3615 usb_pause_mtx(&sc->sc_mtx, 100); 3616 3617 error = urtw_8180_set_anaparam(sc, URTW_8225_ANAPARAM_ON); 3618 if (error) 3619 goto fail; 3620 error = urtw_8185_set_anaparam2(sc, URTW_8225_ANAPARAM2_ON); 3621 if (error) 3622 goto fail; 3623 fail: 3624 return (error); 3625 } 3626 3627 static usb_error_t 3628 urtw_led_ctl(struct urtw_softc *sc, int mode) 3629 { 3630 usb_error_t error = 0; 3631 3632 switch (sc->sc_strategy) { 3633 case URTW_SW_LED_MODE0: 3634 error = urtw_led_mode0(sc, mode); 3635 break; 3636 case URTW_SW_LED_MODE1: 3637 error = urtw_led_mode1(sc, mode); 3638 break; 3639 case URTW_SW_LED_MODE2: 3640 error = urtw_led_mode2(sc, mode); 3641 break; 3642 case URTW_SW_LED_MODE3: 3643 error = urtw_led_mode3(sc, mode); 3644 break; 3645 default: 3646 DPRINTF(sc, URTW_DEBUG_STATE, 3647 "unsupported LED mode %d\n", sc->sc_strategy); 3648 error = USB_ERR_INVAL; 3649 break; 3650 } 3651 3652 return (error); 3653 } 3654 3655 static usb_error_t 3656 urtw_led_mode0(struct urtw_softc *sc, int mode) 3657 { 3658 3659 switch (mode) { 3660 case URTW_LED_CTL_POWER_ON: 3661 sc->sc_gpio_ledstate = URTW_LED_POWER_ON_BLINK; 3662 break; 3663 case URTW_LED_CTL_TX: 3664 if (sc->sc_gpio_ledinprogress == 1) 3665 return (0); 3666 3667 sc->sc_gpio_ledstate = URTW_LED_BLINK_NORMAL; 3668 sc->sc_gpio_blinktime = 2; 3669 break; 3670 case URTW_LED_CTL_LINK: 3671 sc->sc_gpio_ledstate = URTW_LED_ON; 3672 break; 3673 default: 3674 DPRINTF(sc, URTW_DEBUG_STATE, 3675 "unsupported LED mode 0x%x", mode); 3676 return (USB_ERR_INVAL); 3677 } 3678 3679 switch (sc->sc_gpio_ledstate) { 3680 case URTW_LED_ON: 3681 if (sc->sc_gpio_ledinprogress != 0) 3682 break; 3683 urtw_led_on(sc, URTW_LED_GPIO); 3684 break; 3685 case URTW_LED_BLINK_NORMAL: 3686 if (sc->sc_gpio_ledinprogress != 0) 3687 break; 3688 sc->sc_gpio_ledinprogress = 1; 3689 sc->sc_gpio_blinkstate = (sc->sc_gpio_ledon != 0) ? 3690 URTW_LED_OFF : URTW_LED_ON; 3691 usb_callout_reset(&sc->sc_led_ch, hz, urtw_led_ch, sc); 3692 break; 3693 case URTW_LED_POWER_ON_BLINK: 3694 urtw_led_on(sc, URTW_LED_GPIO); 3695 usb_pause_mtx(&sc->sc_mtx, 100); 3696 urtw_led_off(sc, URTW_LED_GPIO); 3697 break; 3698 default: 3699 DPRINTF(sc, URTW_DEBUG_STATE, 3700 "unknown LED status 0x%x", sc->sc_gpio_ledstate); 3701 return (USB_ERR_INVAL); 3702 } 3703 return (0); 3704 } 3705 3706 static usb_error_t 3707 urtw_led_mode1(struct urtw_softc *sc, int mode) 3708 { 3709 return (USB_ERR_INVAL); 3710 } 3711 3712 static usb_error_t 3713 urtw_led_mode2(struct urtw_softc *sc, int mode) 3714 { 3715 return (USB_ERR_INVAL); 3716 } 3717 3718 static usb_error_t 3719 urtw_led_mode3(struct urtw_softc *sc, int mode) 3720 { 3721 return (USB_ERR_INVAL); 3722 } 3723 3724 static usb_error_t 3725 urtw_led_on(struct urtw_softc *sc, int type) 3726 { 3727 usb_error_t error; 3728 3729 if (type == URTW_LED_GPIO) { 3730 switch (sc->sc_gpio_ledpin) { 3731 case URTW_LED_PIN_GPIO0: 3732 urtw_write8_m(sc, URTW_GPIO, 0x01); 3733 urtw_write8_m(sc, URTW_GP_ENABLE, 0x00); 3734 break; 3735 default: 3736 DPRINTF(sc, URTW_DEBUG_STATE, 3737 "unsupported LED PIN type 0x%x", 3738 sc->sc_gpio_ledpin); 3739 error = USB_ERR_INVAL; 3740 goto fail; 3741 } 3742 } else { 3743 DPRINTF(sc, URTW_DEBUG_STATE, 3744 "unsupported LED type 0x%x", type); 3745 error = USB_ERR_INVAL; 3746 goto fail; 3747 } 3748 3749 sc->sc_gpio_ledon = 1; 3750 fail: 3751 return (error); 3752 } 3753 3754 static usb_error_t 3755 urtw_led_off(struct urtw_softc *sc, int type) 3756 { 3757 usb_error_t error; 3758 3759 if (type == URTW_LED_GPIO) { 3760 switch (sc->sc_gpio_ledpin) { 3761 case URTW_LED_PIN_GPIO0: 3762 urtw_write8_m(sc, URTW_GPIO, URTW_GPIO_DATA_MAGIC1); 3763 urtw_write8_m(sc, 3764 URTW_GP_ENABLE, URTW_GP_ENABLE_DATA_MAGIC1); 3765 break; 3766 default: 3767 DPRINTF(sc, URTW_DEBUG_STATE, 3768 "unsupported LED PIN type 0x%x", 3769 sc->sc_gpio_ledpin); 3770 error = USB_ERR_INVAL; 3771 goto fail; 3772 } 3773 } else { 3774 DPRINTF(sc, URTW_DEBUG_STATE, 3775 "unsupported LED type 0x%x", type); 3776 error = USB_ERR_INVAL; 3777 goto fail; 3778 } 3779 3780 sc->sc_gpio_ledon = 0; 3781 3782 fail: 3783 return (error); 3784 } 3785 3786 static void 3787 urtw_led_ch(void *arg) 3788 { 3789 struct urtw_softc *sc = arg; 3790 struct ifnet *ifp = sc->sc_ifp; 3791 struct ieee80211com *ic = ifp->if_l2com; 3792 3793 ieee80211_runtask(ic, &sc->sc_led_task); 3794 } 3795 3796 static void 3797 urtw_ledtask(void *arg, int pending) 3798 { 3799 struct urtw_softc *sc = arg; 3800 3801 if (sc->sc_strategy != URTW_SW_LED_MODE0) { 3802 DPRINTF(sc, URTW_DEBUG_STATE, 3803 "could not process a LED strategy 0x%x", 3804 sc->sc_strategy); 3805 return; 3806 } 3807 3808 URTW_LOCK(sc); 3809 urtw_led_blink(sc); 3810 URTW_UNLOCK(sc); 3811 } 3812 3813 static usb_error_t 3814 urtw_led_blink(struct urtw_softc *sc) 3815 { 3816 uint8_t ing = 0; 3817 usb_error_t error; 3818 3819 if (sc->sc_gpio_blinkstate == URTW_LED_ON) 3820 error = urtw_led_on(sc, URTW_LED_GPIO); 3821 else 3822 error = urtw_led_off(sc, URTW_LED_GPIO); 3823 sc->sc_gpio_blinktime--; 3824 if (sc->sc_gpio_blinktime == 0) 3825 ing = 1; 3826 else { 3827 if (sc->sc_gpio_ledstate != URTW_LED_BLINK_NORMAL && 3828 sc->sc_gpio_ledstate != URTW_LED_BLINK_SLOWLY && 3829 sc->sc_gpio_ledstate != URTW_LED_BLINK_CM3) 3830 ing = 1; 3831 } 3832 if (ing == 1) { 3833 if (sc->sc_gpio_ledstate == URTW_LED_ON && 3834 sc->sc_gpio_ledon == 0) 3835 error = urtw_led_on(sc, URTW_LED_GPIO); 3836 else if (sc->sc_gpio_ledstate == URTW_LED_OFF && 3837 sc->sc_gpio_ledon == 1) 3838 error = urtw_led_off(sc, URTW_LED_GPIO); 3839 3840 sc->sc_gpio_blinktime = 0; 3841 sc->sc_gpio_ledinprogress = 0; 3842 return (0); 3843 } 3844 3845 sc->sc_gpio_blinkstate = (sc->sc_gpio_blinkstate != URTW_LED_ON) ? 3846 URTW_LED_ON : URTW_LED_OFF; 3847 3848 switch (sc->sc_gpio_ledstate) { 3849 case URTW_LED_BLINK_NORMAL: 3850 usb_callout_reset(&sc->sc_led_ch, hz, urtw_led_ch, sc); 3851 break; 3852 default: 3853 DPRINTF(sc, URTW_DEBUG_STATE, 3854 "unknown LED status 0x%x", 3855 sc->sc_gpio_ledstate); 3856 return (USB_ERR_INVAL); 3857 } 3858 return (0); 3859 } 3860 3861 static usb_error_t 3862 urtw_rx_enable(struct urtw_softc *sc) 3863 { 3864 uint8_t data; 3865 usb_error_t error; 3866 3867 usbd_transfer_start((sc->sc_flags & URTW_RTL8187B) ? 3868 sc->sc_xfer[URTW_8187B_BULK_RX] : sc->sc_xfer[URTW_8187L_BULK_RX]); 3869 3870 error = urtw_rx_setconf(sc); 3871 if (error != 0) 3872 goto fail; 3873 3874 if ((sc->sc_flags & URTW_RTL8187B) == 0) { 3875 urtw_read8_m(sc, URTW_CMD, &data); 3876 urtw_write8_m(sc, URTW_CMD, data | URTW_CMD_RX_ENABLE); 3877 } 3878 fail: 3879 return (error); 3880 } 3881 3882 static usb_error_t 3883 urtw_tx_enable(struct urtw_softc *sc) 3884 { 3885 uint8_t data8; 3886 uint32_t data; 3887 usb_error_t error; 3888 3889 if (sc->sc_flags & URTW_RTL8187B) { 3890 urtw_read32_m(sc, URTW_TX_CONF, &data); 3891 data &= ~URTW_TX_LOOPBACK_MASK; 3892 data &= ~(URTW_TX_DPRETRY_MASK | URTW_TX_RTSRETRY_MASK); 3893 data &= ~(URTW_TX_NOCRC | URTW_TX_MXDMA_MASK); 3894 data &= ~URTW_TX_SWPLCPLEN; 3895 data |= URTW_TX_HW_SEQNUM | URTW_TX_DISREQQSIZE | 3896 (7 << 8) | /* short retry limit */ 3897 (7 << 0) | /* long retry limit */ 3898 (7 << 21); /* MAX TX DMA */ 3899 urtw_write32_m(sc, URTW_TX_CONF, data); 3900 3901 urtw_read8_m(sc, URTW_MSR, &data8); 3902 data8 |= URTW_MSR_LINK_ENEDCA; 3903 urtw_write8_m(sc, URTW_MSR, data8); 3904 return (error); 3905 } 3906 3907 urtw_read8_m(sc, URTW_CW_CONF, &data8); 3908 data8 &= ~(URTW_CW_CONF_PERPACKET_CW | URTW_CW_CONF_PERPACKET_RETRY); 3909 urtw_write8_m(sc, URTW_CW_CONF, data8); 3910 3911 urtw_read8_m(sc, URTW_TX_AGC_CTL, &data8); 3912 data8 &= ~URTW_TX_AGC_CTL_PERPACKET_GAIN; 3913 data8 &= ~URTW_TX_AGC_CTL_PERPACKET_ANTSEL; 3914 data8 &= ~URTW_TX_AGC_CTL_FEEDBACK_ANT; 3915 urtw_write8_m(sc, URTW_TX_AGC_CTL, data8); 3916 3917 urtw_read32_m(sc, URTW_TX_CONF, &data); 3918 data &= ~URTW_TX_LOOPBACK_MASK; 3919 data |= URTW_TX_LOOPBACK_NONE; 3920 data &= ~(URTW_TX_DPRETRY_MASK | URTW_TX_RTSRETRY_MASK); 3921 data |= sc->sc_tx_retry << URTW_TX_DPRETRY_SHIFT; 3922 data |= sc->sc_rts_retry << URTW_TX_RTSRETRY_SHIFT; 3923 data &= ~(URTW_TX_NOCRC | URTW_TX_MXDMA_MASK); 3924 data |= URTW_TX_MXDMA_2048 | URTW_TX_CWMIN | URTW_TX_DISCW; 3925 data &= ~URTW_TX_SWPLCPLEN; 3926 data |= URTW_TX_NOICV; 3927 urtw_write32_m(sc, URTW_TX_CONF, data); 3928 3929 urtw_read8_m(sc, URTW_CMD, &data8); 3930 urtw_write8_m(sc, URTW_CMD, data8 | URTW_CMD_TX_ENABLE); 3931 fail: 3932 return (error); 3933 } 3934 3935 static usb_error_t 3936 urtw_rx_setconf(struct urtw_softc *sc) 3937 { 3938 struct ifnet *ifp = sc->sc_ifp; 3939 struct ieee80211com *ic = ifp->if_l2com; 3940 uint32_t data; 3941 usb_error_t error; 3942 3943 urtw_read32_m(sc, URTW_RX, &data); 3944 data = data &~ URTW_RX_FILTER_MASK; 3945 if (sc->sc_flags & URTW_RTL8187B) { 3946 data = data | URTW_RX_FILTER_MNG | URTW_RX_FILTER_DATA | 3947 URTW_RX_FILTER_MCAST | URTW_RX_FILTER_BCAST | 3948 URTW_RX_FILTER_NICMAC | URTW_RX_CHECK_BSSID | 3949 URTW_RX_FIFO_THRESHOLD_NONE | 3950 URTW_MAX_RX_DMA_2048 | 3951 URTW_RX_AUTORESETPHY | URTW_RCR_ONLYERLPKT; 3952 } else { 3953 data = data | URTW_RX_FILTER_MNG | URTW_RX_FILTER_DATA; 3954 data = data | URTW_RX_FILTER_BCAST | URTW_RX_FILTER_MCAST; 3955 3956 if (ic->ic_opmode == IEEE80211_M_MONITOR) { 3957 data = data | URTW_RX_FILTER_ICVERR; 3958 data = data | URTW_RX_FILTER_PWR; 3959 } 3960 if (sc->sc_crcmon == 1 && ic->ic_opmode == IEEE80211_M_MONITOR) 3961 data = data | URTW_RX_FILTER_CRCERR; 3962 3963 if (ic->ic_opmode == IEEE80211_M_MONITOR || 3964 (ifp->if_flags & (IFF_ALLMULTI | IFF_PROMISC))) { 3965 data = data | URTW_RX_FILTER_ALLMAC; 3966 } else { 3967 data = data | URTW_RX_FILTER_NICMAC; 3968 data = data | URTW_RX_CHECK_BSSID; 3969 } 3970 3971 data = data &~ URTW_RX_FIFO_THRESHOLD_MASK; 3972 data = data | URTW_RX_FIFO_THRESHOLD_NONE | 3973 URTW_RX_AUTORESETPHY; 3974 data = data &~ URTW_MAX_RX_DMA_MASK; 3975 data = data | URTW_MAX_RX_DMA_2048 | URTW_RCR_ONLYERLPKT; 3976 } 3977 3978 urtw_write32_m(sc, URTW_RX, data); 3979 fail: 3980 return (error); 3981 } 3982 3983 static struct mbuf * 3984 urtw_rxeof(struct usb_xfer *xfer, struct urtw_data *data, int *rssi_p, 3985 int8_t *nf_p) 3986 { 3987 int actlen, flen, rssi; 3988 struct ieee80211_frame *wh; 3989 struct mbuf *m, *mnew; 3990 struct urtw_softc *sc = data->sc; 3991 struct ifnet *ifp = sc->sc_ifp; 3992 struct ieee80211com *ic = ifp->if_l2com; 3993 uint8_t noise = 0, rate; 3994 3995 usbd_xfer_status(xfer, &actlen, NULL, NULL, NULL); 3996 3997 if (actlen < (int)URTW_MIN_RXBUFSZ) { 3998 ifp->if_ierrors++; 3999 return (NULL); 4000 } 4001 4002 if (sc->sc_flags & URTW_RTL8187B) { 4003 struct urtw_8187b_rxhdr *rx; 4004 4005 rx = (struct urtw_8187b_rxhdr *)(data->buf + 4006 (actlen - (sizeof(struct urtw_8187b_rxhdr)))); 4007 flen = le32toh(rx->flag) & 0xfff; 4008 if (flen > actlen) { 4009 ifp->if_ierrors++; 4010 return (NULL); 4011 } 4012 rate = (le32toh(rx->flag) >> URTW_RX_FLAG_RXRATE_SHIFT) & 0xf; 4013 /* XXX correct? */ 4014 rssi = rx->rssi & URTW_RX_RSSI_MASK; 4015 noise = rx->noise; 4016 } else { 4017 struct urtw_8187l_rxhdr *rx; 4018 4019 rx = (struct urtw_8187l_rxhdr *)(data->buf + 4020 (actlen - (sizeof(struct urtw_8187l_rxhdr)))); 4021 flen = le32toh(rx->flag) & 0xfff; 4022 if (flen > actlen) { 4023 ifp->if_ierrors++; 4024 return (NULL); 4025 } 4026 4027 rate = (le32toh(rx->flag) >> URTW_RX_FLAG_RXRATE_SHIFT) & 0xf; 4028 /* XXX correct? */ 4029 rssi = rx->rssi & URTW_RX_8187L_RSSI_MASK; 4030 noise = rx->noise; 4031 } 4032 4033 mnew = m_getcl(M_NOWAIT, MT_DATA, M_PKTHDR); 4034 if (mnew == NULL) { 4035 ifp->if_ierrors++; 4036 return (NULL); 4037 } 4038 4039 m = data->m; 4040 data->m = mnew; 4041 data->buf = mtod(mnew, uint8_t *); 4042 4043 /* finalize mbuf */ 4044 m->m_pkthdr.rcvif = ifp; 4045 m->m_pkthdr.len = m->m_len = flen - IEEE80211_CRC_LEN; 4046 4047 if (ieee80211_radiotap_active(ic)) { 4048 struct urtw_rx_radiotap_header *tap = &sc->sc_rxtap; 4049 4050 /* XXX Are variables correct? */ 4051 tap->wr_chan_freq = htole16(ic->ic_curchan->ic_freq); 4052 tap->wr_chan_flags = htole16(ic->ic_curchan->ic_flags); 4053 tap->wr_dbm_antsignal = (int8_t)rssi; 4054 } 4055 4056 wh = mtod(m, struct ieee80211_frame *); 4057 if ((wh->i_fc[0] & IEEE80211_FC0_TYPE_MASK) == IEEE80211_FC0_TYPE_DATA) 4058 sc->sc_currate = (rate > 0) ? rate : sc->sc_currate; 4059 4060 *rssi_p = rssi; 4061 *nf_p = noise; /* XXX correct? */ 4062 4063 return (m); 4064 } 4065 4066 static void 4067 urtw_bulk_rx_callback(struct usb_xfer *xfer, usb_error_t error) 4068 { 4069 struct urtw_softc *sc = usbd_xfer_softc(xfer); 4070 struct ifnet *ifp = sc->sc_ifp; 4071 struct ieee80211com *ic = ifp->if_l2com; 4072 struct ieee80211_frame *wh; 4073 struct ieee80211_node *ni; 4074 struct mbuf *m = NULL; 4075 struct urtw_data *data; 4076 int8_t nf = -95; 4077 int rssi = 1; 4078 4079 URTW_ASSERT_LOCKED(sc); 4080 4081 switch (USB_GET_STATE(xfer)) { 4082 case USB_ST_TRANSFERRED: 4083 data = STAILQ_FIRST(&sc->sc_rx_active); 4084 if (data == NULL) 4085 goto setup; 4086 STAILQ_REMOVE_HEAD(&sc->sc_rx_active, next); 4087 m = urtw_rxeof(xfer, data, &rssi, &nf); 4088 STAILQ_INSERT_TAIL(&sc->sc_rx_inactive, data, next); 4089 /* FALLTHROUGH */ 4090 case USB_ST_SETUP: 4091 setup: 4092 data = STAILQ_FIRST(&sc->sc_rx_inactive); 4093 if (data == NULL) { 4094 KASSERT(m == NULL, ("mbuf isn't NULL")); 4095 return; 4096 } 4097 STAILQ_REMOVE_HEAD(&sc->sc_rx_inactive, next); 4098 STAILQ_INSERT_TAIL(&sc->sc_rx_active, data, next); 4099 usbd_xfer_set_frame_data(xfer, 0, data->buf, 4100 usbd_xfer_max_len(xfer)); 4101 usbd_transfer_submit(xfer); 4102 4103 /* 4104 * To avoid LOR we should unlock our private mutex here to call 4105 * ieee80211_input() because here is at the end of a USB 4106 * callback and safe to unlock. 4107 */ 4108 URTW_UNLOCK(sc); 4109 if (m != NULL) { 4110 wh = mtod(m, struct ieee80211_frame *); 4111 ni = ieee80211_find_rxnode(ic, 4112 (struct ieee80211_frame_min *)wh); 4113 if (ni != NULL) { 4114 (void) ieee80211_input(ni, m, rssi, nf); 4115 /* node is no longer needed */ 4116 ieee80211_free_node(ni); 4117 } else 4118 (void) ieee80211_input_all(ic, m, rssi, nf); 4119 m = NULL; 4120 } 4121 URTW_LOCK(sc); 4122 break; 4123 default: 4124 /* needs it to the inactive queue due to a error. */ 4125 data = STAILQ_FIRST(&sc->sc_rx_active); 4126 if (data != NULL) { 4127 STAILQ_REMOVE_HEAD(&sc->sc_rx_active, next); 4128 STAILQ_INSERT_TAIL(&sc->sc_rx_inactive, data, next); 4129 } 4130 if (error != USB_ERR_CANCELLED) { 4131 usbd_xfer_set_stall(xfer); 4132 ifp->if_ierrors++; 4133 goto setup; 4134 } 4135 break; 4136 } 4137 } 4138 4139 #define URTW_STATUS_TYPE_TXCLOSE 1 4140 #define URTW_STATUS_TYPE_BEACON_INTR 0 4141 4142 static void 4143 urtw_txstatus_eof(struct usb_xfer *xfer) 4144 { 4145 struct urtw_softc *sc = usbd_xfer_softc(xfer); 4146 struct ifnet *ifp = sc->sc_ifp; 4147 int actlen, type, pktretry, seq; 4148 uint64_t val; 4149 4150 usbd_xfer_status(xfer, &actlen, NULL, NULL, NULL); 4151 4152 if (actlen != sizeof(uint64_t)) 4153 return; 4154 4155 val = le64toh(sc->sc_txstatus); 4156 type = (val >> 30) & 0x3; 4157 if (type == URTW_STATUS_TYPE_TXCLOSE) { 4158 pktretry = val & 0xff; 4159 seq = (val >> 16) & 0xff; 4160 if (pktretry == URTW_TX_MAXRETRY) 4161 ifp->if_oerrors++; 4162 DPRINTF(sc, URTW_DEBUG_TXSTATUS, "pktretry %d seq %#x\n", 4163 pktretry, seq); 4164 } 4165 } 4166 4167 static void 4168 urtw_bulk_tx_status_callback(struct usb_xfer *xfer, usb_error_t error) 4169 { 4170 struct urtw_softc *sc = usbd_xfer_softc(xfer); 4171 struct ifnet *ifp = sc->sc_ifp; 4172 void *dma_buf = usbd_xfer_get_frame_buffer(xfer, 0); 4173 4174 URTW_ASSERT_LOCKED(sc); 4175 4176 switch (USB_GET_STATE(xfer)) { 4177 case USB_ST_TRANSFERRED: 4178 urtw_txstatus_eof(xfer); 4179 /* FALLTHROUGH */ 4180 case USB_ST_SETUP: 4181 setup: 4182 memcpy(dma_buf, &sc->sc_txstatus, sizeof(uint64_t)); 4183 usbd_xfer_set_frame_len(xfer, 0, sizeof(uint64_t)); 4184 usbd_transfer_submit(xfer); 4185 break; 4186 default: 4187 if (error != USB_ERR_CANCELLED) { 4188 usbd_xfer_set_stall(xfer); 4189 ifp->if_ierrors++; 4190 goto setup; 4191 } 4192 break; 4193 } 4194 } 4195 4196 static void 4197 urtw_txeof(struct usb_xfer *xfer, struct urtw_data *data) 4198 { 4199 struct urtw_softc *sc = usbd_xfer_softc(xfer); 4200 struct ifnet *ifp = sc->sc_ifp; 4201 struct mbuf *m; 4202 4203 URTW_ASSERT_LOCKED(sc); 4204 4205 /* 4206 * Do any tx complete callback. Note this must be done before releasing 4207 * the node reference. 4208 */ 4209 if (data->m) { 4210 m = data->m; 4211 if (m->m_flags & M_TXCB) { 4212 /* XXX status? */ 4213 ieee80211_process_callback(data->ni, m, 0); 4214 } 4215 m_freem(m); 4216 data->m = NULL; 4217 } 4218 if (data->ni) { 4219 ieee80211_free_node(data->ni); 4220 data->ni = NULL; 4221 } 4222 sc->sc_txtimer = 0; 4223 ifp->if_opackets++; 4224 ifp->if_drv_flags &= ~IFF_DRV_OACTIVE; 4225 } 4226 4227 static void 4228 urtw_bulk_tx_callback(struct usb_xfer *xfer, usb_error_t error) 4229 { 4230 struct urtw_softc *sc = usbd_xfer_softc(xfer); 4231 struct ifnet *ifp = sc->sc_ifp; 4232 struct urtw_data *data; 4233 4234 URTW_ASSERT_LOCKED(sc); 4235 4236 switch (USB_GET_STATE(xfer)) { 4237 case USB_ST_TRANSFERRED: 4238 data = STAILQ_FIRST(&sc->sc_tx_active); 4239 if (data == NULL) 4240 goto setup; 4241 STAILQ_REMOVE_HEAD(&sc->sc_tx_active, next); 4242 urtw_txeof(xfer, data); 4243 STAILQ_INSERT_TAIL(&sc->sc_tx_inactive, data, next); 4244 /* FALLTHROUGH */ 4245 case USB_ST_SETUP: 4246 setup: 4247 data = STAILQ_FIRST(&sc->sc_tx_pending); 4248 if (data == NULL) { 4249 DPRINTF(sc, URTW_DEBUG_XMIT, 4250 "%s: empty pending queue\n", __func__); 4251 return; 4252 } 4253 STAILQ_REMOVE_HEAD(&sc->sc_tx_pending, next); 4254 STAILQ_INSERT_TAIL(&sc->sc_tx_active, data, next); 4255 4256 usbd_xfer_set_frame_data(xfer, 0, data->buf, data->buflen); 4257 usbd_transfer_submit(xfer); 4258 4259 URTW_UNLOCK(sc); 4260 urtw_start(ifp); 4261 URTW_LOCK(sc); 4262 break; 4263 default: 4264 data = STAILQ_FIRST(&sc->sc_tx_active); 4265 if (data == NULL) 4266 goto setup; 4267 if (data->ni != NULL) { 4268 ieee80211_free_node(data->ni); 4269 data->ni = NULL; 4270 ifp->if_oerrors++; 4271 } 4272 if (error != USB_ERR_CANCELLED) { 4273 usbd_xfer_set_stall(xfer); 4274 goto setup; 4275 } 4276 break; 4277 } 4278 } 4279 4280 static struct urtw_data * 4281 _urtw_getbuf(struct urtw_softc *sc) 4282 { 4283 struct urtw_data *bf; 4284 4285 bf = STAILQ_FIRST(&sc->sc_tx_inactive); 4286 if (bf != NULL) 4287 STAILQ_REMOVE_HEAD(&sc->sc_tx_inactive, next); 4288 else 4289 bf = NULL; 4290 if (bf == NULL) 4291 DPRINTF(sc, URTW_DEBUG_XMIT, "%s: %s\n", __func__, 4292 "out of xmit buffers"); 4293 return (bf); 4294 } 4295 4296 static struct urtw_data * 4297 urtw_getbuf(struct urtw_softc *sc) 4298 { 4299 struct urtw_data *bf; 4300 4301 URTW_ASSERT_LOCKED(sc); 4302 4303 bf = _urtw_getbuf(sc); 4304 if (bf == NULL) { 4305 struct ifnet *ifp = sc->sc_ifp; 4306 4307 DPRINTF(sc, URTW_DEBUG_XMIT, "%s: stop queue\n", __func__); 4308 ifp->if_drv_flags |= IFF_DRV_OACTIVE; 4309 } 4310 return (bf); 4311 } 4312 4313 static int 4314 urtw_isbmode(uint16_t rate) 4315 { 4316 4317 return ((rate <= 22 && rate != 12 && rate != 18) || 4318 rate == 44) ? (1) : (0); 4319 } 4320 4321 static uint16_t 4322 urtw_rate2dbps(uint16_t rate) 4323 { 4324 4325 switch(rate) { 4326 case 12: 4327 case 18: 4328 case 24: 4329 case 36: 4330 case 48: 4331 case 72: 4332 case 96: 4333 case 108: 4334 return (rate * 2); 4335 default: 4336 break; 4337 } 4338 return (24); 4339 } 4340 4341 static int 4342 urtw_compute_txtime(uint16_t framelen, uint16_t rate, 4343 uint8_t ismgt, uint8_t isshort) 4344 { 4345 uint16_t ceiling, frametime, n_dbps; 4346 4347 if (urtw_isbmode(rate)) { 4348 if (ismgt || !isshort || rate == 2) 4349 frametime = (uint16_t)(144 + 48 + 4350 (framelen * 8 / (rate / 2))); 4351 else 4352 frametime = (uint16_t)(72 + 24 + 4353 (framelen * 8 / (rate / 2))); 4354 if ((framelen * 8 % (rate / 2)) != 0) 4355 frametime++; 4356 } else { 4357 n_dbps = urtw_rate2dbps(rate); 4358 ceiling = (16 + 8 * framelen + 6) / n_dbps 4359 + (((16 + 8 * framelen + 6) % n_dbps) ? 1 : 0); 4360 frametime = (uint16_t)(16 + 4 + 4 * ceiling + 6); 4361 } 4362 return (frametime); 4363 } 4364 4365 /* 4366 * Callback from the 802.11 layer to update the 4367 * slot time based on the current setting. 4368 */ 4369 static void 4370 urtw_updateslot(struct ifnet *ifp) 4371 { 4372 struct urtw_softc *sc = ifp->if_softc; 4373 struct ieee80211com *ic = ifp->if_l2com; 4374 4375 ieee80211_runtask(ic, &sc->sc_updateslot_task); 4376 } 4377 4378 static void 4379 urtw_updateslottask(void *arg, int pending) 4380 { 4381 struct urtw_softc *sc = arg; 4382 struct ifnet *ifp = sc->sc_ifp; 4383 struct ieee80211com *ic = ifp->if_l2com; 4384 int error; 4385 4386 if ((ifp->if_drv_flags & IFF_DRV_RUNNING) == 0) 4387 return; 4388 4389 URTW_LOCK(sc); 4390 if (sc->sc_flags & URTW_RTL8187B) { 4391 urtw_write8_m(sc, URTW_SIFS, 0x22); 4392 if (IEEE80211_IS_CHAN_ANYG(ic->ic_curchan)) 4393 urtw_write8_m(sc, URTW_SLOT, 0x9); 4394 else 4395 urtw_write8_m(sc, URTW_SLOT, 0x14); 4396 urtw_write8_m(sc, URTW_8187B_EIFS, 0x5b); 4397 urtw_write8_m(sc, URTW_CARRIER_SCOUNT, 0x5b); 4398 } else { 4399 urtw_write8_m(sc, URTW_SIFS, 0x22); 4400 if (sc->sc_state == IEEE80211_S_ASSOC && 4401 ic->ic_flags & IEEE80211_F_SHSLOT) 4402 urtw_write8_m(sc, URTW_SLOT, 0x9); 4403 else 4404 urtw_write8_m(sc, URTW_SLOT, 0x14); 4405 if (IEEE80211_IS_CHAN_ANYG(ic->ic_curchan)) { 4406 urtw_write8_m(sc, URTW_DIFS, 0x14); 4407 urtw_write8_m(sc, URTW_EIFS, 0x5b - 0x14); 4408 urtw_write8_m(sc, URTW_CW_VAL, 0x73); 4409 } else { 4410 urtw_write8_m(sc, URTW_DIFS, 0x24); 4411 urtw_write8_m(sc, URTW_EIFS, 0x5b - 0x24); 4412 urtw_write8_m(sc, URTW_CW_VAL, 0xa5); 4413 } 4414 } 4415 fail: 4416 URTW_UNLOCK(sc); 4417 } 4418 4419 static void 4420 urtw_sysctl_node(struct urtw_softc *sc) 4421 { 4422 #define URTW_SYSCTL_STAT_ADD32(c, h, n, p, d) \ 4423 SYSCTL_ADD_UINT(c, h, OID_AUTO, n, CTLFLAG_RD, p, 0, d) 4424 struct sysctl_ctx_list *ctx; 4425 struct sysctl_oid_list *child, *parent; 4426 struct sysctl_oid *tree; 4427 struct urtw_stats *stats = &sc->sc_stats; 4428 4429 ctx = device_get_sysctl_ctx(sc->sc_dev); 4430 child = SYSCTL_CHILDREN(device_get_sysctl_tree(sc->sc_dev)); 4431 4432 tree = SYSCTL_ADD_NODE(ctx, child, OID_AUTO, "stats", CTLFLAG_RD, 4433 NULL, "URTW statistics"); 4434 parent = SYSCTL_CHILDREN(tree); 4435 4436 /* Tx statistics. */ 4437 tree = SYSCTL_ADD_NODE(ctx, parent, OID_AUTO, "tx", CTLFLAG_RD, 4438 NULL, "Tx MAC statistics"); 4439 child = SYSCTL_CHILDREN(tree); 4440 URTW_SYSCTL_STAT_ADD32(ctx, child, "1m", &stats->txrates[0], 4441 "1 Mbit/s"); 4442 URTW_SYSCTL_STAT_ADD32(ctx, child, "2m", &stats->txrates[1], 4443 "2 Mbit/s"); 4444 URTW_SYSCTL_STAT_ADD32(ctx, child, "5.5m", &stats->txrates[2], 4445 "5.5 Mbit/s"); 4446 URTW_SYSCTL_STAT_ADD32(ctx, child, "6m", &stats->txrates[4], 4447 "6 Mbit/s"); 4448 URTW_SYSCTL_STAT_ADD32(ctx, child, "9m", &stats->txrates[5], 4449 "9 Mbit/s"); 4450 URTW_SYSCTL_STAT_ADD32(ctx, child, "11m", &stats->txrates[3], 4451 "11 Mbit/s"); 4452 URTW_SYSCTL_STAT_ADD32(ctx, child, "12m", &stats->txrates[6], 4453 "12 Mbit/s"); 4454 URTW_SYSCTL_STAT_ADD32(ctx, child, "18m", &stats->txrates[7], 4455 "18 Mbit/s"); 4456 URTW_SYSCTL_STAT_ADD32(ctx, child, "24m", &stats->txrates[8], 4457 "24 Mbit/s"); 4458 URTW_SYSCTL_STAT_ADD32(ctx, child, "36m", &stats->txrates[9], 4459 "36 Mbit/s"); 4460 URTW_SYSCTL_STAT_ADD32(ctx, child, "48m", &stats->txrates[10], 4461 "48 Mbit/s"); 4462 URTW_SYSCTL_STAT_ADD32(ctx, child, "54m", &stats->txrates[11], 4463 "54 Mbit/s"); 4464 #undef URTW_SYSCTL_STAT_ADD32 4465 } 4466 4467 static device_method_t urtw_methods[] = { 4468 DEVMETHOD(device_probe, urtw_match), 4469 DEVMETHOD(device_attach, urtw_attach), 4470 DEVMETHOD(device_detach, urtw_detach), 4471 DEVMETHOD_END 4472 }; 4473 static driver_t urtw_driver = { 4474 .name = "urtw", 4475 .methods = urtw_methods, 4476 .size = sizeof(struct urtw_softc) 4477 }; 4478 static devclass_t urtw_devclass; 4479 4480 DRIVER_MODULE(urtw, uhub, urtw_driver, urtw_devclass, NULL, 0); 4481 MODULE_DEPEND(urtw, wlan, 1, 1, 1); 4482 MODULE_DEPEND(urtw, usb, 1, 1, 1); 4483 MODULE_VERSION(urtw, 1); 4484