hci_bcm.c 24.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
/*
 *
 *  Bluetooth HCI UART driver for Broadcom devices
 *
 *  Copyright (C) 2015  Intel Corporation
 *
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 *
 */

#include <linux/kernel.h>
#include <linux/errno.h>
#include <linux/skbuff.h>
27
#include <linux/firmware.h>
28 29
#include <linux/module.h>
#include <linux/acpi.h>
30 31
#include <linux/of.h>
#include <linux/property.h>
32 33 34 35
#include <linux/platform_device.h>
#include <linux/clk.h>
#include <linux/gpio/consumer.h>
#include <linux/tty.h>
36
#include <linux/interrupt.h>
37
#include <linux/dmi.h>
38
#include <linux/pm_runtime.h>
39
#include <linux/serdev.h>
40 41 42 43

#include <net/bluetooth/bluetooth.h>
#include <net/bluetooth/hci_core.h>

44
#include "btbcm.h"
45
#include "hci_uart.h"
46

47 48 49
#define BCM_NULL_PKT 0x00
#define BCM_NULL_SIZE 0

50 51 52
#define BCM_LM_DIAG_PKT 0x07
#define BCM_LM_DIAG_SIZE 63

53 54
#define BCM_AUTOSUSPEND_DELAY	5000 /* default autosleep delay */

55
/* platform device driver resources */
56 57 58 59 60 61 62 63 64 65 66
struct bcm_device {
	struct list_head	list;

	struct platform_device	*pdev;

	const char		*name;
	struct gpio_desc	*device_wakeup;
	struct gpio_desc	*shutdown;

	struct clk		*clk;
	bool			clk_enabled;
67 68

	u32			init_speed;
69
	u32			oper_speed;
70 71
	int			irq;
	u8			irq_polarity;
72

73
#ifdef CONFIG_PM
74 75 76
	struct hci_uart		*hu;
	bool			is_suspended; /* suspend/resume flag */
#endif
77 78
};

79 80 81 82 83 84
/* serdev driver resources */
struct bcm_serdev {
	struct hci_uart hu;
};

/* generic bcm uart resources */
85
struct bcm_data {
86 87 88 89
	struct sk_buff		*rx_skb;
	struct sk_buff_head	txq;

	struct bcm_device	*dev;
90 91
};

92
/* List of BCM BT UART devices */
93
static DEFINE_MUTEX(bcm_device_lock);
94 95
static LIST_HEAD(bcm_device_list);

96 97 98 99 100 101 102 103
static inline void host_set_baudrate(struct hci_uart *hu, unsigned int speed)
{
	if (hu->serdev)
		serdev_device_set_baudrate(hu->serdev, speed);
	else
		hci_uart_set_baudrate(hu, speed);
}

104 105 106 107 108 109 110 111 112 113 114
static int bcm_set_baudrate(struct hci_uart *hu, unsigned int speed)
{
	struct hci_dev *hdev = hu->hdev;
	struct sk_buff *skb;
	struct bcm_update_uart_baud_rate param;

	if (speed > 3000000) {
		struct bcm_write_uart_clock_setting clock;

		clock.type = BCM_UART_CLOCK_48MHZ;

115
		bt_dev_dbg(hdev, "Set Controller clock (%d)", clock.type);
116 117 118 119 120 121 122

		/* This Broadcom specific command changes the UART's controller
		 * clock for baud rate > 3000000.
		 */
		skb = __hci_cmd_sync(hdev, 0xfc45, 1, &clock, HCI_INIT_TIMEOUT);
		if (IS_ERR(skb)) {
			int err = PTR_ERR(skb);
123 124
			bt_dev_err(hdev, "BCM: failed to write clock (%d)",
				   err);
125 126 127 128 129 130
			return err;
		}

		kfree_skb(skb);
	}

131
	bt_dev_dbg(hdev, "Set Controller UART speed to %d bit/s", speed);
132 133 134 135 136 137 138 139 140 141 142

	param.zero = cpu_to_le16(0);
	param.baud_rate = cpu_to_le32(speed);

	/* This Broadcom specific command changes the UART's controller baud
	 * rate.
	 */
	skb = __hci_cmd_sync(hdev, 0xfc18, sizeof(param), &param,
			     HCI_INIT_TIMEOUT);
	if (IS_ERR(skb)) {
		int err = PTR_ERR(skb);
143 144
		bt_dev_err(hdev, "BCM: failed to write update baudrate (%d)",
			   err);
145 146 147 148 149 150 151 152
		return err;
	}

	kfree_skb(skb);

	return 0;
}

