1 /* 2 * 3 * Driver for the 3Com Bluetooth PCMCIA card 4 * 5 * Copyright (C) 2001-2002 Marcel Holtmann <marcel@holtmann.org> 6 * Jose Orlando Pereira <jop@di.uminho.pt> 7 * 8 * 9 * This program is free software; you can redistribute it and/or modify 10 * it under the terms of the GNU General Public License version 2 as 11 * published by the Free Software Foundation; 12 * 13 * Software distributed under the License is distributed on an "AS 14 * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or 15 * implied. See the License for the specific language governing 16 * rights and limitations under the License. 17 * 18 * The initial developer of the original code is David A. Hinds 19 * <dahinds@users.sourceforge.net>. Portions created by David A. Hinds 20 * are Copyright (C) 1999 David A. Hinds. All Rights Reserved. 21 * 22 */ 23 24 #include <linux/module.h> 25 26 #include <linux/kernel.h> 27 #include <linux/init.h> 28 #include <linux/slab.h> 29 #include <linux/types.h> 30 #include <linux/delay.h> 31 #include <linux/errno.h> 32 #include <linux/ptrace.h> 33 #include <linux/ioport.h> 34 #include <linux/spinlock.h> 35 #include <linux/moduleparam.h> 36 37 #include <linux/skbuff.h> 38 #include <linux/string.h> 39 #include <linux/serial.h> 40 #include <linux/serial_reg.h> 41 #include <linux/bitops.h> 42 #include <asm/io.h> 43 44 #include <linux/device.h> 45 #include <linux/firmware.h> 46 47 #include <pcmcia/cistpl.h> 48 #include <pcmcia/ciscode.h> 49 #include <pcmcia/ds.h> 50 #include <pcmcia/cisreg.h> 51 52 #include <net/bluetooth/bluetooth.h> 53 #include <net/bluetooth/hci_core.h> 54 55 56 57 /* ======================== Module parameters ======================== */ 58 59 60 MODULE_AUTHOR("Marcel Holtmann <marcel@holtmann.org>"); 61 MODULE_DESCRIPTION("Bluetooth driver for the 3Com Bluetooth PCMCIA card"); 62 MODULE_LICENSE("GPL"); 63 MODULE_FIRMWARE("BT3CPCC.bin"); 64 65 66 67 /* ======================== Local structures ======================== */ 68 69 70 struct bt3c_info { 71 struct pcmcia_device *p_dev; 72 73 struct hci_dev *hdev; 74 75 spinlock_t lock; /* For serializing operations */ 76 77 struct sk_buff_head txq; 78 unsigned long tx_state; 79 80 unsigned long rx_state; 81 unsigned long rx_count; 82 struct sk_buff *rx_skb; 83 }; 84 85 86 static int bt3c_config(struct pcmcia_device *link); 87 static void bt3c_release(struct pcmcia_device *link); 88 89 static void bt3c_detach(struct pcmcia_device *p_dev); 90 91 92 /* Transmit states */ 93 #define XMIT_SENDING 1 94 #define XMIT_WAKEUP 2 95 #define XMIT_WAITING 8 96 97 /* Receiver states */ 98 #define RECV_WAIT_PACKET_TYPE 0 99 #define RECV_WAIT_EVENT_HEADER 1 100 #define RECV_WAIT_ACL_HEADER 2 101 #define RECV_WAIT_SCO_HEADER 3 102 #define RECV_WAIT_DATA 4 103 104 105 106 /* ======================== Special I/O functions ======================== */ 107 108 109 #define DATA_L 0 110 #define DATA_H 1 111 #define ADDR_L 2 112 #define ADDR_H 3 113 #define CONTROL 4 114 115 116 static inline void bt3c_address(unsigned int iobase, unsigned short addr) 117 { 118 outb(addr & 0xff, iobase + ADDR_L); 119 outb((addr >> 8) & 0xff, iobase + ADDR_H); 120 } 121 122 123 static inline void bt3c_put(unsigned int iobase, unsigned short value) 124 { 125 outb(value & 0xff, iobase + DATA_L); 126 outb((value >> 8) & 0xff, iobase + DATA_H); 127 } 128 129 130 static inline void bt3c_io_write(unsigned int iobase, unsigned short addr, unsigned short value) 131 { 132 bt3c_address(iobase, addr); 133 bt3c_put(iobase, value); 134 } 135 136 137 static inline unsigned short bt3c_get(unsigned int iobase) 138 { 139 unsigned short value = inb(iobase + DATA_L); 140 141 value |= inb(iobase + DATA_H) << 8; 142 143 return value; 144 } 145 146 147 static inline unsigned short bt3c_read(unsigned int iobase, unsigned short addr) 148 { 149 bt3c_address(iobase, addr); 150 151 return bt3c_get(iobase); 152 } 153 154 155 156 /* ======================== Interrupt handling ======================== */ 157 158 159 static int bt3c_write(unsigned int iobase, int fifo_size, __u8 *buf, int len) 160 { 161 int actual = 0; 162 163 bt3c_address(iobase, 0x7080); 164 165 /* Fill FIFO with current frame */ 166 while (actual < len) { 167 /* Transmit next byte */ 168 bt3c_put(iobase, buf[actual]); 169 actual++; 170 } 171 172 bt3c_io_write(iobase, 0x7005, actual); 173 174 return actual; 175 } 176 177 178 static void bt3c_write_wakeup(struct bt3c_info *info) 179 { 180 if (!info) { 181 BT_ERR("Unknown device"); 182 return; 183 } 184 185 if (test_and_set_bit(XMIT_SENDING, &(info->tx_state))) 186 return; 187 188 do { 189 unsigned int iobase = info->p_dev->resource[0]->start; 190 register struct sk_buff *skb; 191 int len; 192 193 if (!pcmcia_dev_present(info->p_dev)) 194 break; 195 196 skb = skb_dequeue(&(info->txq)); 197 if (!skb) { 198 clear_bit(XMIT_SENDING, &(info->tx_state)); 199 break; 200 } 201 202 /* Send frame */ 203 len = bt3c_write(iobase, 256, skb->data, skb->len); 204 205 if (len != skb->len) { 206 BT_ERR("Very strange"); 207 } 208 209 kfree_skb(skb); 210 211 info->hdev->stat.byte_tx += len; 212 213 } while (0); 214 } 215 216 217 static void bt3c_receive(struct bt3c_info *info) 218 { 219 unsigned int iobase; 220 int size = 0, avail; 221 222 if (!info) { 223 BT_ERR("Unknown device"); 224 return; 225 } 226 227 iobase = info->p_dev->resource[0]->start; 228 229 avail = bt3c_read(iobase, 0x7006); 230 231 bt3c_address(iobase, 0x7480); 232 while (size < avail) { 233 size++; 234 info->hdev->stat.byte_rx++; 235 236 /* Allocate packet */ 237 if (info->rx_skb == NULL) { 238 info->rx_state = RECV_WAIT_PACKET_TYPE; 239 info->rx_count = 0; 240 info->rx_skb = bt_skb_alloc(HCI_MAX_FRAME_SIZE, GFP_ATOMIC); 241 if (!info->rx_skb) { 242 BT_ERR("Can't allocate mem for new packet"); 243 return; 244 } 245 } 246 247 248 if (info->rx_state == RECV_WAIT_PACKET_TYPE) { 249 250 bt_cb(info->rx_skb)->pkt_type = inb(iobase + DATA_L); 251 inb(iobase + DATA_H); 252 253 switch (bt_cb(info->rx_skb)->pkt_type) { 254 255 case HCI_EVENT_PKT: 256 info->rx_state = RECV_WAIT_EVENT_HEADER; 257 info->rx_count = HCI_EVENT_HDR_SIZE; 258 break; 259 260 case HCI_ACLDATA_PKT: 261 info->rx_state = RECV_WAIT_ACL_HEADER; 262 info->rx_count = HCI_ACL_HDR_SIZE; 263 break; 264 265 case HCI_SCODATA_PKT: 266 info->rx_state = RECV_WAIT_SCO_HEADER; 267 info->rx_count = HCI_SCO_HDR_SIZE; 268 break; 269 270 default: 271 /* Unknown packet */ 272 BT_ERR("Unknown HCI packet with type 0x%02x received", bt_cb(info->rx_skb)->pkt_type); 273 info->hdev->stat.err_rx++; 274 clear_bit(HCI_RUNNING, &(info->hdev->flags)); 275 276 kfree_skb(info->rx_skb); 277 info->rx_skb = NULL; 278 break; 279 280 } 281 282 } else { 283 284 __u8 x = inb(iobase + DATA_L); 285 286 *skb_put(info->rx_skb, 1) = x; 287 inb(iobase + DATA_H); 288 info->rx_count--; 289 290 if (info->rx_count == 0) { 291 292 int dlen; 293 struct hci_event_hdr *eh; 294 struct hci_acl_hdr *ah; 295 struct hci_sco_hdr *sh; 296 297 switch (info->rx_state) { 298 299 case RECV_WAIT_EVENT_HEADER: 300 eh = hci_event_hdr(info->rx_skb); 301 info->rx_state = RECV_WAIT_DATA; 302 info->rx_count = eh->plen; 303 break; 304 305 case RECV_WAIT_ACL_HEADER: 306 ah = hci_acl_hdr(info->rx_skb); 307 dlen = __le16_to_cpu(ah->dlen); 308 info->rx_state = RECV_WAIT_DATA; 309 info->rx_count = dlen; 310 break; 311 312 case RECV_WAIT_SCO_HEADER: 313 sh = hci_sco_hdr(info->rx_skb); 314 info->rx_state = RECV_WAIT_DATA; 315 info->rx_count = sh->dlen; 316 break; 317 318 case RECV_WAIT_DATA: 319 hci_recv_frame(info->hdev, info->rx_skb); 320 info->rx_skb = NULL; 321 break; 322 323 } 324 325 } 326 327 } 328 329 } 330 331 bt3c_io_write(iobase, 0x7006, 0x0000); 332 } 333 334 335 static irqreturn_t bt3c_interrupt(int irq, void *dev_inst) 336 { 337 struct bt3c_info *info = dev_inst; 338 unsigned int iobase; 339 int iir; 340 irqreturn_t r = IRQ_NONE; 341 342 if (!info || !info->hdev) 343 /* our irq handler is shared */ 344 return IRQ_NONE; 345 346 iobase = info->p_dev->resource[0]->start; 347 348 spin_lock(&(info->lock)); 349 350 iir = inb(iobase + CONTROL); 351 if (iir & 0x80) { 352 int stat = bt3c_read(iobase, 0x7001); 353 354 if ((stat & 0xff) == 0x7f) { 355 BT_ERR("Very strange (stat=0x%04x)", stat); 356 } else if ((stat & 0xff) != 0xff) { 357 if (stat & 0x0020) { 358 int status = bt3c_read(iobase, 0x7002) & 0x10; 359 BT_INFO("%s: Antenna %s", info->hdev->name, 360 status ? "out" : "in"); 361 } 362 if (stat & 0x0001) 363 bt3c_receive(info); 364 if (stat & 0x0002) { 365 clear_bit(XMIT_SENDING, &(info->tx_state)); 366 bt3c_write_wakeup(info); 367 } 368 369 bt3c_io_write(iobase, 0x7001, 0x0000); 370 371 outb(iir, iobase + CONTROL); 372 } 373 r = IRQ_HANDLED; 374 } 375 376 spin_unlock(&(info->lock)); 377 378 return r; 379 } 380 381 382 383 /* ======================== HCI interface ======================== */ 384 385 386 static int bt3c_hci_flush(struct hci_dev *hdev) 387 { 388 struct bt3c_info *info = hci_get_drvdata(hdev); 389 390 /* Drop TX queue */ 391 skb_queue_purge(&(info->txq)); 392 393 return 0; 394 } 395 396 397 static int bt3c_hci_open(struct hci_dev *hdev) 398 { 399 set_bit(HCI_RUNNING, &(hdev->flags)); 400 401 return 0; 402 } 403 404 405 static int bt3c_hci_close(struct hci_dev *hdev) 406 { 407 if (!test_and_clear_bit(HCI_RUNNING, &(hdev->flags))) 408 return 0; 409 410 bt3c_hci_flush(hdev); 411 412 return 0; 413 } 414 415 416 static int bt3c_hci_send_frame(struct hci_dev *hdev, struct sk_buff *skb) 417 { 418 struct bt3c_info *info = hci_get_drvdata(hdev); 419 unsigned long flags; 420 421 switch (bt_cb(skb)->pkt_type) { 422 case HCI_COMMAND_PKT: 423 hdev->stat.cmd_tx++; 424 break; 425 case HCI_ACLDATA_PKT: 426 hdev->stat.acl_tx++; 427 break; 428 case HCI_SCODATA_PKT: 429 hdev->stat.sco_tx++; 430 break; 431 }; 432 433 /* Prepend skb with frame type */ 434 memcpy(skb_push(skb, 1), &bt_cb(skb)->pkt_type, 1); 435 skb_queue_tail(&(info->txq), skb); 436 437 spin_lock_irqsave(&(info->lock), flags); 438 439 bt3c_write_wakeup(info); 440 441 spin_unlock_irqrestore(&(info->lock), flags); 442 443 return 0; 444 } 445 446 447 448 /* ======================== Card services HCI interaction ======================== */ 449 450 451 static int bt3c_load_firmware(struct bt3c_info *info, 452 const unsigned char *firmware, 453 int count) 454 { 455 char *ptr = (char *) firmware; 456 char b[9]; 457 unsigned int iobase, size, addr, fcs, tmp; 458 int i, err = 0; 459 460 iobase = info->p_dev->resource[0]->start; 461 462 /* Reset */ 463 bt3c_io_write(iobase, 0x8040, 0x0404); 464 bt3c_io_write(iobase, 0x8040, 0x0400); 465 466 udelay(1); 467 468 bt3c_io_write(iobase, 0x8040, 0x0404); 469 470 udelay(17); 471 472 /* Load */ 473 while (count) { 474 if (ptr[0] != 'S') { 475 BT_ERR("Bad address in firmware"); 476 err = -EFAULT; 477 goto error; 478 } 479 480 memset(b, 0, sizeof(b)); 481 memcpy(b, ptr + 2, 2); 482 size = simple_strtoul(b, NULL, 16); 483 484 memset(b, 0, sizeof(b)); 485 memcpy(b, ptr + 4, 8); 486 addr = simple_strtoul(b, NULL, 16); 487 488 memset(b, 0, sizeof(b)); 489 memcpy(b, ptr + (size * 2) + 2, 2); 490 fcs = simple_strtoul(b, NULL, 16); 491 492 memset(b, 0, sizeof(b)); 493 for (tmp = 0, i = 0; i < size; i++) { 494 memcpy(b, ptr + (i * 2) + 2, 2); 495 tmp += simple_strtol(b, NULL, 16); 496 } 497 498 if (((tmp + fcs) & 0xff) != 0xff) { 499 BT_ERR("Checksum error in firmware"); 500 err = -EILSEQ; 501 goto error; 502 } 503 504 if (ptr[1] == '3') { 505 bt3c_address(iobase, addr); 506 507 memset(b, 0, sizeof(b)); 508 for (i = 0; i < (size - 4) / 2; i++) { 509 memcpy(b, ptr + (i * 4) + 12, 4); 510 tmp = simple_strtoul(b, NULL, 16); 511 bt3c_put(iobase, tmp); 512 } 513 } 514 515 ptr += (size * 2) + 6; 516 count -= (size * 2) + 6; 517 } 518 519 udelay(17); 520 521 /* Boot */ 522 bt3c_address(iobase, 0x3000); 523 outb(inb(iobase + CONTROL) | 0x40, iobase + CONTROL); 524 525 error: 526 udelay(17); 527 528 /* Clear */ 529 bt3c_io_write(iobase, 0x7006, 0x0000); 530 bt3c_io_write(iobase, 0x7005, 0x0000); 531 bt3c_io_write(iobase, 0x7001, 0x0000); 532 533 return err; 534 } 535 536 537 static int bt3c_open(struct bt3c_info *info) 538 { 539 const struct firmware *firmware; 540 struct hci_dev *hdev; 541 int err; 542 543 spin_lock_init(&(info->lock)); 544 545 skb_queue_head_init(&(info->txq)); 546 547 info->rx_state = RECV_WAIT_PACKET_TYPE; 548 info->rx_count = 0; 549 info->rx_skb = NULL; 550 551 /* Initialize HCI device */ 552 hdev = hci_alloc_dev(); 553 if (!hdev) { 554 BT_ERR("Can't allocate HCI device"); 555 return -ENOMEM; 556 } 557 558 info->hdev = hdev; 559 560 hdev->bus = HCI_PCCARD; 561 hci_set_drvdata(hdev, info); 562 SET_HCIDEV_DEV(hdev, &info->p_dev->dev); 563 564 hdev->open = bt3c_hci_open; 565 hdev->close = bt3c_hci_close; 566 hdev->flush = bt3c_hci_flush; 567 hdev->send = bt3c_hci_send_frame; 568 569 /* Load firmware */ 570 err = request_firmware(&firmware, "BT3CPCC.bin", &info->p_dev->dev); 571 if (err < 0) { 572 BT_ERR("Firmware request failed"); 573 goto error; 574 } 575 576 err = bt3c_load_firmware(info, firmware->data, firmware->size); 577 578 release_firmware(firmware); 579 580 if (err < 0) { 581 BT_ERR("Firmware loading failed"); 582 goto error; 583 } 584 585 /* Timeout before it is safe to send the first HCI packet */ 586 msleep(1000); 587 588 /* Register HCI device */ 589 err = hci_register_dev(hdev); 590 if (err < 0) { 591 BT_ERR("Can't register HCI device"); 592 goto error; 593 } 594 595 return 0; 596 597 error: 598 info->hdev = NULL; 599 hci_free_dev(hdev); 600 return err; 601 } 602 603 604 static int bt3c_close(struct bt3c_info *info) 605 { 606 struct hci_dev *hdev = info->hdev; 607 608 if (!hdev) 609 return -ENODEV; 610 611 bt3c_hci_close(hdev); 612 613 hci_unregister_dev(hdev); 614 hci_free_dev(hdev); 615 616 return 0; 617 } 618 619 static int bt3c_probe(struct pcmcia_device *link) 620 { 621 struct bt3c_info *info; 622 623 /* Create new info device */ 624 info = devm_kzalloc(&link->dev, sizeof(*info), GFP_KERNEL); 625 if (!info) 626 return -ENOMEM; 627 628 info->p_dev = link; 629 link->priv = info; 630 631 link->config_flags |= CONF_ENABLE_IRQ | CONF_AUTO_SET_VPP | 632 CONF_AUTO_SET_IO; 633 634 return bt3c_config(link); 635 } 636 637 638 static void bt3c_detach(struct pcmcia_device *link) 639 { 640 bt3c_release(link); 641 } 642 643 static int bt3c_check_config(struct pcmcia_device *p_dev, void *priv_data) 644 { 645 int *try = priv_data; 646 647 if (!try) 648 p_dev->io_lines = 16; 649 650 if ((p_dev->resource[0]->end != 8) || (p_dev->resource[0]->start == 0)) 651 return -EINVAL; 652 653 p_dev->resource[0]->end = 8; 654 p_dev->resource[0]->flags &= ~IO_DATA_PATH_WIDTH; 655 p_dev->resource[0]->flags |= IO_DATA_PATH_WIDTH_8; 656 657 return pcmcia_request_io(p_dev); 658 } 659 660 static int bt3c_check_config_notpicky(struct pcmcia_device *p_dev, 661 void *priv_data) 662 { 663 static unsigned int base[5] = { 0x3f8, 0x2f8, 0x3e8, 0x2e8, 0x0 }; 664 int j; 665 666 if (p_dev->io_lines > 3) 667 return -ENODEV; 668 669 p_dev->resource[0]->flags &= ~IO_DATA_PATH_WIDTH; 670 p_dev->resource[0]->flags |= IO_DATA_PATH_WIDTH_8; 671 p_dev->resource[0]->end = 8; 672 673 for (j = 0; j < 5; j++) { 674 p_dev->resource[0]->start = base[j]; 675 p_dev->io_lines = base[j] ? 16 : 3; 676 if (!pcmcia_request_io(p_dev)) 677 return 0; 678 } 679 return -ENODEV; 680 } 681 682 static int bt3c_config(struct pcmcia_device *link) 683 { 684 struct bt3c_info *info = link->priv; 685 int i; 686 unsigned long try; 687 688 /* First pass: look for a config entry that looks normal. 689 Two tries: without IO aliases, then with aliases */ 690 for (try = 0; try < 2; try++) 691 if (!pcmcia_loop_config(link, bt3c_check_config, (void *) try)) 692 goto found_port; 693 694 /* Second pass: try to find an entry that isn't picky about 695 its base address, then try to grab any standard serial port 696 address, and finally try to get any free port. */ 697 if (!pcmcia_loop_config(link, bt3c_check_config_notpicky, NULL)) 698 goto found_port; 699 700 BT_ERR("No usable port range found"); 701 goto failed; 702 703 found_port: 704 i = pcmcia_request_irq(link, &bt3c_interrupt); 705 if (i != 0) 706 goto failed; 707 708 i = pcmcia_enable_device(link); 709 if (i != 0) 710 goto failed; 711 712 if (bt3c_open(info) != 0) 713 goto failed; 714 715 return 0; 716 717 failed: 718 bt3c_release(link); 719 return -ENODEV; 720 } 721 722 723 static void bt3c_release(struct pcmcia_device *link) 724 { 725 struct bt3c_info *info = link->priv; 726 727 bt3c_close(info); 728 729 pcmcia_disable_device(link); 730 } 731 732 733 static const struct pcmcia_device_id bt3c_ids[] = { 734 PCMCIA_DEVICE_PROD_ID13("3COM", "Bluetooth PC Card", 0xefce0a31, 0xd4ce9b02), 735 PCMCIA_DEVICE_NULL 736 }; 737 MODULE_DEVICE_TABLE(pcmcia, bt3c_ids); 738 739 static struct pcmcia_driver bt3c_driver = { 740 .owner = THIS_MODULE, 741 .name = "bt3c_cs", 742 .probe = bt3c_probe, 743 .remove = bt3c_detach, 744 .id_table = bt3c_ids, 745 }; 746 module_pcmcia_driver(bt3c_driver); 747