1 // SPDX-License-Identifier: ISC 2 /* 3 * Copyright (c) 2011 Broadcom Corporation 4 */ 5 6 #include <linux/kernel.h> 7 #include <linux/module.h> 8 #include <linux/firmware.h> 9 #include <linux/usb.h> 10 #include <linux/vmalloc.h> 11 12 #include <brcmu_utils.h> 13 #include <brcm_hw_ids.h> 14 #include <brcmu_wifi.h> 15 #include "bus.h" 16 #include "debug.h" 17 #include "firmware.h" 18 #include "usb.h" 19 #include "core.h" 20 #include "common.h" 21 #include "bcdc.h" 22 23 24 #define IOCTL_RESP_TIMEOUT msecs_to_jiffies(2000) 25 26 #define BRCMF_USB_RESET_GETVER_SPINWAIT 100 /* in unit of ms */ 27 #define BRCMF_USB_RESET_GETVER_LOOP_CNT 10 28 29 #define BRCMF_POSTBOOT_ID 0xA123 /* ID to detect if dongle 30 has boot up */ 31 #define BRCMF_USB_NRXQ 50 32 #define BRCMF_USB_NTXQ 50 33 34 #define BRCMF_USB_CBCTL_WRITE 0 35 #define BRCMF_USB_CBCTL_READ 1 36 #define BRCMF_USB_MAX_PKT_SIZE 1600 37 38 BRCMF_FW_DEF(43143, "brcmfmac43143"); 39 BRCMF_FW_DEF(43236B, "brcmfmac43236b"); 40 BRCMF_FW_DEF(43242A, "brcmfmac43242a"); 41 BRCMF_FW_DEF(43569, "brcmfmac43569"); 42 BRCMF_FW_DEF(4373, "brcmfmac4373"); 43 44 static const struct brcmf_firmware_mapping brcmf_usb_fwnames[] = { 45 BRCMF_FW_ENTRY(BRCM_CC_43143_CHIP_ID, 0xFFFFFFFF, 43143), 46 BRCMF_FW_ENTRY(BRCM_CC_43235_CHIP_ID, 0x00000008, 43236B), 47 BRCMF_FW_ENTRY(BRCM_CC_43236_CHIP_ID, 0x00000008, 43236B), 48 BRCMF_FW_ENTRY(BRCM_CC_43238_CHIP_ID, 0x00000008, 43236B), 49 BRCMF_FW_ENTRY(BRCM_CC_43242_CHIP_ID, 0xFFFFFFFF, 43242A), 50 BRCMF_FW_ENTRY(BRCM_CC_43566_CHIP_ID, 0xFFFFFFFF, 43569), 51 BRCMF_FW_ENTRY(BRCM_CC_43569_CHIP_ID, 0xFFFFFFFF, 43569), 52 BRCMF_FW_ENTRY(CY_CC_4373_CHIP_ID, 0xFFFFFFFF, 4373) 53 }; 54 55 #define TRX_MAGIC 0x30524448 /* "HDR0" */ 56 #define TRX_MAX_OFFSET 3 /* Max number of file offsets */ 57 #define TRX_UNCOMP_IMAGE 0x20 /* Trx holds uncompressed img */ 58 #define TRX_RDL_CHUNK 1500 /* size of each dl transfer */ 59 #define TRX_OFFSETS_DLFWLEN_IDX 0 60 61 /* Control messages: bRequest values */ 62 #define DL_GETSTATE 0 /* returns the rdl_state_t struct */ 63 #define DL_CHECK_CRC 1 /* currently unused */ 64 #define DL_GO 2 /* execute downloaded image */ 65 #define DL_START 3 /* initialize dl state */ 66 #define DL_REBOOT 4 /* reboot the device in 2 seconds */ 67 #define DL_GETVER 5 /* returns the bootrom_id_t struct */ 68 #define DL_GO_PROTECTED 6 /* execute the downloaded code and set reset 69 * event to occur in 2 seconds. It is the 70 * responsibility of the downloaded code to 71 * clear this event 72 */ 73 #define DL_EXEC 7 /* jump to a supplied address */ 74 #define DL_RESETCFG 8 /* To support single enum on dongle 75 * - Not used by bootloader 76 */ 77 #define DL_DEFER_RESP_OK 9 /* Potentially defer the response to setup 78 * if resp unavailable 79 */ 80 81 /* states */ 82 #define DL_WAITING 0 /* waiting to rx first pkt */ 83 #define DL_READY 1 /* hdr was good, waiting for more of the 84 * compressed image 85 */ 86 #define DL_BAD_HDR 2 /* hdr was corrupted */ 87 #define DL_BAD_CRC 3 /* compressed image was corrupted */ 88 #define DL_RUNNABLE 4 /* download was successful,waiting for go cmd */ 89 #define DL_START_FAIL 5 /* failed to initialize correctly */ 90 #define DL_NVRAM_TOOBIG 6 /* host specified nvram data exceeds DL_NVRAM 91 * value 92 */ 93 #define DL_IMAGE_TOOBIG 7 /* firmware image too big */ 94 95 96 struct trx_header_le { 97 __le32 magic; /* "HDR0" */ 98 __le32 len; /* Length of file including header */ 99 __le32 crc32; /* CRC from flag_version to end of file */ 100 __le32 flag_version; /* 0:15 flags, 16:31 version */ 101 __le32 offsets[TRX_MAX_OFFSET]; /* Offsets of partitions from start of 102 * header 103 */ 104 }; 105 106 struct rdl_state_le { 107 __le32 state; 108 __le32 bytes; 109 }; 110 111 struct bootrom_id_le { 112 __le32 chip; /* Chip id */ 113 __le32 chiprev; /* Chip rev */ 114 __le32 ramsize; /* Size of RAM */ 115 __le32 remapbase; /* Current remap base address */ 116 __le32 boardtype; /* Type of board */ 117 __le32 boardrev; /* Board revision */ 118 }; 119 120 struct brcmf_usbdev_info { 121 struct brcmf_usbdev bus_pub; /* MUST BE FIRST */ 122 spinlock_t qlock; 123 struct list_head rx_freeq; 124 struct list_head rx_postq; 125 struct list_head tx_freeq; 126 struct list_head tx_postq; 127 uint rx_pipe, tx_pipe; 128 129 int rx_low_watermark; 130 int tx_low_watermark; 131 int tx_high_watermark; 132 int tx_freecount; 133 bool tx_flowblock; 134 spinlock_t tx_flowblock_lock; 135 136 struct brcmf_usbreq *tx_reqs; 137 struct brcmf_usbreq *rx_reqs; 138 139 char fw_name[BRCMF_FW_NAME_LEN]; 140 const u8 *image; /* buffer for combine fw and nvram */ 141 int image_len; 142 143 struct usb_device *usbdev; 144 struct device *dev; 145 struct completion dev_init_done; 146 147 int ctl_in_pipe, ctl_out_pipe; 148 struct urb *ctl_urb; /* URB for control endpoint */ 149 struct usb_ctrlrequest ctl_write; 150 struct usb_ctrlrequest ctl_read; 151 u32 ctl_urb_actual_length; 152 int ctl_urb_status; 153 int ctl_completed; 154 wait_queue_head_t ioctl_resp_wait; 155 ulong ctl_op; 156 u8 ifnum; 157 158 struct urb *bulk_urb; /* used for FW download */ 159 160 struct brcmf_mp_device *settings; 161 }; 162 163 static void brcmf_usb_rx_refill(struct brcmf_usbdev_info *devinfo, 164 struct brcmf_usbreq *req); 165 166 static struct brcmf_usbdev *brcmf_usb_get_buspub(struct device *dev) 167 { 168 struct brcmf_bus *bus_if = dev_get_drvdata(dev); 169 return bus_if->bus_priv.usb; 170 } 171 172 static struct brcmf_usbdev_info *brcmf_usb_get_businfo(struct device *dev) 173 { 174 return brcmf_usb_get_buspub(dev)->devinfo; 175 } 176 177 static int brcmf_usb_ioctl_resp_wait(struct brcmf_usbdev_info *devinfo) 178 { 179 return wait_event_timeout(devinfo->ioctl_resp_wait, 180 devinfo->ctl_completed, IOCTL_RESP_TIMEOUT); 181 } 182 183 static void brcmf_usb_ioctl_resp_wake(struct brcmf_usbdev_info *devinfo) 184 { 185 wake_up(&devinfo->ioctl_resp_wait); 186 } 187 188 static void 189 brcmf_usb_ctl_complete(struct brcmf_usbdev_info *devinfo, int type, int status) 190 { 191 brcmf_dbg(USB, "Enter, status=%d\n", status); 192 193 if (unlikely(devinfo == NULL)) 194 return; 195 196 if (type == BRCMF_USB_CBCTL_READ) { 197 if (status == 0) 198 devinfo->bus_pub.stats.rx_ctlpkts++; 199 else 200 devinfo->bus_pub.stats.rx_ctlerrs++; 201 } else if (type == BRCMF_USB_CBCTL_WRITE) { 202 if (status == 0) 203 devinfo->bus_pub.stats.tx_ctlpkts++; 204 else 205 devinfo->bus_pub.stats.tx_ctlerrs++; 206 } 207 208 devinfo->ctl_urb_status = status; 209 devinfo->ctl_completed = true; 210 brcmf_usb_ioctl_resp_wake(devinfo); 211 } 212 213 static void 214 brcmf_usb_ctlread_complete(struct urb *urb) 215 { 216 struct brcmf_usbdev_info *devinfo = 217 (struct brcmf_usbdev_info *)urb->context; 218 219 brcmf_dbg(USB, "Enter\n"); 220 devinfo->ctl_urb_actual_length = urb->actual_length; 221 brcmf_usb_ctl_complete(devinfo, BRCMF_USB_CBCTL_READ, 222 urb->status); 223 } 224 225 static void 226 brcmf_usb_ctlwrite_complete(struct urb *urb) 227 { 228 struct brcmf_usbdev_info *devinfo = 229 (struct brcmf_usbdev_info *)urb->context; 230 231 brcmf_dbg(USB, "Enter\n"); 232 brcmf_usb_ctl_complete(devinfo, BRCMF_USB_CBCTL_WRITE, 233 urb->status); 234 } 235 236 static int 237 brcmf_usb_send_ctl(struct brcmf_usbdev_info *devinfo, u8 *buf, int len) 238 { 239 int ret; 240 u16 size; 241 242 brcmf_dbg(USB, "Enter\n"); 243 if (devinfo == NULL || buf == NULL || 244 len == 0 || devinfo->ctl_urb == NULL) 245 return -EINVAL; 246 247 size = len; 248 devinfo->ctl_write.wLength = cpu_to_le16p(&size); 249 devinfo->ctl_urb->transfer_buffer_length = size; 250 devinfo->ctl_urb_status = 0; 251 devinfo->ctl_urb_actual_length = 0; 252 253 usb_fill_control_urb(devinfo->ctl_urb, 254 devinfo->usbdev, 255 devinfo->ctl_out_pipe, 256 (unsigned char *) &devinfo->ctl_write, 257 buf, size, 258 (usb_complete_t)brcmf_usb_ctlwrite_complete, 259 devinfo); 260 261 ret = usb_submit_urb(devinfo->ctl_urb, GFP_ATOMIC); 262 if (ret < 0) 263 brcmf_err("usb_submit_urb failed %d\n", ret); 264 265 return ret; 266 } 267 268 static int 269 brcmf_usb_recv_ctl(struct brcmf_usbdev_info *devinfo, u8 *buf, int len) 270 { 271 int ret; 272 u16 size; 273 274 brcmf_dbg(USB, "Enter\n"); 275 if ((devinfo == NULL) || (buf == NULL) || (len == 0) 276 || (devinfo->ctl_urb == NULL)) 277 return -EINVAL; 278 279 size = len; 280 devinfo->ctl_read.wLength = cpu_to_le16p(&size); 281 devinfo->ctl_urb->transfer_buffer_length = size; 282 283 devinfo->ctl_read.bRequestType = USB_DIR_IN 284 | USB_TYPE_CLASS | USB_RECIP_INTERFACE; 285 devinfo->ctl_read.bRequest = 1; 286 287 usb_fill_control_urb(devinfo->ctl_urb, 288 devinfo->usbdev, 289 devinfo->ctl_in_pipe, 290 (unsigned char *) &devinfo->ctl_read, 291 buf, size, 292 (usb_complete_t)brcmf_usb_ctlread_complete, 293 devinfo); 294 295 ret = usb_submit_urb(devinfo->ctl_urb, GFP_ATOMIC); 296 if (ret < 0) 297 brcmf_err("usb_submit_urb failed %d\n", ret); 298 299 return ret; 300 } 301 302 static int brcmf_usb_tx_ctlpkt(struct device *dev, u8 *buf, u32 len) 303 { 304 int err = 0; 305 int timeout = 0; 306 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(dev); 307 struct usb_interface *intf = to_usb_interface(dev); 308 309 brcmf_dbg(USB, "Enter\n"); 310 311 err = usb_autopm_get_interface(intf); 312 if (err) 313 goto out; 314 315 if (devinfo->bus_pub.state != BRCMFMAC_USB_STATE_UP) { 316 err = -EIO; 317 goto fail; 318 } 319 320 if (test_and_set_bit(0, &devinfo->ctl_op)) { 321 err = -EIO; 322 goto fail; 323 } 324 325 devinfo->ctl_completed = false; 326 err = brcmf_usb_send_ctl(devinfo, buf, len); 327 if (err) { 328 brcmf_err("fail %d bytes: %d\n", err, len); 329 clear_bit(0, &devinfo->ctl_op); 330 goto fail; 331 } 332 timeout = brcmf_usb_ioctl_resp_wait(devinfo); 333 if (!timeout) { 334 brcmf_err("Txctl wait timed out\n"); 335 usb_kill_urb(devinfo->ctl_urb); 336 err = -EIO; 337 goto fail; 338 } 339 clear_bit(0, &devinfo->ctl_op); 340 341 fail: 342 usb_autopm_put_interface(intf); 343 out: 344 return err; 345 } 346 347 static int brcmf_usb_rx_ctlpkt(struct device *dev, u8 *buf, u32 len) 348 { 349 int err = 0; 350 int timeout = 0; 351 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(dev); 352 struct usb_interface *intf = to_usb_interface(dev); 353 354 brcmf_dbg(USB, "Enter\n"); 355 356 err = usb_autopm_get_interface(intf); 357 if (err) 358 goto out; 359 360 if (devinfo->bus_pub.state != BRCMFMAC_USB_STATE_UP) { 361 err = -EIO; 362 goto fail; 363 } 364 365 if (test_and_set_bit(0, &devinfo->ctl_op)) { 366 err = -EIO; 367 goto fail; 368 } 369 370 devinfo->ctl_completed = false; 371 err = brcmf_usb_recv_ctl(devinfo, buf, len); 372 if (err) { 373 brcmf_err("fail %d bytes: %d\n", err, len); 374 clear_bit(0, &devinfo->ctl_op); 375 goto fail; 376 } 377 timeout = brcmf_usb_ioctl_resp_wait(devinfo); 378 err = devinfo->ctl_urb_status; 379 if (!timeout) { 380 brcmf_err("rxctl wait timed out\n"); 381 usb_kill_urb(devinfo->ctl_urb); 382 err = -EIO; 383 goto fail; 384 } 385 clear_bit(0, &devinfo->ctl_op); 386 fail: 387 usb_autopm_put_interface(intf); 388 if (!err) 389 return devinfo->ctl_urb_actual_length; 390 out: 391 return err; 392 } 393 394 static struct brcmf_usbreq *brcmf_usb_deq(struct brcmf_usbdev_info *devinfo, 395 struct list_head *q, int *counter) 396 { 397 unsigned long flags; 398 struct brcmf_usbreq *req; 399 spin_lock_irqsave(&devinfo->qlock, flags); 400 if (list_empty(q)) { 401 spin_unlock_irqrestore(&devinfo->qlock, flags); 402 return NULL; 403 } 404 req = list_entry(q->next, struct brcmf_usbreq, list); 405 list_del_init(q->next); 406 if (counter) 407 (*counter)--; 408 spin_unlock_irqrestore(&devinfo->qlock, flags); 409 return req; 410 411 } 412 413 static void brcmf_usb_enq(struct brcmf_usbdev_info *devinfo, 414 struct list_head *q, struct brcmf_usbreq *req, 415 int *counter) 416 { 417 unsigned long flags; 418 spin_lock_irqsave(&devinfo->qlock, flags); 419 list_add_tail(&req->list, q); 420 if (counter) 421 (*counter)++; 422 spin_unlock_irqrestore(&devinfo->qlock, flags); 423 } 424 425 static struct brcmf_usbreq * 426 brcmf_usbdev_qinit(struct list_head *q, int qsize) 427 { 428 int i; 429 struct brcmf_usbreq *req, *reqs; 430 431 reqs = kcalloc(qsize, sizeof(struct brcmf_usbreq), GFP_ATOMIC); 432 if (reqs == NULL) 433 return NULL; 434 435 req = reqs; 436 437 for (i = 0; i < qsize; i++) { 438 req->urb = usb_alloc_urb(0, GFP_ATOMIC); 439 if (!req->urb) 440 goto fail; 441 442 INIT_LIST_HEAD(&req->list); 443 list_add_tail(&req->list, q); 444 req++; 445 } 446 return reqs; 447 fail: 448 brcmf_err("fail!\n"); 449 while (!list_empty(q)) { 450 req = list_entry(q->next, struct brcmf_usbreq, list); 451 if (req) 452 usb_free_urb(req->urb); 453 list_del(q->next); 454 } 455 kfree(reqs); 456 return NULL; 457 458 } 459 460 static void brcmf_usb_free_q(struct list_head *q) 461 { 462 struct brcmf_usbreq *req, *next; 463 464 list_for_each_entry_safe(req, next, q, list) { 465 if (!req->urb) { 466 brcmf_err("bad req\n"); 467 break; 468 } 469 usb_free_urb(req->urb); 470 list_del_init(&req->list); 471 } 472 } 473 474 static void brcmf_usb_del_fromq(struct brcmf_usbdev_info *devinfo, 475 struct brcmf_usbreq *req) 476 { 477 unsigned long flags; 478 479 spin_lock_irqsave(&devinfo->qlock, flags); 480 list_del_init(&req->list); 481 spin_unlock_irqrestore(&devinfo->qlock, flags); 482 } 483 484 485 static void brcmf_usb_tx_complete(struct urb *urb) 486 { 487 struct brcmf_usbreq *req = (struct brcmf_usbreq *)urb->context; 488 struct brcmf_usbdev_info *devinfo = req->devinfo; 489 unsigned long flags; 490 491 brcmf_dbg(USB, "Enter, urb->status=%d, skb=%p\n", urb->status, 492 req->skb); 493 brcmf_usb_del_fromq(devinfo, req); 494 495 brcmf_proto_bcdc_txcomplete(devinfo->dev, req->skb, urb->status == 0); 496 req->skb = NULL; 497 brcmf_usb_enq(devinfo, &devinfo->tx_freeq, req, &devinfo->tx_freecount); 498 spin_lock_irqsave(&devinfo->tx_flowblock_lock, flags); 499 if (devinfo->tx_freecount > devinfo->tx_high_watermark && 500 devinfo->tx_flowblock) { 501 brcmf_proto_bcdc_txflowblock(devinfo->dev, false); 502 devinfo->tx_flowblock = false; 503 } 504 spin_unlock_irqrestore(&devinfo->tx_flowblock_lock, flags); 505 } 506 507 static void brcmf_usb_rx_complete(struct urb *urb) 508 { 509 struct brcmf_usbreq *req = (struct brcmf_usbreq *)urb->context; 510 struct brcmf_usbdev_info *devinfo = req->devinfo; 511 struct sk_buff *skb; 512 513 brcmf_dbg(USB, "Enter, urb->status=%d\n", urb->status); 514 brcmf_usb_del_fromq(devinfo, req); 515 skb = req->skb; 516 req->skb = NULL; 517 518 /* zero length packets indicate usb "failure". Do not refill */ 519 if (urb->status != 0 || !urb->actual_length) { 520 brcmu_pkt_buf_free_skb(skb); 521 brcmf_usb_enq(devinfo, &devinfo->rx_freeq, req, NULL); 522 return; 523 } 524 525 if (devinfo->bus_pub.state == BRCMFMAC_USB_STATE_UP || 526 devinfo->bus_pub.state == BRCMFMAC_USB_STATE_SLEEP) { 527 skb_put(skb, urb->actual_length); 528 brcmf_rx_frame(devinfo->dev, skb, true, true); 529 brcmf_usb_rx_refill(devinfo, req); 530 usb_mark_last_busy(urb->dev); 531 } else { 532 brcmu_pkt_buf_free_skb(skb); 533 brcmf_usb_enq(devinfo, &devinfo->rx_freeq, req, NULL); 534 } 535 return; 536 537 } 538 539 static void brcmf_usb_rx_refill(struct brcmf_usbdev_info *devinfo, 540 struct brcmf_usbreq *req) 541 { 542 struct sk_buff *skb; 543 int ret; 544 545 if (!req || !devinfo) 546 return; 547 548 skb = dev_alloc_skb(devinfo->bus_pub.bus_mtu); 549 if (!skb) { 550 brcmf_usb_enq(devinfo, &devinfo->rx_freeq, req, NULL); 551 return; 552 } 553 req->skb = skb; 554 555 usb_fill_bulk_urb(req->urb, devinfo->usbdev, devinfo->rx_pipe, 556 skb->data, skb_tailroom(skb), brcmf_usb_rx_complete, 557 req); 558 req->devinfo = devinfo; 559 brcmf_usb_enq(devinfo, &devinfo->rx_postq, req, NULL); 560 561 ret = usb_submit_urb(req->urb, GFP_ATOMIC); 562 if (ret) { 563 brcmf_usb_del_fromq(devinfo, req); 564 brcmu_pkt_buf_free_skb(req->skb); 565 req->skb = NULL; 566 brcmf_usb_enq(devinfo, &devinfo->rx_freeq, req, NULL); 567 } 568 return; 569 } 570 571 static void brcmf_usb_rx_fill_all(struct brcmf_usbdev_info *devinfo) 572 { 573 struct brcmf_usbreq *req; 574 575 if (devinfo->bus_pub.state != BRCMFMAC_USB_STATE_UP) { 576 brcmf_err("bus is not up=%d\n", devinfo->bus_pub.state); 577 return; 578 } 579 while ((req = brcmf_usb_deq(devinfo, &devinfo->rx_freeq, NULL)) != NULL) 580 brcmf_usb_rx_refill(devinfo, req); 581 } 582 583 static void 584 brcmf_usb_state_change(struct brcmf_usbdev_info *devinfo, int state) 585 { 586 struct brcmf_bus *bcmf_bus = devinfo->bus_pub.bus; 587 588 brcmf_dbg(USB, "Enter, current state=%d, new state=%d\n", 589 devinfo->bus_pub.state, state); 590 591 if (devinfo->bus_pub.state == state) 592 return; 593 594 devinfo->bus_pub.state = state; 595 596 /* update state of upper layer */ 597 if (state == BRCMFMAC_USB_STATE_DOWN) { 598 brcmf_dbg(USB, "DBUS is down\n"); 599 brcmf_bus_change_state(bcmf_bus, BRCMF_BUS_DOWN); 600 } else if (state == BRCMFMAC_USB_STATE_UP) { 601 brcmf_dbg(USB, "DBUS is up\n"); 602 brcmf_bus_change_state(bcmf_bus, BRCMF_BUS_UP); 603 } else { 604 brcmf_dbg(USB, "DBUS current state=%d\n", state); 605 } 606 } 607 608 static int brcmf_usb_tx(struct device *dev, struct sk_buff *skb) 609 { 610 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(dev); 611 struct brcmf_usbreq *req; 612 int ret; 613 unsigned long flags; 614 struct usb_interface *intf = to_usb_interface(dev); 615 616 ret = usb_autopm_get_interface(intf); 617 if (ret) 618 goto out; 619 620 brcmf_dbg(USB, "Enter, skb=%p\n", skb); 621 if (devinfo->bus_pub.state != BRCMFMAC_USB_STATE_UP) { 622 ret = -EIO; 623 goto fail; 624 } 625 626 req = brcmf_usb_deq(devinfo, &devinfo->tx_freeq, 627 &devinfo->tx_freecount); 628 if (!req) { 629 brcmf_err("no req to send\n"); 630 ret = -ENOMEM; 631 goto fail; 632 } 633 634 req->skb = skb; 635 req->devinfo = devinfo; 636 usb_fill_bulk_urb(req->urb, devinfo->usbdev, devinfo->tx_pipe, 637 skb->data, skb->len, brcmf_usb_tx_complete, req); 638 req->urb->transfer_flags |= URB_ZERO_PACKET; 639 brcmf_usb_enq(devinfo, &devinfo->tx_postq, req, NULL); 640 ret = usb_submit_urb(req->urb, GFP_ATOMIC); 641 if (ret) { 642 brcmf_err("brcmf_usb_tx usb_submit_urb FAILED\n"); 643 brcmf_usb_del_fromq(devinfo, req); 644 req->skb = NULL; 645 brcmf_usb_enq(devinfo, &devinfo->tx_freeq, req, 646 &devinfo->tx_freecount); 647 goto fail; 648 } 649 650 spin_lock_irqsave(&devinfo->tx_flowblock_lock, flags); 651 if (devinfo->tx_freecount < devinfo->tx_low_watermark && 652 !devinfo->tx_flowblock) { 653 brcmf_proto_bcdc_txflowblock(dev, true); 654 devinfo->tx_flowblock = true; 655 } 656 spin_unlock_irqrestore(&devinfo->tx_flowblock_lock, flags); 657 658 fail: 659 usb_autopm_put_interface(intf); 660 out: 661 return ret; 662 } 663 664 665 static int brcmf_usb_up(struct device *dev) 666 { 667 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(dev); 668 669 brcmf_dbg(USB, "Enter\n"); 670 if (devinfo->bus_pub.state == BRCMFMAC_USB_STATE_UP) 671 return 0; 672 673 /* Success, indicate devinfo is fully up */ 674 brcmf_usb_state_change(devinfo, BRCMFMAC_USB_STATE_UP); 675 676 if (devinfo->ctl_urb) { 677 devinfo->ctl_in_pipe = usb_rcvctrlpipe(devinfo->usbdev, 0); 678 devinfo->ctl_out_pipe = usb_sndctrlpipe(devinfo->usbdev, 0); 679 680 /* CTL Write */ 681 devinfo->ctl_write.bRequestType = 682 USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_INTERFACE; 683 devinfo->ctl_write.bRequest = 0; 684 devinfo->ctl_write.wValue = cpu_to_le16(0); 685 devinfo->ctl_write.wIndex = cpu_to_le16(devinfo->ifnum); 686 687 /* CTL Read */ 688 devinfo->ctl_read.bRequestType = 689 USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE; 690 devinfo->ctl_read.bRequest = 1; 691 devinfo->ctl_read.wValue = cpu_to_le16(0); 692 devinfo->ctl_read.wIndex = cpu_to_le16(devinfo->ifnum); 693 } 694 brcmf_usb_rx_fill_all(devinfo); 695 return 0; 696 } 697 698 static void brcmf_cancel_all_urbs(struct brcmf_usbdev_info *devinfo) 699 { 700 int i; 701 702 if (devinfo->ctl_urb) 703 usb_kill_urb(devinfo->ctl_urb); 704 if (devinfo->bulk_urb) 705 usb_kill_urb(devinfo->bulk_urb); 706 if (devinfo->tx_reqs) 707 for (i = 0; i < devinfo->bus_pub.ntxq; i++) 708 usb_kill_urb(devinfo->tx_reqs[i].urb); 709 if (devinfo->rx_reqs) 710 for (i = 0; i < devinfo->bus_pub.nrxq; i++) 711 usb_kill_urb(devinfo->rx_reqs[i].urb); 712 } 713 714 static void brcmf_usb_down(struct device *dev) 715 { 716 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(dev); 717 718 brcmf_dbg(USB, "Enter\n"); 719 if (devinfo == NULL) 720 return; 721 722 if (devinfo->bus_pub.state == BRCMFMAC_USB_STATE_DOWN) 723 return; 724 725 brcmf_usb_state_change(devinfo, BRCMFMAC_USB_STATE_DOWN); 726 727 brcmf_cancel_all_urbs(devinfo); 728 } 729 730 static void 731 brcmf_usb_sync_complete(struct urb *urb) 732 { 733 struct brcmf_usbdev_info *devinfo = 734 (struct brcmf_usbdev_info *)urb->context; 735 736 devinfo->ctl_completed = true; 737 brcmf_usb_ioctl_resp_wake(devinfo); 738 } 739 740 static int brcmf_usb_dl_cmd(struct brcmf_usbdev_info *devinfo, u8 cmd, 741 void *buffer, int buflen) 742 { 743 int ret; 744 char *tmpbuf = NULL; 745 u16 size; 746 747 if (!devinfo || !devinfo->ctl_urb) { 748 ret = -EINVAL; 749 goto err; 750 } 751 752 tmpbuf = kmalloc(buflen, GFP_ATOMIC); 753 if (!tmpbuf) { 754 ret = -ENOMEM; 755 goto err; 756 } 757 758 size = buflen; 759 devinfo->ctl_urb->transfer_buffer_length = size; 760 761 devinfo->ctl_read.wLength = cpu_to_le16p(&size); 762 devinfo->ctl_read.bRequestType = USB_DIR_IN | USB_TYPE_VENDOR | 763 USB_RECIP_INTERFACE; 764 devinfo->ctl_read.bRequest = cmd; 765 766 usb_fill_control_urb(devinfo->ctl_urb, 767 devinfo->usbdev, 768 usb_rcvctrlpipe(devinfo->usbdev, 0), 769 (unsigned char *) &devinfo->ctl_read, 770 (void *) tmpbuf, size, 771 (usb_complete_t)brcmf_usb_sync_complete, devinfo); 772 773 devinfo->ctl_completed = false; 774 ret = usb_submit_urb(devinfo->ctl_urb, GFP_ATOMIC); 775 if (ret < 0) { 776 brcmf_err("usb_submit_urb failed %d\n", ret); 777 goto err; 778 } 779 780 if (!brcmf_usb_ioctl_resp_wait(devinfo)) { 781 usb_kill_urb(devinfo->ctl_urb); 782 ret = -ETIMEDOUT; 783 goto err; 784 } else { 785 memcpy(buffer, tmpbuf, buflen); 786 } 787 788 kfree(tmpbuf); 789 return 0; 790 791 err: 792 kfree(tmpbuf); 793 brcmf_err("dl cmd %u failed: err=%d\n", cmd, ret); 794 return ret; 795 } 796 797 static bool 798 brcmf_usb_dlneeded(struct brcmf_usbdev_info *devinfo) 799 { 800 struct bootrom_id_le id; 801 u32 chipid, chiprev; 802 803 brcmf_dbg(USB, "Enter\n"); 804 805 if (devinfo == NULL) 806 return false; 807 808 /* Check if firmware downloaded already by querying runtime ID */ 809 id.chip = cpu_to_le32(0xDEAD); 810 brcmf_usb_dl_cmd(devinfo, DL_GETVER, &id, sizeof(id)); 811 812 chipid = le32_to_cpu(id.chip); 813 chiprev = le32_to_cpu(id.chiprev); 814 815 if ((chipid & 0x4300) == 0x4300) 816 brcmf_dbg(USB, "chip %x rev 0x%x\n", chipid, chiprev); 817 else 818 brcmf_dbg(USB, "chip %d rev 0x%x\n", chipid, chiprev); 819 if (chipid == BRCMF_POSTBOOT_ID) { 820 brcmf_dbg(USB, "firmware already downloaded\n"); 821 brcmf_usb_dl_cmd(devinfo, DL_RESETCFG, &id, sizeof(id)); 822 return false; 823 } else { 824 devinfo->bus_pub.devid = chipid; 825 devinfo->bus_pub.chiprev = chiprev; 826 } 827 return true; 828 } 829 830 static int 831 brcmf_usb_resetcfg(struct brcmf_usbdev_info *devinfo) 832 { 833 struct bootrom_id_le id; 834 u32 loop_cnt; 835 int err; 836 837 brcmf_dbg(USB, "Enter\n"); 838 839 loop_cnt = 0; 840 do { 841 mdelay(BRCMF_USB_RESET_GETVER_SPINWAIT); 842 loop_cnt++; 843 id.chip = cpu_to_le32(0xDEAD); /* Get the ID */ 844 err = brcmf_usb_dl_cmd(devinfo, DL_GETVER, &id, sizeof(id)); 845 if ((err) && (err != -ETIMEDOUT)) 846 return err; 847 if (id.chip == cpu_to_le32(BRCMF_POSTBOOT_ID)) 848 break; 849 } while (loop_cnt < BRCMF_USB_RESET_GETVER_LOOP_CNT); 850 851 if (id.chip == cpu_to_le32(BRCMF_POSTBOOT_ID)) { 852 brcmf_dbg(USB, "postboot chip 0x%x/rev 0x%x\n", 853 le32_to_cpu(id.chip), le32_to_cpu(id.chiprev)); 854 855 brcmf_usb_dl_cmd(devinfo, DL_RESETCFG, &id, sizeof(id)); 856 return 0; 857 } else { 858 brcmf_err("Cannot talk to Dongle. Firmware is not UP, %d ms\n", 859 BRCMF_USB_RESET_GETVER_SPINWAIT * loop_cnt); 860 return -EINVAL; 861 } 862 } 863 864 865 static int 866 brcmf_usb_dl_send_bulk(struct brcmf_usbdev_info *devinfo, void *buffer, int len) 867 { 868 int ret; 869 870 if ((devinfo == NULL) || (devinfo->bulk_urb == NULL)) 871 return -EINVAL; 872 873 /* Prepare the URB */ 874 usb_fill_bulk_urb(devinfo->bulk_urb, devinfo->usbdev, 875 devinfo->tx_pipe, buffer, len, 876 (usb_complete_t)brcmf_usb_sync_complete, devinfo); 877 878 devinfo->bulk_urb->transfer_flags |= URB_ZERO_PACKET; 879 880 devinfo->ctl_completed = false; 881 ret = usb_submit_urb(devinfo->bulk_urb, GFP_ATOMIC); 882 if (ret) { 883 brcmf_err("usb_submit_urb failed %d\n", ret); 884 return ret; 885 } 886 ret = brcmf_usb_ioctl_resp_wait(devinfo); 887 return (ret == 0); 888 } 889 890 static int 891 brcmf_usb_dl_writeimage(struct brcmf_usbdev_info *devinfo, u8 *fw, int fwlen) 892 { 893 unsigned int sendlen, sent, dllen; 894 char *bulkchunk = NULL, *dlpos; 895 struct rdl_state_le state; 896 u32 rdlstate, rdlbytes; 897 int err = 0; 898 899 brcmf_dbg(USB, "Enter, fw %p, len %d\n", fw, fwlen); 900 901 bulkchunk = kmalloc(TRX_RDL_CHUNK, GFP_ATOMIC); 902 if (bulkchunk == NULL) { 903 err = -ENOMEM; 904 goto fail; 905 } 906 907 /* 1) Prepare USB boot loader for runtime image */ 908 brcmf_usb_dl_cmd(devinfo, DL_START, &state, sizeof(state)); 909 910 rdlstate = le32_to_cpu(state.state); 911 rdlbytes = le32_to_cpu(state.bytes); 912 913 /* 2) Check we are in the Waiting state */ 914 if (rdlstate != DL_WAITING) { 915 brcmf_err("Failed to DL_START\n"); 916 err = -EINVAL; 917 goto fail; 918 } 919 sent = 0; 920 dlpos = fw; 921 dllen = fwlen; 922 923 /* Get chip id and rev */ 924 while (rdlbytes != dllen) { 925 /* Wait until the usb device reports it received all 926 * the bytes we sent */ 927 if ((rdlbytes == sent) && (rdlbytes != dllen)) { 928 if ((dllen-sent) < TRX_RDL_CHUNK) 929 sendlen = dllen-sent; 930 else 931 sendlen = TRX_RDL_CHUNK; 932 933 /* simply avoid having to send a ZLP by ensuring we 934 * never have an even 935 * multiple of 64 936 */ 937 if (!(sendlen % 64)) 938 sendlen -= 4; 939 940 /* send data */ 941 memcpy(bulkchunk, dlpos, sendlen); 942 if (brcmf_usb_dl_send_bulk(devinfo, bulkchunk, 943 sendlen)) { 944 brcmf_err("send_bulk failed\n"); 945 err = -EINVAL; 946 goto fail; 947 } 948 949 dlpos += sendlen; 950 sent += sendlen; 951 } 952 err = brcmf_usb_dl_cmd(devinfo, DL_GETSTATE, &state, 953 sizeof(state)); 954 if (err) { 955 brcmf_err("DL_GETSTATE Failed\n"); 956 goto fail; 957 } 958 959 rdlstate = le32_to_cpu(state.state); 960 rdlbytes = le32_to_cpu(state.bytes); 961 962 /* restart if an error is reported */ 963 if (rdlstate == DL_BAD_HDR || rdlstate == DL_BAD_CRC) { 964 brcmf_err("Bad Hdr or Bad CRC state %d\n", 965 rdlstate); 966 err = -EINVAL; 967 goto fail; 968 } 969 } 970 971 fail: 972 kfree(bulkchunk); 973 brcmf_dbg(USB, "Exit, err=%d\n", err); 974 return err; 975 } 976 977 static int brcmf_usb_dlstart(struct brcmf_usbdev_info *devinfo, u8 *fw, int len) 978 { 979 int err; 980 981 brcmf_dbg(USB, "Enter\n"); 982 983 if (devinfo == NULL) 984 return -EINVAL; 985 986 if (devinfo->bus_pub.devid == 0xDEAD) 987 return -EINVAL; 988 989 err = brcmf_usb_dl_writeimage(devinfo, fw, len); 990 if (err == 0) 991 devinfo->bus_pub.state = BRCMFMAC_USB_STATE_DL_DONE; 992 else 993 devinfo->bus_pub.state = BRCMFMAC_USB_STATE_DL_FAIL; 994 brcmf_dbg(USB, "Exit, err=%d\n", err); 995 996 return err; 997 } 998 999 static int brcmf_usb_dlrun(struct brcmf_usbdev_info *devinfo) 1000 { 1001 struct rdl_state_le state; 1002 1003 brcmf_dbg(USB, "Enter\n"); 1004 if (!devinfo) 1005 return -EINVAL; 1006 1007 if (devinfo->bus_pub.devid == 0xDEAD) 1008 return -EINVAL; 1009 1010 /* Check we are runnable */ 1011 state.state = 0; 1012 brcmf_usb_dl_cmd(devinfo, DL_GETSTATE, &state, sizeof(state)); 1013 1014 /* Start the image */ 1015 if (state.state == cpu_to_le32(DL_RUNNABLE)) { 1016 if (brcmf_usb_dl_cmd(devinfo, DL_GO, &state, sizeof(state))) 1017 return -ENODEV; 1018 if (brcmf_usb_resetcfg(devinfo)) 1019 return -ENODEV; 1020 /* The Dongle may go for re-enumeration. */ 1021 } else { 1022 brcmf_err("Dongle not runnable\n"); 1023 return -EINVAL; 1024 } 1025 brcmf_dbg(USB, "Exit\n"); 1026 return 0; 1027 } 1028 1029 static int 1030 brcmf_usb_fw_download(struct brcmf_usbdev_info *devinfo) 1031 { 1032 int err; 1033 struct usb_interface *intf; 1034 1035 brcmf_dbg(USB, "Enter\n"); 1036 if (!devinfo) { 1037 err = -ENODEV; 1038 goto out; 1039 } 1040 1041 if (!devinfo->image) { 1042 brcmf_err("No firmware!\n"); 1043 err = -ENOENT; 1044 goto out; 1045 } 1046 1047 intf = to_usb_interface(devinfo->dev); 1048 err = usb_autopm_get_interface(intf); 1049 if (err) 1050 goto out; 1051 1052 err = brcmf_usb_dlstart(devinfo, 1053 (u8 *)devinfo->image, devinfo->image_len); 1054 if (err == 0) 1055 err = brcmf_usb_dlrun(devinfo); 1056 1057 usb_autopm_put_interface(intf); 1058 out: 1059 return err; 1060 } 1061 1062 1063 static void brcmf_usb_detach(struct brcmf_usbdev_info *devinfo) 1064 { 1065 brcmf_dbg(USB, "Enter, devinfo %p\n", devinfo); 1066 1067 /* free the URBS */ 1068 brcmf_usb_free_q(&devinfo->rx_freeq); 1069 brcmf_usb_free_q(&devinfo->tx_freeq); 1070 1071 usb_free_urb(devinfo->ctl_urb); 1072 usb_free_urb(devinfo->bulk_urb); 1073 1074 kfree(devinfo->tx_reqs); 1075 kfree(devinfo->rx_reqs); 1076 1077 if (devinfo->settings) 1078 brcmf_release_module_param(devinfo->settings); 1079 } 1080 1081 1082 static int check_file(const u8 *headers) 1083 { 1084 struct trx_header_le *trx; 1085 int actual_len = -1; 1086 1087 brcmf_dbg(USB, "Enter\n"); 1088 /* Extract trx header */ 1089 trx = (struct trx_header_le *) headers; 1090 if (trx->magic != cpu_to_le32(TRX_MAGIC)) 1091 return -1; 1092 1093 headers += sizeof(struct trx_header_le); 1094 1095 if (le32_to_cpu(trx->flag_version) & TRX_UNCOMP_IMAGE) { 1096 actual_len = le32_to_cpu(trx->offsets[TRX_OFFSETS_DLFWLEN_IDX]); 1097 return actual_len + sizeof(struct trx_header_le); 1098 } 1099 return -1; 1100 } 1101 1102 1103 static 1104 struct brcmf_usbdev *brcmf_usb_attach(struct brcmf_usbdev_info *devinfo, 1105 int nrxq, int ntxq) 1106 { 1107 brcmf_dbg(USB, "Enter\n"); 1108 1109 devinfo->bus_pub.nrxq = nrxq; 1110 devinfo->rx_low_watermark = nrxq / 2; 1111 devinfo->bus_pub.devinfo = devinfo; 1112 devinfo->bus_pub.ntxq = ntxq; 1113 devinfo->bus_pub.state = BRCMFMAC_USB_STATE_DOWN; 1114 1115 /* flow control when too many tx urbs posted */ 1116 devinfo->tx_low_watermark = ntxq / 4; 1117 devinfo->tx_high_watermark = devinfo->tx_low_watermark * 3; 1118 devinfo->bus_pub.bus_mtu = BRCMF_USB_MAX_PKT_SIZE; 1119 1120 /* Initialize other structure content */ 1121 init_waitqueue_head(&devinfo->ioctl_resp_wait); 1122 1123 /* Initialize the spinlocks */ 1124 spin_lock_init(&devinfo->qlock); 1125 spin_lock_init(&devinfo->tx_flowblock_lock); 1126 1127 INIT_LIST_HEAD(&devinfo->rx_freeq); 1128 INIT_LIST_HEAD(&devinfo->rx_postq); 1129 1130 INIT_LIST_HEAD(&devinfo->tx_freeq); 1131 INIT_LIST_HEAD(&devinfo->tx_postq); 1132 1133 devinfo->tx_flowblock = false; 1134 1135 devinfo->rx_reqs = brcmf_usbdev_qinit(&devinfo->rx_freeq, nrxq); 1136 if (!devinfo->rx_reqs) 1137 goto error; 1138 1139 devinfo->tx_reqs = brcmf_usbdev_qinit(&devinfo->tx_freeq, ntxq); 1140 if (!devinfo->tx_reqs) 1141 goto error; 1142 devinfo->tx_freecount = ntxq; 1143 1144 devinfo->ctl_urb = usb_alloc_urb(0, GFP_ATOMIC); 1145 if (!devinfo->ctl_urb) 1146 goto error; 1147 devinfo->bulk_urb = usb_alloc_urb(0, GFP_ATOMIC); 1148 if (!devinfo->bulk_urb) 1149 goto error; 1150 1151 return &devinfo->bus_pub; 1152 1153 error: 1154 brcmf_err("failed!\n"); 1155 brcmf_usb_detach(devinfo); 1156 return NULL; 1157 } 1158 1159 static int brcmf_usb_get_blob(struct device *dev, const struct firmware **fw, 1160 enum brcmf_blob_type type) 1161 { 1162 /* No blobs for USB devices... */ 1163 return -ENOENT; 1164 } 1165 1166 static const struct brcmf_bus_ops brcmf_usb_bus_ops = { 1167 .preinit = brcmf_usb_up, 1168 .stop = brcmf_usb_down, 1169 .txdata = brcmf_usb_tx, 1170 .txctl = brcmf_usb_tx_ctlpkt, 1171 .rxctl = brcmf_usb_rx_ctlpkt, 1172 .get_blob = brcmf_usb_get_blob, 1173 }; 1174 1175 #define BRCMF_USB_FW_CODE 0 1176 1177 static void brcmf_usb_probe_phase2(struct device *dev, int ret, 1178 struct brcmf_fw_request *fwreq) 1179 { 1180 struct brcmf_bus *bus = dev_get_drvdata(dev); 1181 struct brcmf_usbdev_info *devinfo = bus->bus_priv.usb->devinfo; 1182 const struct firmware *fw; 1183 1184 if (ret) 1185 goto error; 1186 1187 brcmf_dbg(USB, "Start fw downloading\n"); 1188 1189 fw = fwreq->items[BRCMF_USB_FW_CODE].binary; 1190 kfree(fwreq); 1191 1192 ret = check_file(fw->data); 1193 if (ret < 0) { 1194 brcmf_err("invalid firmware\n"); 1195 release_firmware(fw); 1196 goto error; 1197 } 1198 1199 devinfo->image = fw->data; 1200 devinfo->image_len = fw->size; 1201 1202 ret = brcmf_usb_fw_download(devinfo); 1203 release_firmware(fw); 1204 if (ret) 1205 goto error; 1206 1207 ret = brcmf_alloc(devinfo->dev, devinfo->settings); 1208 if (ret) 1209 goto error; 1210 1211 /* Attach to the common driver interface */ 1212 ret = brcmf_attach(devinfo->dev); 1213 if (ret) 1214 goto error; 1215 1216 complete(&devinfo->dev_init_done); 1217 return; 1218 error: 1219 brcmf_dbg(TRACE, "failed: dev=%s, err=%d\n", dev_name(dev), ret); 1220 complete(&devinfo->dev_init_done); 1221 device_release_driver(dev); 1222 } 1223 1224 static struct brcmf_fw_request * 1225 brcmf_usb_prepare_fw_request(struct brcmf_usbdev_info *devinfo) 1226 { 1227 struct brcmf_fw_request *fwreq; 1228 struct brcmf_fw_name fwnames[] = { 1229 { ".bin", devinfo->fw_name }, 1230 }; 1231 1232 fwreq = brcmf_fw_alloc_request(devinfo->bus_pub.devid, 1233 devinfo->bus_pub.chiprev, 1234 brcmf_usb_fwnames, 1235 ARRAY_SIZE(brcmf_usb_fwnames), 1236 fwnames, ARRAY_SIZE(fwnames)); 1237 if (!fwreq) 1238 return NULL; 1239 1240 fwreq->items[BRCMF_USB_FW_CODE].type = BRCMF_FW_TYPE_BINARY; 1241 1242 return fwreq; 1243 } 1244 1245 static int brcmf_usb_probe_cb(struct brcmf_usbdev_info *devinfo, 1246 enum brcmf_fwvendor fwvid) 1247 { 1248 struct brcmf_bus *bus; 1249 struct brcmf_usbdev *bus_pub; 1250 struct device *dev = devinfo->dev; 1251 struct brcmf_fw_request *fwreq; 1252 int ret; 1253 1254 brcmf_dbg(USB, "Enter\n"); 1255 bus_pub = brcmf_usb_attach(devinfo, BRCMF_USB_NRXQ, BRCMF_USB_NTXQ); 1256 if (!bus_pub) 1257 return -ENODEV; 1258 1259 bus = kzalloc(sizeof(*bus), GFP_ATOMIC); 1260 if (!bus) { 1261 ret = -ENOMEM; 1262 goto fail; 1263 } 1264 1265 bus->dev = dev; 1266 bus_pub->bus = bus; 1267 bus->bus_priv.usb = bus_pub; 1268 dev_set_drvdata(dev, bus); 1269 bus->ops = &brcmf_usb_bus_ops; 1270 bus->proto_type = BRCMF_PROTO_BCDC; 1271 bus->fwvid = fwvid; 1272 bus->always_use_fws_queue = true; 1273 #ifdef CONFIG_PM 1274 bus->wowl_supported = true; 1275 #endif 1276 1277 devinfo->settings = brcmf_get_module_param(bus->dev, BRCMF_BUSTYPE_USB, 1278 bus_pub->devid, 1279 bus_pub->chiprev); 1280 if (!devinfo->settings) { 1281 ret = -ENOMEM; 1282 goto fail; 1283 } 1284 ret = PTR_ERR_OR_ZERO(devinfo->settings); 1285 if (ret < 0) 1286 goto fail; 1287 1288 if (!brcmf_usb_dlneeded(devinfo)) { 1289 ret = brcmf_alloc(devinfo->dev, devinfo->settings); 1290 if (ret) 1291 goto fail; 1292 ret = brcmf_attach(devinfo->dev); 1293 if (ret) 1294 goto fail; 1295 /* we are done */ 1296 complete(&devinfo->dev_init_done); 1297 return 0; 1298 } 1299 bus->chip = bus_pub->devid; 1300 bus->chiprev = bus_pub->chiprev; 1301 1302 fwreq = brcmf_usb_prepare_fw_request(devinfo); 1303 if (!fwreq) { 1304 ret = -ENOMEM; 1305 goto fail; 1306 } 1307 1308 /* request firmware here */ 1309 ret = brcmf_fw_get_firmwares(dev, fwreq, brcmf_usb_probe_phase2); 1310 if (ret) { 1311 brcmf_err("firmware request failed: %d\n", ret); 1312 kfree(fwreq); 1313 goto fail; 1314 } 1315 1316 return 0; 1317 1318 fail: 1319 /* Release resources in reverse order */ 1320 brcmf_free(devinfo->dev); 1321 kfree(bus); 1322 brcmf_usb_detach(devinfo); 1323 return ret; 1324 } 1325 1326 static void 1327 brcmf_usb_disconnect_cb(struct brcmf_usbdev_info *devinfo) 1328 { 1329 if (!devinfo) 1330 return; 1331 brcmf_dbg(USB, "Enter, bus_pub %p\n", devinfo); 1332 1333 brcmf_detach(devinfo->dev); 1334 brcmf_free(devinfo->dev); 1335 kfree(devinfo->bus_pub.bus); 1336 brcmf_usb_detach(devinfo); 1337 } 1338 1339 /* Forward declaration for usb_match_id() call */ 1340 static const struct usb_device_id brcmf_usb_devid_table[]; 1341 1342 static int 1343 brcmf_usb_probe(struct usb_interface *intf, const struct usb_device_id *id) 1344 { 1345 struct usb_device *usb = interface_to_usbdev(intf); 1346 struct brcmf_usbdev_info *devinfo; 1347 struct usb_interface_descriptor *desc; 1348 struct usb_endpoint_descriptor *endpoint; 1349 int ret = 0; 1350 u32 num_of_eps; 1351 u8 endpoint_num, ep; 1352 1353 if (!id) { 1354 id = usb_match_id(intf, brcmf_usb_devid_table); 1355 if (!id) { 1356 dev_err(&intf->dev, "Error could not find matching usb_device_id\n"); 1357 return -ENODEV; 1358 } 1359 } 1360 1361 brcmf_dbg(USB, "Enter 0x%04x:0x%04x\n", id->idVendor, id->idProduct); 1362 1363 devinfo = kzalloc(sizeof(*devinfo), GFP_ATOMIC); 1364 if (devinfo == NULL) 1365 return -ENOMEM; 1366 1367 devinfo->usbdev = usb; 1368 devinfo->dev = &usb->dev; 1369 /* Init completion, to protect for disconnect while still loading. 1370 * Necessary because of the asynchronous firmware load construction 1371 */ 1372 init_completion(&devinfo->dev_init_done); 1373 1374 usb_set_intfdata(intf, devinfo); 1375 1376 intf->needs_remote_wakeup = 1; 1377 1378 /* Check that the device supports only one configuration */ 1379 if (usb->descriptor.bNumConfigurations != 1) { 1380 brcmf_err("Number of configurations: %d not supported\n", 1381 usb->descriptor.bNumConfigurations); 1382 ret = -ENODEV; 1383 goto fail; 1384 } 1385 1386 if ((usb->descriptor.bDeviceClass != USB_CLASS_VENDOR_SPEC) && 1387 (usb->descriptor.bDeviceClass != USB_CLASS_MISC) && 1388 (usb->descriptor.bDeviceClass != USB_CLASS_WIRELESS_CONTROLLER)) { 1389 brcmf_err("Device class: 0x%x not supported\n", 1390 usb->descriptor.bDeviceClass); 1391 ret = -ENODEV; 1392 goto fail; 1393 } 1394 1395 desc = &intf->cur_altsetting->desc; 1396 if ((desc->bInterfaceClass != USB_CLASS_VENDOR_SPEC) || 1397 (desc->bInterfaceSubClass != 2) || 1398 (desc->bInterfaceProtocol != 0xff)) { 1399 brcmf_err("non WLAN interface %d: 0x%x:0x%x:0x%x\n", 1400 desc->bInterfaceNumber, desc->bInterfaceClass, 1401 desc->bInterfaceSubClass, desc->bInterfaceProtocol); 1402 ret = -ENODEV; 1403 goto fail; 1404 } 1405 1406 num_of_eps = desc->bNumEndpoints; 1407 for (ep = 0; ep < num_of_eps; ep++) { 1408 endpoint = &intf->cur_altsetting->endpoint[ep].desc; 1409 endpoint_num = usb_endpoint_num(endpoint); 1410 if (!usb_endpoint_xfer_bulk(endpoint)) 1411 continue; 1412 if (usb_endpoint_dir_in(endpoint)) { 1413 if (!devinfo->rx_pipe) 1414 devinfo->rx_pipe = 1415 usb_rcvbulkpipe(usb, endpoint_num); 1416 } else { 1417 if (!devinfo->tx_pipe) 1418 devinfo->tx_pipe = 1419 usb_sndbulkpipe(usb, endpoint_num); 1420 } 1421 } 1422 if (devinfo->rx_pipe == 0) { 1423 brcmf_err("No RX (in) Bulk EP found\n"); 1424 ret = -ENODEV; 1425 goto fail; 1426 } 1427 if (devinfo->tx_pipe == 0) { 1428 brcmf_err("No TX (out) Bulk EP found\n"); 1429 ret = -ENODEV; 1430 goto fail; 1431 } 1432 1433 devinfo->ifnum = desc->bInterfaceNumber; 1434 1435 if (usb->speed == USB_SPEED_SUPER_PLUS) 1436 brcmf_dbg(USB, "Broadcom super speed plus USB WLAN interface detected\n"); 1437 else if (usb->speed == USB_SPEED_SUPER) 1438 brcmf_dbg(USB, "Broadcom super speed USB WLAN interface detected\n"); 1439 else if (usb->speed == USB_SPEED_HIGH) 1440 brcmf_dbg(USB, "Broadcom high speed USB WLAN interface detected\n"); 1441 else 1442 brcmf_dbg(USB, "Broadcom full speed USB WLAN interface detected\n"); 1443 1444 ret = brcmf_usb_probe_cb(devinfo, id->driver_info); 1445 if (ret) 1446 goto fail; 1447 1448 /* Success */ 1449 return 0; 1450 1451 fail: 1452 complete(&devinfo->dev_init_done); 1453 kfree(devinfo); 1454 usb_set_intfdata(intf, NULL); 1455 return ret; 1456 } 1457 1458 static void 1459 brcmf_usb_disconnect(struct usb_interface *intf) 1460 { 1461 struct brcmf_usbdev_info *devinfo; 1462 1463 brcmf_dbg(USB, "Enter\n"); 1464 devinfo = (struct brcmf_usbdev_info *)usb_get_intfdata(intf); 1465 1466 if (devinfo) { 1467 wait_for_completion(&devinfo->dev_init_done); 1468 /* Make sure that devinfo still exists. Firmware probe routines 1469 * may have released the device and cleared the intfdata. 1470 */ 1471 if (!usb_get_intfdata(intf)) 1472 goto done; 1473 1474 brcmf_usb_disconnect_cb(devinfo); 1475 kfree(devinfo); 1476 } 1477 done: 1478 brcmf_dbg(USB, "Exit\n"); 1479 } 1480 1481 /* 1482 * only need to signal the bus being down and update the state. 1483 */ 1484 static int brcmf_usb_suspend(struct usb_interface *intf, pm_message_t state) 1485 { 1486 struct usb_device *usb = interface_to_usbdev(intf); 1487 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(&usb->dev); 1488 1489 brcmf_dbg(USB, "Enter\n"); 1490 devinfo->bus_pub.state = BRCMFMAC_USB_STATE_SLEEP; 1491 brcmf_cancel_all_urbs(devinfo); 1492 device_set_wakeup_enable(devinfo->dev, true); 1493 return 0; 1494 } 1495 1496 /* 1497 * (re-) start the bus. 1498 */ 1499 static int brcmf_usb_resume(struct usb_interface *intf) 1500 { 1501 struct usb_device *usb = interface_to_usbdev(intf); 1502 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(&usb->dev); 1503 1504 brcmf_dbg(USB, "Enter\n"); 1505 1506 devinfo->bus_pub.state = BRCMFMAC_USB_STATE_UP; 1507 brcmf_usb_rx_fill_all(devinfo); 1508 device_set_wakeup_enable(devinfo->dev, false); 1509 return 0; 1510 } 1511 1512 static int brcmf_usb_reset_resume(struct usb_interface *intf) 1513 { 1514 struct usb_device *usb = interface_to_usbdev(intf); 1515 struct brcmf_usbdev_info *devinfo = brcmf_usb_get_businfo(&usb->dev); 1516 struct brcmf_fw_request *fwreq; 1517 int ret; 1518 1519 brcmf_dbg(USB, "Enter\n"); 1520 1521 fwreq = brcmf_usb_prepare_fw_request(devinfo); 1522 if (!fwreq) 1523 return -ENOMEM; 1524 1525 ret = brcmf_fw_get_firmwares(&usb->dev, fwreq, brcmf_usb_probe_phase2); 1526 if (ret < 0) 1527 kfree(fwreq); 1528 1529 return ret; 1530 } 1531 1532 #define BRCMF_USB_DEVICE(dev_id) \ 1533 { \ 1534 USB_DEVICE(BRCM_USB_VENDOR_ID_BROADCOM, dev_id), \ 1535 .driver_info = BRCMF_FWVENDOR_WCC \ 1536 } 1537 1538 #define LINKSYS_USB_DEVICE(dev_id) \ 1539 { \ 1540 USB_DEVICE(BRCM_USB_VENDOR_ID_LINKSYS, dev_id), \ 1541 .driver_info = BRCMF_FWVENDOR_WCC \ 1542 } 1543 1544 #define CYPRESS_USB_DEVICE(dev_id) \ 1545 { \ 1546 USB_DEVICE(CY_USB_VENDOR_ID_CYPRESS, dev_id), \ 1547 .driver_info = BRCMF_FWVENDOR_WCC \ 1548 } 1549 1550 static const struct usb_device_id brcmf_usb_devid_table[] = { 1551 BRCMF_USB_DEVICE(BRCM_USB_43143_DEVICE_ID), 1552 BRCMF_USB_DEVICE(BRCM_USB_43236_DEVICE_ID), 1553 BRCMF_USB_DEVICE(BRCM_USB_43242_DEVICE_ID), 1554 BRCMF_USB_DEVICE(BRCM_USB_43569_DEVICE_ID), 1555 LINKSYS_USB_DEVICE(BRCM_USB_43235_LINKSYS_DEVICE_ID), 1556 CYPRESS_USB_DEVICE(CY_USB_4373_DEVICE_ID), 1557 { USB_DEVICE(BRCM_USB_VENDOR_ID_LG, BRCM_USB_43242_LG_DEVICE_ID) }, 1558 /* special entry for device with firmware loaded and running */ 1559 BRCMF_USB_DEVICE(BRCM_USB_BCMFW_DEVICE_ID), 1560 CYPRESS_USB_DEVICE(BRCM_USB_BCMFW_DEVICE_ID), 1561 { /* end: all zeroes */ } 1562 }; 1563 1564 MODULE_DEVICE_TABLE(usb, brcmf_usb_devid_table); 1565 1566 static struct usb_driver brcmf_usbdrvr = { 1567 .name = KBUILD_MODNAME, 1568 .probe = brcmf_usb_probe, 1569 .disconnect = brcmf_usb_disconnect, 1570 .id_table = brcmf_usb_devid_table, 1571 .suspend = brcmf_usb_suspend, 1572 .resume = brcmf_usb_resume, 1573 .reset_resume = brcmf_usb_reset_resume, 1574 .supports_autosuspend = true, 1575 .disable_hub_initiated_lpm = 1, 1576 }; 1577 1578 static int brcmf_usb_reset_device(struct device *dev, void *notused) 1579 { 1580 /* device past is the usb interface so we 1581 * need to use parent here. 1582 */ 1583 brcmf_dev_reset(dev->parent); 1584 return 0; 1585 } 1586 1587 void brcmf_usb_exit(void) 1588 { 1589 struct device_driver *drv = &brcmf_usbdrvr.driver; 1590 int ret; 1591 1592 brcmf_dbg(USB, "Enter\n"); 1593 ret = driver_for_each_device(drv, NULL, NULL, 1594 brcmf_usb_reset_device); 1595 if (ret) 1596 brcmf_err("failed to reset all usb devices %d\n", ret); 1597 1598 usb_deregister(&brcmf_usbdrvr); 1599 } 1600 1601 int brcmf_usb_register(void) 1602 { 1603 brcmf_dbg(USB, "Enter\n"); 1604 return usb_register(&brcmf_usbdrvr); 1605 } 1606