153
/* bcm_device_exists should be protected by bcm_device_lock */
154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170
static bool bcm_device_exists(struct bcm_device *device)
{
	struct list_head *p;

	list_for_each(p, &bcm_device_list) {
		struct bcm_device *dev = list_entry(p, struct bcm_device, list);

		if (device == dev)
			return true;
	}

	return false;
}

static int bcm_gpio_set_power(struct bcm_device *dev, bool powered)
{
	if (powered && !IS_ERR(dev->clk) && !dev->clk_enabled)
171
		clk_prepare_enable(dev->clk);
172

173 174
	gpiod_set_value(dev->shutdown, powered);
	gpiod_set_value(dev->device_wakeup, powered);
175 176

	if (!powered && !IS_ERR(dev->clk) && dev->clk_enabled)
177
		clk_disable_unprepare(dev->clk);
178 179 180 181 182 183

	dev->clk_enabled = powered;

	return 0;
}

184
#ifdef CONFIG_PM
185 186 187 188 189 190
static irqreturn_t bcm_host_wake(int irq, void *data)
{
	struct bcm_device *bdev = data;

	bt_dev_dbg(bdev, "Host wake IRQ");

191 192 193 194
	pm_runtime_get(&bdev->pdev->dev);
	pm_runtime_mark_last_busy(&bdev->pdev->dev);
	pm_runtime_put_autosuspend(&bdev->pdev->dev);

195 196 197 198 199 200
	return IRQ_HANDLED;
}

static int bcm_request_irq(struct bcm_data *bcm)
{
	struct bcm_device *bdev = bcm->dev;
201
	int err;
202 203 204 205 206 207 208 209

	/* If this is not a platform device, do not enable PM functionalities */
	mutex_lock(&bcm_device_lock);
	if (!bcm_device_exists(bdev)) {
		err = -ENODEV;
		goto unlock;
	}

210 211 212 213
	if (bdev->irq <= 0) {
		err = -EOPNOTSUPP;
		goto unlock;
	}
214

215 216 217 218
	err = devm_request_irq(&bdev->pdev->dev, bdev->irq, bcm_host_wake,
			       IRQF_TRIGGER_RISING, "host_wake", bdev);
	if (err)
		goto unlock;
219

220 221 222 223 224 225 226
	device_init_wakeup(&bdev->pdev->dev, true);

	pm_runtime_set_autosuspend_delay(&bdev->pdev->dev,
					 BCM_AUTOSUSPEND_DELAY);
	pm_runtime_use_autosuspend(&bdev->pdev->dev);
	pm_runtime_set_active(&bdev->pdev->dev);
	pm_runtime_enable(&bdev->pdev->dev);
227 228 229 230 231 232 233 234 235 236 237 238 239 240

unlock:
	mutex_unlock(&bcm_device_lock);

	return err;
}

static const struct bcm_set_sleep_mode default_sleep_params = {
	.sleep_mode = 1,	/* 0=Disabled, 1=UART, 2=Reserved, 3=USB */
	.idle_host = 2,		/* idle threshold HOST, in 300ms */
	.idle_dev = 2,		/* idle threshold device, in 300ms */
	.bt_wake_active = 1,	/* BT_WAKE active mode: 1 = high, 0 = low */
	.host_wake_active = 0,	/* HOST_WAKE active mode: 1 = high, 0 = low */
	.allow_host_sleep = 1,	/* Allow host sleep in SCO flag */
241
	.combine_modes = 1,	/* Combine sleep and LPM flag */
242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275
	.tristate_control = 0,	/* Allow tri-state control of UART tx flag */
	/* Irrelevant USB flags */
	.usb_auto_sleep = 0,
	.usb_resume_timeout = 0,
	.pulsed_host_wake = 0,
	.break_to_host = 0
};

static int bcm_setup_sleep(struct hci_uart *hu)
{
	struct bcm_data *bcm = hu->priv;
	struct sk_buff *skb;
	struct bcm_set_sleep_mode sleep_params = default_sleep_params;

	sleep_params.host_wake_active = !bcm->dev->irq_polarity;

	skb = __hci_cmd_sync(hu->hdev, 0xfc27, sizeof(sleep_params),
			     &sleep_params, HCI_INIT_TIMEOUT);
	if (IS_ERR(skb)) {
		int err = PTR_ERR(skb);
		bt_dev_err(hu->hdev, "Sleep VSC failed (%d)", err);
		return err;
	}
	kfree_skb(skb);

	bt_dev_dbg(hu->hdev, "Set Sleep Parameters VSC succeeded");

	return 0;
}
#else
static inline int bcm_request_irq(struct bcm_data *bcm) { return 0; }
static inline int bcm_setup_sleep(struct hci_uart *hu) { return 0; }
#endif

