3 * Bluetooth support for Intel devices
5 * Copyright (C) 2015 Intel Corporation
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
24 #include <linux/module.h>
25 #include <linux/firmware.h>
26 #include <linux/regmap.h>
28 #include <net/bluetooth/bluetooth.h>
29 #include <net/bluetooth/hci_core.h>
35 #define BDADDR_INTEL (&(bdaddr_t) {{0x00, 0x8b, 0x9e, 0x19, 0x03, 0x00}})
37 int btintel_check_bdaddr(struct hci_dev
*hdev
)
39 struct hci_rp_read_bd_addr
*bda
;
42 skb
= __hci_cmd_sync(hdev
, HCI_OP_READ_BD_ADDR
, 0, NULL
,
45 int err
= PTR_ERR(skb
);
46 bt_dev_err(hdev
, "Reading Intel device address failed (%d)",
51 if (skb
->len
!= sizeof(*bda
)) {
52 bt_dev_err(hdev
, "Intel device address length mismatch");
57 bda
= (struct hci_rp_read_bd_addr
*)skb
->data
;
59 /* For some Intel based controllers, the default Bluetooth device
60 * address 00:03:19:9E:8B:00 can be found. These controllers are
61 * fully operational, but have the danger of duplicate addresses
62 * and that in turn can cause problems with Bluetooth operation.
64 if (!bacmp(&bda
->bdaddr
, BDADDR_INTEL
)) {
65 bt_dev_err(hdev
, "Found Intel default device address (%pMR)",
67 set_bit(HCI_QUIRK_INVALID_BDADDR
, &hdev
->quirks
);
74 EXPORT_SYMBOL_GPL(btintel_check_bdaddr
);
76 int btintel_enter_mfg(struct hci_dev
*hdev
)
78 const u8 param
[] = { 0x01, 0x00 };
81 skb
= __hci_cmd_sync(hdev
, 0xfc11, 2, param
, HCI_CMD_TIMEOUT
);
83 bt_dev_err(hdev
, "Entering manufacturer mode failed (%ld)",
91 EXPORT_SYMBOL_GPL(btintel_enter_mfg
);
93 int btintel_exit_mfg(struct hci_dev
*hdev
, bool reset
, bool patched
)
95 u8 param
[] = { 0x00, 0x00 };
98 /* The 2nd command parameter specifies the manufacturing exit method:
99 * 0x00: Just disable the manufacturing mode (0x00).
100 * 0x01: Disable manufacturing mode and reset with patches deactivated.
101 * 0x02: Disable manufacturing mode and reset with patches activated.
104 param
[1] |= patched
? 0x02 : 0x01;
106 skb
= __hci_cmd_sync(hdev
, 0xfc11, 2, param
, HCI_CMD_TIMEOUT
);
108 bt_dev_err(hdev
, "Exiting manufacturer mode failed (%ld)",
116 EXPORT_SYMBOL_GPL(btintel_exit_mfg
);
118 int btintel_set_bdaddr(struct hci_dev
*hdev
, const bdaddr_t
*bdaddr
)
123 skb
= __hci_cmd_sync(hdev
, 0xfc31, 6, bdaddr
, HCI_INIT_TIMEOUT
);
126 bt_dev_err(hdev
, "Changing Intel device address failed (%d)",
134 EXPORT_SYMBOL_GPL(btintel_set_bdaddr
);
136 int btintel_set_diag(struct hci_dev
*hdev
, bool enable
)
152 skb
= __hci_cmd_sync(hdev
, 0xfc43, 3, param
, HCI_INIT_TIMEOUT
);
157 bt_dev_err(hdev
, "Changing Intel diagnostic mode failed (%d)",
164 btintel_set_event_mask(hdev
, enable
);
167 EXPORT_SYMBOL_GPL(btintel_set_diag
);
169 int btintel_set_diag_mfg(struct hci_dev
*hdev
, bool enable
)
173 err
= btintel_enter_mfg(hdev
);
177 ret
= btintel_set_diag(hdev
, enable
);
179 err
= btintel_exit_mfg(hdev
, false, false);
185 EXPORT_SYMBOL_GPL(btintel_set_diag_mfg
);
187 void btintel_hw_error(struct hci_dev
*hdev
, u8 code
)
192 bt_dev_err(hdev
, "Hardware error 0x%2.2x", code
);
194 skb
= __hci_cmd_sync(hdev
, HCI_OP_RESET
, 0, NULL
, HCI_INIT_TIMEOUT
);
196 bt_dev_err(hdev
, "Reset after hardware error failed (%ld)",
202 skb
= __hci_cmd_sync(hdev
, 0xfc22, 1, &type
, HCI_INIT_TIMEOUT
);
204 bt_dev_err(hdev
, "Retrieving Intel exception info failed (%ld)",
209 if (skb
->len
!= 13) {
210 bt_dev_err(hdev
, "Exception info size mismatch");
215 bt_dev_err(hdev
, "Exception info %s", (char *)(skb
->data
+ 1));
219 EXPORT_SYMBOL_GPL(btintel_hw_error
);
221 void btintel_version_info(struct hci_dev
*hdev
, struct intel_version
*ver
)
225 switch (ver
->fw_variant
) {
227 variant
= "Bootloader";
230 variant
= "Firmware";
236 bt_dev_info(hdev
, "%s revision %u.%u build %u week %u %u",
237 variant
, ver
->fw_revision
>> 4, ver
->fw_revision
& 0x0f,
238 ver
->fw_build_num
, ver
->fw_build_ww
,
239 2000 + ver
->fw_build_yy
);
241 EXPORT_SYMBOL_GPL(btintel_version_info
);
243 int btintel_secure_send(struct hci_dev
*hdev
, u8 fragment_type
, u32 plen
,
248 u8 cmd_param
[253], fragment_len
= (plen
> 252) ? 252 : plen
;
250 cmd_param
[0] = fragment_type
;
251 memcpy(cmd_param
+ 1, param
, fragment_len
);
253 skb
= __hci_cmd_sync(hdev
, 0xfc09, fragment_len
+ 1,
254 cmd_param
, HCI_INIT_TIMEOUT
);
260 plen
-= fragment_len
;
261 param
+= fragment_len
;
266 EXPORT_SYMBOL_GPL(btintel_secure_send
);
268 int btintel_load_ddc_config(struct hci_dev
*hdev
, const char *ddc_name
)
270 const struct firmware
*fw
;
275 err
= request_firmware_direct(&fw
, ddc_name
, &hdev
->dev
);
277 bt_dev_err(hdev
, "Failed to load Intel DDC file %s (%d)",
282 bt_dev_info(hdev
, "Found Intel DDC parameters: %s", ddc_name
);
286 /* DDC file contains one or more DDC structure which has
287 * Length (1 byte), DDC ID (2 bytes), and DDC value (Length - 2).
289 while (fw
->size
> fw_ptr
- fw
->data
) {
290 u8 cmd_plen
= fw_ptr
[0] + sizeof(u8
);
292 skb
= __hci_cmd_sync(hdev
, 0xfc8b, cmd_plen
, fw_ptr
,
295 bt_dev_err(hdev
, "Failed to send Intel_Write_DDC (%ld)",
297 release_firmware(fw
);
305 release_firmware(fw
);
307 bt_dev_info(hdev
, "Applying Intel DDC parameters completed");
311 EXPORT_SYMBOL_GPL(btintel_load_ddc_config
);
313 int btintel_set_event_mask(struct hci_dev
*hdev
, bool debug
)
315 u8 mask
[8] = { 0x87, 0x0c, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
322 skb
= __hci_cmd_sync(hdev
, 0xfc52, 8, mask
, HCI_INIT_TIMEOUT
);
325 bt_dev_err(hdev
, "Setting Intel event mask failed (%d)", err
);
332 EXPORT_SYMBOL_GPL(btintel_set_event_mask
);
334 int btintel_set_event_mask_mfg(struct hci_dev
*hdev
, bool debug
)
338 err
= btintel_enter_mfg(hdev
);
342 ret
= btintel_set_event_mask(hdev
, debug
);
344 err
= btintel_exit_mfg(hdev
, false, false);
350 EXPORT_SYMBOL_GPL(btintel_set_event_mask_mfg
);
352 int btintel_read_version(struct hci_dev
*hdev
, struct intel_version
*ver
)
356 skb
= __hci_cmd_sync(hdev
, 0xfc05, 0, NULL
, HCI_CMD_TIMEOUT
);
358 bt_dev_err(hdev
, "Reading Intel version information failed (%ld)",
363 if (skb
->len
!= sizeof(*ver
)) {
364 bt_dev_err(hdev
, "Intel version event size mismatch");
369 memcpy(ver
, skb
->data
, sizeof(*ver
));
375 EXPORT_SYMBOL_GPL(btintel_read_version
);
377 /* ------- REGMAP IBT SUPPORT ------- */
379 #define IBT_REG_MODE_8BIT 0x00
380 #define IBT_REG_MODE_16BIT 0x01
381 #define IBT_REG_MODE_32BIT 0x02
383 struct regmap_ibt_context
{
384 struct hci_dev
*hdev
;
389 struct ibt_cp_reg_access
{
396 struct ibt_rp_reg_access
{
402 static int regmap_ibt_read(void *context
, const void *addr
, size_t reg_size
,
403 void *val
, size_t val_size
)
405 struct regmap_ibt_context
*ctx
= context
;
406 struct ibt_cp_reg_access cp
;
407 struct ibt_rp_reg_access
*rp
;
411 if (reg_size
!= sizeof(__le32
))
416 cp
.mode
= IBT_REG_MODE_8BIT
;
419 cp
.mode
= IBT_REG_MODE_16BIT
;
422 cp
.mode
= IBT_REG_MODE_32BIT
;
428 /* regmap provides a little-endian formatted addr */
429 cp
.addr
= *(__le32
*)addr
;
432 bt_dev_dbg(ctx
->hdev
, "Register (0x%x) read", le32_to_cpu(cp
.addr
));
434 skb
= hci_cmd_sync(ctx
->hdev
, ctx
->op_read
, sizeof(cp
), &cp
,
438 bt_dev_err(ctx
->hdev
, "regmap: Register (0x%x) read error (%d)",
439 le32_to_cpu(cp
.addr
), err
);
443 if (skb
->len
!= sizeof(*rp
) + val_size
) {
444 bt_dev_err(ctx
->hdev
, "regmap: Register (0x%x) read error, bad len",
445 le32_to_cpu(cp
.addr
));
450 rp
= (struct ibt_rp_reg_access
*)skb
->data
;
452 if (rp
->addr
!= cp
.addr
) {
453 bt_dev_err(ctx
->hdev
, "regmap: Register (0x%x) read error, bad addr",
454 le32_to_cpu(rp
->addr
));
459 memcpy(val
, rp
->data
, val_size
);
466 static int regmap_ibt_gather_write(void *context
,
467 const void *addr
, size_t reg_size
,
468 const void *val
, size_t val_size
)
470 struct regmap_ibt_context
*ctx
= context
;
471 struct ibt_cp_reg_access
*cp
;
473 int plen
= sizeof(*cp
) + val_size
;
477 if (reg_size
!= sizeof(__le32
))
482 mode
= IBT_REG_MODE_8BIT
;
485 mode
= IBT_REG_MODE_16BIT
;
488 mode
= IBT_REG_MODE_32BIT
;
494 cp
= kmalloc(plen
, GFP_KERNEL
);
498 /* regmap provides a little-endian formatted addr/value */
499 cp
->addr
= *(__le32
*)addr
;
502 memcpy(&cp
->data
, val
, val_size
);
504 bt_dev_dbg(ctx
->hdev
, "Register (0x%x) write", le32_to_cpu(cp
->addr
));
506 skb
= hci_cmd_sync(ctx
->hdev
, ctx
->op_write
, plen
, cp
, HCI_CMD_TIMEOUT
);
509 bt_dev_err(ctx
->hdev
, "regmap: Register (0x%x) write error (%d)",
510 le32_to_cpu(cp
->addr
), err
);
520 static int regmap_ibt_write(void *context
, const void *data
, size_t count
)
522 /* data contains register+value, since we only support 32bit addr,
523 * minimum data size is 4 bytes.
525 if (WARN_ONCE(count
< 4, "Invalid register access"))
528 return regmap_ibt_gather_write(context
, data
, 4, data
+ 4, count
- 4);
531 static void regmap_ibt_free_context(void *context
)
536 static struct regmap_bus regmap_ibt
= {
537 .read
= regmap_ibt_read
,
538 .write
= regmap_ibt_write
,
539 .gather_write
= regmap_ibt_gather_write
,
540 .free_context
= regmap_ibt_free_context
,
541 .reg_format_endian_default
= REGMAP_ENDIAN_LITTLE
,
542 .val_format_endian_default
= REGMAP_ENDIAN_LITTLE
,
545 /* Config is the same for all register regions */
546 static const struct regmap_config regmap_ibt_cfg
= {
547 .name
= "btintel_regmap",
552 struct regmap
*btintel_regmap_init(struct hci_dev
*hdev
, u16 opcode_read
,
555 struct regmap_ibt_context
*ctx
;
557 bt_dev_info(hdev
, "regmap: Init R%x-W%x region", opcode_read
,
560 ctx
= kzalloc(sizeof(*ctx
), GFP_KERNEL
);
562 return ERR_PTR(-ENOMEM
);
564 ctx
->op_read
= opcode_read
;
565 ctx
->op_write
= opcode_write
;
568 return regmap_init(&hdev
->dev
, ®map_ibt
, ctx
, ®map_ibt_cfg
);
570 EXPORT_SYMBOL_GPL(btintel_regmap_init
);
572 MODULE_AUTHOR("Marcel Holtmann <marcel@holtmann.org>");
573 MODULE_DESCRIPTION("Bluetooth support for Intel devices ver " VERSION
);
574 MODULE_VERSION(VERSION
);
575 MODULE_LICENSE("GPL");
576 MODULE_FIRMWARE("intel/ibt-11-5.sfi");
577 MODULE_FIRMWARE("intel/ibt-11-5.ddc");
578 MODULE_FIRMWARE("intel/ibt-12-16.sfi");
579 MODULE_FIRMWARE("intel/ibt-12-16.ddc");