Lines Matching defs:hdev

27 int btintel_check_bdaddr(struct hci_dev *hdev)
32 skb = __hci_cmd_sync(hdev, HCI_OP_READ_BD_ADDR, 0, NULL,
36 bt_dev_err(hdev, "Reading Intel device address failed (%d)",
42 bt_dev_err(hdev, "Intel device address length mismatch");
55 bt_dev_err(hdev, "Found Intel default device address (%pMR)",
57 set_bit(HCI_QUIRK_INVALID_BDADDR, &hdev->quirks);
66 int btintel_enter_mfg(struct hci_dev *hdev)
71 skb = __hci_cmd_sync(hdev, 0xfc11, 2, param, HCI_CMD_TIMEOUT);
73 bt_dev_err(hdev, "Entering manufacturer mode failed (%ld)",
83 int btintel_exit_mfg(struct hci_dev *hdev, bool reset, bool patched)
96 skb = __hci_cmd_sync(hdev, 0xfc11, 2, param, HCI_CMD_TIMEOUT);
98 bt_dev_err(hdev, "Exiting manufacturer mode failed (%ld)",
108 int btintel_set_bdaddr(struct hci_dev *hdev, const bdaddr_t *bdaddr)
113 skb = __hci_cmd_sync(hdev, 0xfc31, 6, bdaddr, HCI_INIT_TIMEOUT);
116 bt_dev_err(hdev, "Changing Intel device address failed (%d)",
126 int btintel_set_diag(struct hci_dev *hdev, bool enable)
142 skb = __hci_cmd_sync(hdev, 0xfc43, 3, param, HCI_INIT_TIMEOUT);
147 bt_dev_err(hdev, "Changing Intel diagnostic mode failed (%d)",
154 btintel_set_event_mask(hdev, enable);
159 int btintel_set_diag_mfg(struct hci_dev *hdev, bool enable)
163 err = btintel_enter_mfg(hdev);
167 ret = btintel_set_diag(hdev, enable);
169 err = btintel_exit_mfg(hdev, false, false);
177 void btintel_hw_error(struct hci_dev *hdev, u8 code)
182 bt_dev_err(hdev, "Hardware error 0x%2.2x", code);
184 skb = __hci_cmd_sync(hdev, HCI_OP_RESET, 0, NULL, HCI_INIT_TIMEOUT);
186 bt_dev_err(hdev, "Reset after hardware error failed (%ld)",
192 skb = __hci_cmd_sync(hdev, 0xfc22, 1, &type, HCI_INIT_TIMEOUT);
194 bt_dev_err(hdev, "Retrieving Intel exception info failed (%ld)",
200 bt_dev_err(hdev, "Exception info size mismatch");
205 bt_dev_err(hdev, "Exception info %s", (char *)(skb->data + 1));
211 void btintel_version_info(struct hci_dev *hdev, struct intel_version *ver)
226 bt_dev_info(hdev, "%s revision %u.%u build %u week %u %u",
233 int btintel_secure_send(struct hci_dev *hdev, u8 fragment_type, u32 plen,
243 skb = __hci_cmd_sync(hdev, 0xfc09, fragment_len + 1,
258 int btintel_load_ddc_config(struct hci_dev *hdev, const char *ddc_name)
265 err = request_firmware_direct(&fw, ddc_name, &hdev->dev);
267 bt_dev_err(hdev, "Failed to load Intel DDC file %s (%d)",
272 bt_dev_info(hdev, "Found Intel DDC parameters: %s", ddc_name);
282 skb = __hci_cmd_sync(hdev, 0xfc8b, cmd_plen, fw_ptr,
285 bt_dev_err(hdev, "Failed to send Intel_Write_DDC (%ld)",
297 bt_dev_info(hdev, "Applying Intel DDC parameters completed");
303 int btintel_set_event_mask(struct hci_dev *hdev, bool debug)
312 skb = __hci_cmd_sync(hdev, 0xfc52, 8, mask, HCI_INIT_TIMEOUT);
315 bt_dev_err(hdev, "Setting Intel event mask failed (%d)", err);
324 int btintel_set_event_mask_mfg(struct hci_dev *hdev, bool debug)
328 err = btintel_enter_mfg(hdev);
332 ret = btintel_set_event_mask(hdev, debug);
334 err = btintel_exit_mfg(hdev, false, false);
342 int btintel_read_version(struct hci_dev *hdev, struct intel_version *ver)
346 skb = __hci_cmd_sync(hdev, 0xfc05, 0, NULL, HCI_CMD_TIMEOUT);
348 bt_dev_err(hdev, "Reading Intel version information failed (%ld)",
354 bt_dev_err(hdev, "Intel version event size mismatch");
367 void btintel_version_info_tlv(struct hci_dev *hdev, struct intel_version_tlv *version)
374 bt_dev_info(hdev, "Device revision is %u", version->dev_rev_id);
375 bt_dev_info(hdev, "Secure boot is %s",
377 bt_dev_info(hdev, "OTP lock is %s",
379 bt_dev_info(hdev, "API lock is %s",
381 bt_dev_info(hdev, "Debug lock is %s",
383 bt_dev_info(hdev, "Minimum firmware build %u week %u %u",
391 bt_dev_err(hdev, "Unsupported image type(%02x)", version->img_type);
395 bt_dev_info(hdev, "%s timestamp %u.%u buildtype %u build %u", variant,
404 int btintel_read_version_tlv(struct hci_dev *hdev, struct intel_version_tlv *version)
412 skb = __hci_cmd_sync(hdev, 0xfc05, 1, param, HCI_CMD_TIMEOUT);
414 bt_dev_err(hdev, "Reading Intel version information failed (%ld)",
420 bt_dev_err(hdev, "Intel Read Version command failed (%02x)",
512 struct hci_dev *hdev;
560 bt_dev_dbg(ctx->hdev, "Register (0x%x) read", le32_to_cpu(cp.addr));
562 skb = hci_cmd_sync(ctx->hdev, ctx->op_read, sizeof(cp), &cp,
566 bt_dev_err(ctx->hdev, "regmap: Register (0x%x) read error (%d)",
572 bt_dev_err(ctx->hdev, "regmap: Register (0x%x) read error, bad len",
581 bt_dev_err(ctx->hdev, "regmap: Register (0x%x) read error, bad addr",
632 bt_dev_dbg(ctx->hdev, "Register (0x%x) write", le32_to_cpu(cp->addr));
634 skb = hci_cmd_sync(ctx->hdev, ctx->op_write, plen, cp, HCI_CMD_TIMEOUT);
637 bt_dev_err(ctx->hdev, "regmap: Register (0x%x) write error (%d)",
680 struct regmap *btintel_regmap_init(struct hci_dev *hdev, u16 opcode_read,
685 bt_dev_info(hdev, "regmap: Init R%x-W%x region", opcode_read,
694 ctx->hdev = hdev;
696 return regmap_init(&hdev->dev, &regmap_ibt, ctx, &regmap_ibt_cfg);
700 int btintel_send_intel_reset(struct hci_dev *hdev, u32 boot_param)
707 skb = __hci_cmd_sync(hdev, 0xfc01, sizeof(params), &params,
710 bt_dev_err(hdev, "Failed to send Intel Reset command");
720 int btintel_read_boot_params(struct hci_dev *hdev,
725 skb = __hci_cmd_sync(hdev, 0xfc0d, 0, NULL, HCI_INIT_TIMEOUT);
727 bt_dev_err(hdev, "Reading Intel boot parameters failed (%ld)",
733 bt_dev_err(hdev, "Intel boot parameters size mismatch");
743 bt_dev_err(hdev, "Intel boot parameters command failed (%02x)",
748 bt_dev_info(hdev, "Device revision is %u",
751 bt_dev_info(hdev, "Secure boot is %s",
754 bt_dev_info(hdev, "OTP lock is %s",
757 bt_dev_info(hdev, "API lock is %s",
760 bt_dev_info(hdev, "Debug lock is %s",
763 bt_dev_info(hdev, "Minimum firmware build %u week %u %u",
771 static int btintel_sfi_rsa_header_secure_send(struct hci_dev *hdev,
779 err = btintel_secure_send(hdev, 0x00, 128, fw->data);
781 bt_dev_err(hdev, "Failed to send firmware header (%d)", err);
788 err = btintel_secure_send(hdev, 0x03, 256, fw->data + 128);
790 bt_dev_err(hdev, "Failed to send firmware pkey (%d)", err);
797 err = btintel_secure_send(hdev, 0x02, 256, fw->data + 388);
799 bt_dev_err(hdev, "Failed to send firmware signature (%d)", err);
807 static int btintel_sfi_ecdsa_header_secure_send(struct hci_dev *hdev,
815 err = btintel_secure_send(hdev, 0x00, 128, fw->data + 644);
817 bt_dev_err(hdev, "Failed to send firmware header (%d)", err);
824 err = btintel_secure_send(hdev, 0x03, 96, fw->data + 644 + 128);
826 bt_dev_err(hdev, "Failed to send firmware pkey (%d)", err);
833 err = btintel_secure_send(hdev, 0x02, 96, fw->data + 644 + 224);
835 bt_dev_err(hdev, "Failed to send firmware signature (%d)",
842 static int btintel_download_firmware_payload(struct hci_dev *hdev,
868 bt_dev_dbg(hdev, "boot_param=0x%x", *boot_param);
882 err = btintel_secure_send(hdev, 0x01, frag_len, fw_ptr);
884 bt_dev_err(hdev,
899 int btintel_download_firmware(struct hci_dev *hdev,
905 err = btintel_sfi_rsa_header_secure_send(hdev, fw);
909 return btintel_download_firmware_payload(hdev, fw, boot_param,
914 int btintel_download_firmware_newgen(struct hci_dev *hdev,
935 bt_dev_err(hdev, "Invalid CSS Header version");
941 bt_dev_err(hdev, "Invalid SBE type for hardware variant (%d)",
946 err = btintel_sfi_rsa_header_secure_send(hdev, fw);
950 err = btintel_download_firmware_payload(hdev, fw, boot_param, RSA_HEADER_LEN);
961 bt_dev_err(hdev, "Invalid CSS Header version");
966 err = btintel_sfi_rsa_header_secure_send(hdev, fw);
970 err = btintel_download_firmware_payload(hdev, fw,
976 err = btintel_sfi_ecdsa_header_secure_send(hdev, fw);
980 err = btintel_download_firmware_payload(hdev, fw,
991 void btintel_reset_to_bootloader(struct hci_dev *hdev)
1017 skb = __hci_cmd_sync(hdev, 0xfc01, sizeof(params),
1020 bt_dev_err(hdev, "FW download error recovery failed (%ld)",
1024 bt_dev_info(hdev, "Intel reset sent to retry FW download");
1036 int btintel_read_debug_features(struct hci_dev *hdev,
1045 skb = __hci_cmd_sync(hdev, 0xfca6, sizeof(page_no), &page_no,
1048 bt_dev_err(hdev, "Reading supported features failed (%ld)",
1054 bt_dev_err(hdev, "Supported features event size mismatch");
1068 int btintel_set_debug_features(struct hci_dev *hdev,
1079 bt_dev_info(hdev, "Telemetry exception format not supported");
1083 skb = __hci_cmd_sync(hdev, 0xfc8b, 11, mask, HCI_INIT_TIMEOUT);
1085 bt_dev_err(hdev, "Setting Intel telemetry ddc write event mask failed (%ld)",