276 277 278 279 280 281 282 283 284 285
static int bcm_set_diag(struct hci_dev *hdev, bool enable)
{
	struct hci_uart *hu = hci_get_drvdata(hdev);
	struct bcm_data *bcm = hu->priv;
	struct sk_buff *skb;

	if (!test_bit(HCI_RUNNING, &hdev->flags))
		return -ENETDOWN;

	skb = bt_skb_alloc(3, GFP_KERNEL);
286 287
	if (!skb)
		return -ENOMEM;
288

289 290 291
	skb_put_u8(skb, BCM_LM_DIAG_PKT);
	skb_put_u8(skb, 0xf0);
	skb_put_u8(skb, enable);
292 293 294 295 296 297 298

	skb_queue_tail(&bcm->txq, skb);
	hci_uart_tx_wakeup(hu);

	return 0;
}

299 300 301
static int bcm_open(struct hci_uart *hu)
{
	struct bcm_data *bcm;
302
	struct list_head *p;
303

304
	bt_dev_dbg(hu->hdev, "hu %p", hu);
305 306 307 308 309 310 311 312

	bcm = kzalloc(sizeof(*bcm), GFP_KERNEL);
	if (!bcm)
		return -ENOMEM;

	skb_queue_head_init(&bcm->txq);

	hu->priv = bcm;
313

314 315 316 317 318 319 320 321
	/* If this is a serdev defined device, then only use
	 * serdev open primitive and skip the rest.
	 */
	if (hu->serdev) {
		serdev_device_open(hu->serdev);
		goto out;
	}

322 323 324
	if (!hu->tty->dev)
		goto out;

325
	mutex_lock(&bcm_device_lock);
326 327 328 329 330 331 332 333 334
	list_for_each(p, &bcm_device_list) {
		struct bcm_device *dev = list_entry(p, struct bcm_device, list);

		/* Retrieve saved bcm_device based on parent of the
		 * platform device (saved during device probe) and
		 * parent of tty device used by hci_uart
		 */
		if (hu->tty->dev->parent == dev->pdev->dev.parent) {
			bcm->dev = dev;
335
			hu->init_speed = dev->init_speed;
336
			hu->oper_speed = dev->oper_speed;
337
#ifdef CONFIG_PM
338 339
			dev->hu = hu;
#endif
340
			bcm_gpio_set_power(bcm->dev, true);
341 342 343 344
			break;
		}
	}

345
	mutex_unlock(&bcm_device_lock);
346
out:
347 348 349 350 351 352
	return 0;
}

static int bcm_close(struct hci_uart *hu)
{
	struct bcm_data *bcm = hu->priv;
353
	struct bcm_device *bdev = bcm->dev;
354

355
	bt_dev_dbg(hu->hdev, "hu %p", hu);
356

357 358 359 360 361 362
	/* If this is a serdev defined device, only use serdev
	 * close primitive and then continue as usual.
	 */
	if (hu->serdev)
		serdev_device_close(hu->serdev);

363
	/* Protect bcm->dev against removal of the device or driver */
364
	mutex_lock(&bcm_device_lock);
365 366
	if (bcm_device_exists(bdev)) {
		bcm_gpio_set_power(bdev, false);
367
#ifdef CONFIG_PM
368 369 370
		pm_runtime_disable(&bdev->pdev->dev);
		pm_runtime_set_suspended(&bdev->pdev->dev);

371 372 373 374 375 376
		if (device_can_wakeup(&bdev->pdev->dev)) {
			devm_free_irq(&bdev->pdev->dev, bdev->irq, bdev);
			device_init_wakeup(&bdev->pdev->dev, false);
		}

		bdev->hu = NULL;
377 378
#endif
	}
379
	mutex_unlock(&bcm_device_lock);
380

381 382 383 384 385 386 387 388 389 390 391 392
	skb_queue_purge(&bcm->txq);
	kfree_skb(bcm->rx_skb);
	kfree(bcm);

	hu->priv = NULL;
	return 0;
}

static int bcm_flush(struct hci_uart *hu)
{
	struct bcm_data *bcm = hu->priv;

393
	bt_dev_dbg(hu->hdev, "hu %p", hu);
394 395 396 397 398 399 400 401

	skb_queue_purge(&bcm->txq);

	return 0;
}

static int bcm_setup(struct hci_uart *hu)
{
402
	struct bcm_data *bcm = hu->priv;
403 404
	char fw_name[64];
	const struct firmware *fw;
405
	unsigned int speed;
406 407
	int err;

408
	bt_dev_dbg(hu->hdev, "hu %p", hu);
409

410
	hu->hdev->set_diag = bcm_set_diag;
411 412
	hu->hdev->set_bdaddr = btbcm_set_bdaddr;

413 414 415 416 417 418
	err = btbcm_initialize(hu->hdev, fw_name, sizeof(fw_name));
	if (err)
		return err;

	err = request_firmware(&fw, fw_name, &hu->hdev->dev);
	if (err < 0) {
419
		bt_dev_info(hu->hdev, "BCM: Patch %s not found", fw_name);
420 421 422 423 424
		return 0;
	}

	err = btbcm_patchram(hu->hdev, fw);
	if (err) {
425
		bt_dev_info(hu->hdev, "BCM: Patch failed (%d)", err);
426 427 428
		goto finalize;
	}

429 430 431 432 433 434 435 436 437
	/* Init speed if any */
	if (hu->init_speed)
		speed = hu->init_speed;
	else if (hu->proto->init_speed)
		speed = hu->proto->init_speed;
	else
		speed = 0;

	if (speed)
438
		host_set_baudrate(hu, speed);
439 440 441 442 443 444 445 446 447 448 449

	/* Operational speed if any */
	if (hu->oper_speed)
		speed = hu->oper_speed;
	else if (hu->proto->oper_speed)
		speed = hu->proto->oper_speed;
	else
		speed = 0;

	if (speed) {
		err = bcm_set_baudrate(hu, speed);
450
		if (!err)
451
			host_set_baudrate(hu, speed);
452 453
	}

454 455 456 457
finalize:
	release_firmware(fw);

	err = btbcm_finalize(hu->hdev);
458 459 460
	if (err)
		return err;

461
	if (!bcm_request_irq(bcm))
462
		err = bcm_setup_sleep(hu);
463 464

	return err;
465 466
}

467 468 469 470 471 472 473
#define BCM_RECV_LM_DIAG \
	.type = BCM_LM_DIAG_PKT, \
	.hlen = BCM_LM_DIAG_SIZE, \
	.loff = 0, \
	.lsize = 0, \
	.maxlen = BCM_LM_DIAG_SIZE

474 475 476 477 478 479 480
#define BCM_RECV_NULL \
	.type = BCM_NULL_PKT, \
	.hlen = BCM_NULL_SIZE, \
	.loff = 0, \
	.lsize = 0, \
	.maxlen = BCM_NULL_SIZE

481
static const struct h4_recv_pkt bcm_recv_pkts[] = {
482 483 484 485
	{ H4_RECV_ACL,      .recv = hci_recv_frame },
	{ H4_RECV_SCO,      .recv = hci_recv_frame },
	{ H4_RECV_EVENT,    .recv = hci_recv_frame },
	{ BCM_RECV_LM_DIAG, .recv = hci_recv_diag  },
486
	{ BCM_RECV_NULL,    .recv = hci_recv_diag  },
487 488
};

489 490 491 492 493 494 495
static int bcm_recv(struct hci_uart *hu, const void *data, int count)
{
	struct bcm_data *bcm = hu->priv;

	if (!test_bit(HCI_UART_REGISTERED, &hu->flags))
		return -EUNATCH;

496 497
	bcm->rx_skb = h4_recv_buf(hu->hdev, bcm->rx_skb, data, count,
				  bcm_recv_pkts, ARRAY_SIZE(bcm_recv_pkts));
498 499
	if (IS_ERR(bcm->rx_skb)) {
		int err = PTR_ERR(bcm->rx_skb);
500
		bt_dev_err(hu->hdev, "Frame reassembly failed (%d)", err);
501
		bcm->rx_skb = NULL;
502
		return err;
503 504 505 506 507 508 509 510 511
	} else if (!bcm->rx_skb) {
		/* Delay auto-suspend when receiving completed packet */
		mutex_lock(&bcm_device_lock);
		if (bcm->dev && bcm_device_exists(bcm->dev)) {
			pm_runtime_get(&bcm->dev->pdev->dev);
			pm_runtime_mark_last_busy(&bcm->dev->pdev->dev);
			pm_runtime_put_autosuspend(&bcm->dev->pdev->dev);
		}
		mutex_unlock(&bcm_device_lock);
512 513 514 515 516 517 518 519 520
	}

	return count;
}

static int bcm_enqueue(struct hci_uart *hu, struct sk_buff *skb)
{
	struct bcm_data *bcm = hu->priv;

521
	bt_dev_dbg(hu->hdev, "hu %p skb %p", hu, skb);
522 523

	/* Prepend skb with frame type */
524
	memcpy(skb_push(skb, 1), &hci_skb_pkt_type(skb), 1);
525 526 527 528 529 530 531 532
	skb_queue_tail(&bcm->txq, skb);

	return 0;
}

static struct sk_buff *bcm_dequeue(struct hci_uart *hu)
{
	struct bcm_data *bcm = hu->priv;
533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549
	struct sk_buff *skb = NULL;
	struct bcm_device *bdev = NULL;

	mutex_lock(&bcm_device_lock);

	if (bcm_device_exists(bcm->dev)) {
		bdev = bcm->dev;
		pm_runtime_get_sync(&bdev->pdev->dev);
		/* Shall be resumed here */
	}

	skb = skb_dequeue(&bcm->txq);

	if (bdev) {
		pm_runtime_mark_last_busy(&bdev->pdev->dev);
		pm_runtime_put_autosuspend(&bdev->pdev->dev);
	}
550

551 552 553
	mutex_unlock(&bcm_device_lock);

	return skb;
554 555
}

556 557
#ifdef CONFIG_PM
static int bcm_suspend_device(struct device *dev)
558 559 560
{
	struct bcm_device *bdev = platform_get_drvdata(to_platform_device(dev));

561
	bt_dev_dbg(bdev, "");
562

563
	if (!bdev->is_suspended && bdev->hu) {
564 565
		hci_uart_set_flow_control(bdev->hu, true);

566
		/* Once this returns, driver suspends BT via GPIO */
567 568 569 570 571 572
		bdev->is_suspended = true;
	}

	/* Suspend the device */
	if (bdev->device_wakeup) {
		gpiod_set_value(bdev->device_wakeup, false);
573
		bt_dev_dbg(bdev, "suspend, delaying 15 ms");
574 575 576
		mdelay(15);
	}

577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620
	return 0;
}

static int bcm_resume_device(struct device *dev)
{
	struct bcm_device *bdev = platform_get_drvdata(to_platform_device(dev));

	bt_dev_dbg(bdev, "");

	if (bdev->device_wakeup) {
		gpiod_set_value(bdev->device_wakeup, true);
		bt_dev_dbg(bdev, "resume, delaying 15 ms");
		mdelay(15);
	}

	/* When this executes, the device has woken up already */
	if (bdev->is_suspended && bdev->hu) {
		bdev->is_suspended = false;

		hci_uart_set_flow_control(bdev->hu, false);
	}

	return 0;
}
#endif

#ifdef CONFIG_PM_SLEEP
/* Platform suspend callback */
static int bcm_suspend(struct device *dev)
{
	struct bcm_device *bdev = platform_get_drvdata(to_platform_device(dev));
	int error;

	bt_dev_dbg(bdev, "suspend: is_suspended %d", bdev->is_suspended);

	/* bcm_suspend can be called at any time as long as platform device is
	 * bound, so it should use bcm_device_lock to protect access to hci_uart
	 * and device_wake-up GPIO.
	 */
	mutex_lock(&bcm_device_lock);

	if (!bdev->hu)
		goto unlock;

621 622
	if (pm_runtime_active(dev))
		bcm_suspend_device(dev);
623

624 625 626 627 628 629
	if (device_may_wakeup(&bdev->pdev->dev)) {
		error = enable_irq_wake(bdev->irq);
		if (!error)
			bt_dev_dbg(bdev, "BCM irq: enabled");
	}

630
unlock:
631
	mutex_unlock(&bcm_device_lock);
632

633 634 635 636 637 638 639 640
	return 0;
}

/* Platform resume callback */
static int bcm_resume(struct device *dev)
{
	struct bcm_device *bdev = platform_get_drvdata(to_platform_device(dev));

641
	bt_dev_dbg(bdev, "resume: is_suspended %d", bdev->is_suspended);
642

643 644 645 646
	/* bcm_resume can be called at any time as long as platform device is
	 * bound, so it should use bcm_device_lock to protect access to hci_uart
	 * and device_wake-up GPIO.
	 */
647
	mutex_lock(&bcm_device_lock);
648 649 650 651

	if (!bdev->hu)
		goto unlock;

652 653 654 655 656
	if (device_may_wakeup(&bdev->pdev->dev)) {
		disable_irq_wake(bdev->irq);
		bt_dev_dbg(bdev, "BCM irq: disabled");
	}

657
	bcm_resume_device(dev);
658

659
unlock:
660
	mutex_unlock(&bcm_device_lock);
661

662 663 664 665
	pm_runtime_disable(dev);
	pm_runtime_set_active(dev);
	pm_runtime_enable(dev);

666 667 668 669
	return 0;
}
#endif

670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688
static const struct acpi_gpio_params int_last_device_wakeup_gpios = { 0, 0, false };
static const struct acpi_gpio_params int_last_shutdown_gpios = { 1, 0, false };
static const struct acpi_gpio_params int_last_host_wakeup_gpios = { 2, 0, false };

static const struct acpi_gpio_mapping acpi_bcm_int_last_gpios[] = {
	{ "device-wakeup-gpios", &int_last_device_wakeup_gpios, 1 },
	{ "shutdown-gpios", &int_last_shutdown_gpios, 1 },
	{ "host-wakeup-gpios", &int_last_host_wakeup_gpios, 1 },
	{ },
};

static const struct acpi_gpio_params int_first_host_wakeup_gpios = { 0, 0, false };
static const struct acpi_gpio_params int_first_device_wakeup_gpios = { 1, 0, false };
static const struct acpi_gpio_params int_first_shutdown_gpios = { 2, 0, false };

static const struct acpi_gpio_mapping acpi_bcm_int_first_gpios[] = {
	{ "device-wakeup-gpios", &int_first_device_wakeup_gpios, 1 },
	{ "shutdown-gpios", &int_first_shutdown_gpios, 1 },
	{ "host-wakeup-gpios", &int_first_host_wakeup_gpios, 1 },
689 690 691
	{ },
};

692
#ifdef CONFIG_ACPI
693 694 695 696 697 698 699 700 701 702 703 704 705
static u8 acpi_active_low = ACPI_ACTIVE_LOW;

/* IRQ polarity of some chipsets are not defined correctly in ACPI table. */
static const struct dmi_system_id bcm_wrong_irq_dmi_table[] = {
	{
		.ident = "Asus T100TA",
		.matches = {
			DMI_EXACT_MATCH(DMI_SYS_VENDOR,
					"ASUSTeK COMPUTER INC."),
			DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "T100TA"),
		},
		.driver_data = &acpi_active_low,
	},
706 707 708 709 710 711 712 713 714
	{
		.ident = "Asus T100CHI",
		.matches = {
			DMI_EXACT_MATCH(DMI_SYS_VENDOR,
					"ASUSTeK COMPUTER INC."),
			DMI_EXACT_MATCH(DMI_PRODUCT_NAME, "T100CHI"),
		},
		.driver_data = &acpi_active_low,
	},
715 716 717 718 719 720 721 722
	{	/* Handle ThinkPad 8 tablets with BCM2E55 chipset ACPI ID */
		.ident = "Lenovo ThinkPad 8",
		.matches = {
			DMI_EXACT_MATCH(DMI_SYS_VENDOR, "LENOVO"),
			DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "ThinkPad 8"),
		},
		.driver_data = &acpi_active_low,
	},
723 724 725
	{ }
};

726 727 728
static int bcm_resource(struct acpi_resource *ares, void *data)
{
	struct bcm_device *dev = data;
729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745
	struct acpi_resource_extended_irq *irq;
	struct acpi_resource_gpio *gpio;
	struct acpi_resource_uart_serialbus *sb;

	switch (ares->type) {
	case ACPI_RESOURCE_TYPE_EXTENDED_IRQ:
		irq = &ares->data.extended_irq;
		dev->irq_polarity = irq->polarity;
		break;

	case ACPI_RESOURCE_TYPE_GPIO:
		gpio = &ares->data.gpio;
		if (gpio->connection_type == ACPI_RESOURCE_GPIO_TYPE_INT)
			dev->irq_polarity = gpio->polarity;
		break;

	case ACPI_RESOURCE_TYPE_SERIAL_BUS:
746
		sb = &ares->data.uart_serial_bus;
747
		if (sb->type == ACPI_RESOURCE_SERIAL_TYPE_UART) {
748
			dev->init_speed = sb->default_baud_rate;
749 750
			dev->oper_speed = 4000000;
		}
751 752 753 754
		break;

	default:
		break;
755 756 757 758 759
	}

	/* Always tell the ACPI core to skip this resource */
	return 1;
}
760
#endif /* CONFIG_ACPI */
761

762
static int bcm_platform_probe(struct bcm_device *dev)
763 764 765 766
{
	struct platform_device *pdev = dev->pdev;

	dev->name = dev_name(&pdev->dev);
767

768 769
	dev->clk = devm_clk_get(&pdev->dev, NULL);

770 771 772 773 774
	dev->device_wakeup = devm_gpiod_get_optional(&pdev->dev,
						     "device-wakeup",
						     GPIOD_OUT_LOW);
	if (IS_ERR(dev->device_wakeup))
		return PTR_ERR(dev->device_wakeup);
775

776 777 778 779
	dev->shutdown = devm_gpiod_get_optional(&pdev->dev, "shutdown",
						GPIOD_OUT_LOW);
	if (IS_ERR(dev->shutdown))
		return PTR_ERR(dev->shutdown);
780

781 782 783 784 785 786 787 788 789 790 791 792 793 794 795
	/* IRQ can be declared in ACPI table as Interrupt or GpioInt */
	dev->irq = platform_get_irq(pdev, 0);
	if (dev->irq <= 0) {
		struct gpio_desc *gpio;

		gpio = devm_gpiod_get_optional(&pdev->dev, "host-wakeup",
					       GPIOD_IN);
		if (IS_ERR(gpio))
			return PTR_ERR(gpio);

		dev->irq = gpiod_to_irq(gpio);
	}

	dev_info(&pdev->dev, "BCM irq: %d\n", dev->irq);

796 797 798 799 800 801 802 803
	/* Make sure at-least one of the GPIO is defined and that
	 * a name is specified for this instance
	 */
	if ((!dev->device_wakeup && !dev->shutdown) || !dev->name) {
		dev_err(&pdev->dev, "invalid platform data\n");
		return -EINVAL;
	}

804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821
	return 0;
}

#ifdef CONFIG_ACPI
static int bcm_acpi_probe(struct bcm_device *dev)
{
	struct platform_device *pdev = dev->pdev;
	LIST_HEAD(resources);
	const struct dmi_system_id *dmi_id;
	const struct acpi_gpio_mapping *gpio_mapping = acpi_bcm_int_last_gpios;
	const struct acpi_device_id *id;
	int ret;

	/* Retrieve GPIO data */
	id = acpi_match_device(pdev->dev.driver->acpi_match_table, &pdev->dev);
	if (id)
		gpio_mapping = (const struct acpi_gpio_mapping *) id->driver_data;

822
	ret = devm_acpi_dev_add_driver_gpios(&pdev->dev, gpio_mapping);
823 824 825 826 827 828 829
	if (ret)
		return ret;

	ret = bcm_platform_probe(dev);
	if (ret)
		return ret;

830
	/* Retrieve UART ACPI info */
831 832
	ret = acpi_dev_get_resources(ACPI_COMPANION(&dev->pdev->dev),
				     &resources, bcm_resource, dev);
833 834
	if (ret < 0)
		return ret;
835
	acpi_dev_free_resource_list(&resources);
836

837 838 839 840 841 842 843
	dmi_id = dmi_first_match(bcm_wrong_irq_dmi_table);
	if (dmi_id) {
		bt_dev_warn(dev, "%s: Overwriting IRQ polarity to active low",
			    dmi_id->ident);
		dev->irq_polarity = *(u8 *)dmi_id->driver_data;
	}

844 845
	return 0;
}
846 847 848 849 850 851
#else
static int bcm_acpi_probe(struct bcm_device *dev)
{
	return -EINVAL;
}
#endif /* CONFIG_ACPI */
852 853 854 855 856 857 858 859 860 861 862 863

static int bcm_probe(struct platform_device *pdev)
{
	struct bcm_device *dev;
	int ret;

	dev = devm_kzalloc(&pdev->dev, sizeof(*dev), GFP_KERNEL);
	if (!dev)
		return -ENOMEM;

	dev->pdev = pdev;

864 865 866 867
	if (has_acpi_companion(&pdev->dev))
		ret = bcm_acpi_probe(dev);
	else
		ret = bcm_platform_probe(dev);
868 869
	if (ret)
		return ret;
870 871 872 873 874 875

	platform_set_drvdata(pdev, dev);

	dev_info(&pdev->dev, "%s device registered.\n", dev->name);

	/* Place this instance on the device list */
876
	mutex_lock(&bcm_device_lock);
877
	list_add_tail(&dev->list, &bcm_device_list);
878
	mutex_unlock(&bcm_device_lock);
879 880 881 882 883 884 885 886 887 888

	bcm_gpio_set_power(dev, false);

	return 0;
}

static int bcm_remove(struct platform_device *pdev)
{
	struct bcm_device *dev = platform_get_drvdata(pdev);

889
	mutex_lock(&bcm_device_lock);
890
	list_del(&dev->list);
891
	mutex_unlock(&bcm_device_lock);
892 893 894 895 896 897

	dev_info(&pdev->dev, "%s device unregistered.\n", dev->name);

	return 0;
}

898 899
static const struct hci_uart_proto bcm_proto = {
	.id		= HCI_UART_BCM,
900
	.name		= "Broadcom",
901
	.manufacturer	= 15,
902
	.init_speed	= 115200,
903 904 905 906
	.open		= bcm_open,
	.close		= bcm_close,
	.flush		= bcm_flush,
	.setup		= bcm_setup,
907
	.set_baudrate	= bcm_set_baudrate,
908 909 910 911 912
	.recv		= bcm_recv,
	.enqueue	= bcm_enqueue,
	.dequeue	= bcm_dequeue,
};

913 914
#ifdef CONFIG_ACPI
static const struct acpi_device_id bcm_acpi_match[] = {
915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930
	{ "BCM2E1A", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E39", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E3A", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E3D", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E3F", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E40", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E54", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E55", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E64", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E65", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E67", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E71", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E7B", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E7C", (kernel_ulong_t)&acpi_bcm_int_last_gpios },
	{ "BCM2E95", (kernel_ulong_t)&acpi_bcm_int_first_gpios },
	{ "BCM2E96", (kernel_ulong_t)&acpi_bcm_int_first_gpios },
931 932 933 934 935
	{ },
};
MODULE_DEVICE_TABLE(acpi, bcm_acpi_match);
#endif

936
/* Platform suspend and resume callbacks */
937 938 939 940
static const struct dev_pm_ops bcm_pm_ops = {
	SET_SYSTEM_SLEEP_PM_OPS(bcm_suspend, bcm_resume)
	SET_RUNTIME_PM_OPS(bcm_suspend_device, bcm_resume_device, NULL)
};
941

942 943 944 945 946 947
static struct platform_driver bcm_driver = {
	.probe = bcm_probe,
	.remove = bcm_remove,
	.driver = {
		.name = "hci_bcm",
		.acpi_match_table = ACPI_PTR(bcm_acpi_match),
948
		.pm = &bcm_pm_ops,
949 950 951
	},
};

952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995
static int bcm_serdev_probe(struct serdev_device *serdev)
{
	struct bcm_serdev *bcmdev;
	u32 speed;
	int err;

	bcmdev = devm_kzalloc(&serdev->dev, sizeof(*bcmdev), GFP_KERNEL);
	if (!bcmdev)
		return -ENOMEM;

	bcmdev->hu.serdev = serdev;
	serdev_device_set_drvdata(serdev, bcmdev);

	err = device_property_read_u32(&serdev->dev, "max-speed", &speed);
	if (!err)
		bcmdev->hu.oper_speed = speed;

	return hci_uart_register_device(&bcmdev->hu, &bcm_proto);
}

static void bcm_serdev_remove(struct serdev_device *serdev)
{
	struct bcm_serdev *bcmdev = serdev_device_get_drvdata(serdev);

	hci_uart_unregister_device(&bcmdev->hu);
}

#ifdef CONFIG_OF
static const struct of_device_id bcm_bluetooth_of_match[] = {
	{ .compatible = "brcm,bcm43438-bt" },
	{ },
};
MODULE_DEVICE_TABLE(of, bcm_bluetooth_of_match);
#endif

static struct serdev_device_driver bcm_serdev_driver = {
	.probe = bcm_serdev_probe,
	.remove = bcm_serdev_remove,
	.driver = {
		.name = "hci_uart_bcm",
		.of_match_table = of_match_ptr(bcm_bluetooth_of_match),
	},
};

996 997
int __init bcm_init(void)
{
998 999 1000
	/* For now, we need to keep both platform device
	 * driver (ACPI generated) and serdev driver (DT).
	 */
1001
	platform_driver_register(&bcm_driver);
1002
	serdev_device_driver_register(&bcm_serdev_driver);
1003

1004 1005 1006 1007 1008
	return hci_uart_register_proto(&bcm_proto);
}

int __exit bcm_deinit(void)
{
1009
	platform_driver_unregister(&bcm_driver);
1010
	serdev_device_driver_unregister(&bcm_serdev_driver);
1011

1012 1013
	return hci_uart_unregister_proto(&bcm_proto);
}