linux/drivers/bluetooth/btintel.c

// SPDX-License-Identifier: GPL-2.0-or-later
/*
 *
 *  Bluetooth support for Intel devices
 *
 *  Copyright (C) 2015  Intel Corporation
 */

#include <linux/module.h>
#include <linux/firmware.h>
#include <linux/regmap.h>
#include <linux/acpi.h>
#include <acpi/acpi_bus.h>
#include <linux/unaligned.h>
#include <linux/efi.h>

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

#include "btintel.h"

#define VERSION

#define BDADDR_INTEL
#define RSA_HEADER_LEN
#define CSS_HEADER_OFFSET
#define ECDSA_OFFSET
#define ECDSA_HEADER_LEN

#define BTINTEL_EFI_DSBR

enum {};

#define CMD_WRITE_BOOT_PARAMS
struct cmd_write_boot_params {} __packed;

static struct {} coredump_info;

static const guid_t btintel_guid_dsm =;

int btintel_check_bdaddr(struct hci_dev *hdev)
{}
EXPORT_SYMBOL_GPL();

int btintel_enter_mfg(struct hci_dev *hdev)
{}
EXPORT_SYMBOL_GPL();

int btintel_exit_mfg(struct hci_dev *hdev, bool reset, bool patched)
{}
EXPORT_SYMBOL_GPL();

int btintel_set_bdaddr(struct hci_dev *hdev, const bdaddr_t *bdaddr)
{}
EXPORT_SYMBOL_GPL();

static int btintel_set_event_mask(struct hci_dev *hdev, bool debug)
{}

int btintel_set_diag(struct hci_dev *hdev, bool enable)
{}
EXPORT_SYMBOL_GPL();

static int btintel_set_diag_mfg(struct hci_dev *hdev, bool enable)
{}

static int btintel_set_diag_combined(struct hci_dev *hdev, bool enable)
{}

void btintel_hw_error(struct hci_dev *hdev, u8 code)
{}
EXPORT_SYMBOL_GPL();

int btintel_version_info(struct hci_dev *hdev, struct intel_version *ver)
{}
EXPORT_SYMBOL_GPL();

static int btintel_secure_send(struct hci_dev *hdev, u8 fragment_type, u32 plen,
			       const void *param)
{}

int btintel_load_ddc_config(struct hci_dev *hdev, const char *ddc_name)
{}
EXPORT_SYMBOL_GPL();

int btintel_set_event_mask_mfg(struct hci_dev *hdev, bool debug)
{}
EXPORT_SYMBOL_GPL();

int btintel_read_version(struct hci_dev *hdev, struct intel_version *ver)
{}
EXPORT_SYMBOL_GPL();

int btintel_version_info_tlv(struct hci_dev *hdev,
			     struct intel_version_tlv *version)
{}
EXPORT_SYMBOL_GPL();

int btintel_parse_version_tlv(struct hci_dev *hdev,
			      struct intel_version_tlv *version,
			      struct sk_buff *skb)
{}
EXPORT_SYMBOL_GPL();

static int btintel_read_version_tlv(struct hci_dev *hdev,
				    struct intel_version_tlv *version)
{}

/* ------- REGMAP IBT SUPPORT ------- */

#define IBT_REG_MODE_8BIT
#define IBT_REG_MODE_16BIT
#define IBT_REG_MODE_32BIT

struct regmap_ibt_context {};

struct ibt_cp_reg_access {} __packed;

struct ibt_rp_reg_access {} __packed;

static int regmap_ibt_read(void *context, const void *addr, size_t reg_size,
			   void *val, size_t val_size)
{}

static int regmap_ibt_gather_write(void *context,
				   const void *addr, size_t reg_size,
				   const void *val, size_t val_size)
{}

static int regmap_ibt_write(void *context, const void *data, size_t count)
{}

static void regmap_ibt_free_context(void *context)
{}

static const struct regmap_bus regmap_ibt =;

/* Config is the same for all register regions */
static const struct regmap_config regmap_ibt_cfg =;

struct regmap *btintel_regmap_init(struct hci_dev *hdev, u16 opcode_read,
				   u16 opcode_write)
{}
EXPORT_SYMBOL_GPL();

int btintel_send_intel_reset(struct hci_dev *hdev, u32 boot_param)
{}
EXPORT_SYMBOL_GPL();

int btintel_read_boot_params(struct hci_dev *hdev,
			     struct intel_boot_params *params)
{}
EXPORT_SYMBOL_GPL();

static int btintel_sfi_rsa_header_secure_send(struct hci_dev *hdev,
					      const struct firmware *fw)
{}

static int btintel_sfi_ecdsa_header_secure_send(struct hci_dev *hdev,
						const struct firmware *fw)
{}

static int btintel_download_firmware_payload(struct hci_dev *hdev,
					     const struct firmware *fw,
					     size_t offset)
{}

static bool btintel_firmware_version(struct hci_dev *hdev,
				     u8 num, u8 ww, u8 yy,
				     const struct firmware *fw,
				     u32 *boot_addr)
{}

int btintel_download_firmware(struct hci_dev *hdev,
			      struct intel_version *ver,
			      const struct firmware *fw,
			      u32 *boot_param)
{}
EXPORT_SYMBOL_GPL();

static int btintel_download_fw_tlv(struct hci_dev *hdev,
				   struct intel_version_tlv *ver,
				   const struct firmware *fw, u32 *boot_param,
				   u8 hw_variant, u8 sbe_type)
{}

static void btintel_reset_to_bootloader(struct hci_dev *hdev)
{}

static int btintel_read_debug_features(struct hci_dev *hdev,
				       struct intel_debug_features *features)
{}

static int btintel_set_debug_features(struct hci_dev *hdev,
			       const struct intel_debug_features *features)
{}

static int btintel_reset_debug_features(struct hci_dev *hdev,
				 const struct intel_debug_features *features)
{}

int btintel_set_quality_report(struct hci_dev *hdev, bool enable)
{}
EXPORT_SYMBOL_GPL();

static void btintel_coredump(struct hci_dev *hdev)
{}

static void btintel_dmp_hdr(struct hci_dev *hdev, struct sk_buff *skb)
{}

static int btintel_register_devcoredump_support(struct hci_dev *hdev)
{}

static const struct firmware *btintel_legacy_rom_get_fw(struct hci_dev *hdev,
					       struct intel_version *ver)
{}

static int btintel_legacy_rom_patching(struct hci_dev *hdev,
				      const struct firmware *fw,
				      const u8 **fw_ptr, int *disable_patch)
{}

static int btintel_legacy_rom_setup(struct hci_dev *hdev,
				    struct intel_version *ver)
{}

static int btintel_download_wait(struct hci_dev *hdev, ktime_t calltime, int msec)
{}

static int btintel_boot_wait(struct hci_dev *hdev, ktime_t calltime, int msec)
{}

static int btintel_boot(struct hci_dev *hdev, u32 boot_addr)
{}

static int btintel_get_fw_name(struct intel_version *ver,
					     struct intel_boot_params *params,
					     char *fw_name, size_t len,
					     const char *suffix)
{}

static int btintel_download_fw(struct hci_dev *hdev,
					 struct intel_version *ver,
					 struct intel_boot_params *params,
					 u32 *boot_param)
{}

static int btintel_bootloader_setup(struct hci_dev *hdev,
				    struct intel_version *ver)
{}

static void btintel_get_fw_name_tlv(const struct intel_version_tlv *ver,
				    char *fw_name, size_t len,
				    const char *suffix)
{}

static void btintel_get_iml_tlv(const struct intel_version_tlv *ver,
				char *fw_name, size_t len,
				const char *suffix)
{}

static int btintel_prepare_fw_download_tlv(struct hci_dev *hdev,
					   struct intel_version_tlv *ver,
					   u32 *boot_param)
{}

static int btintel_get_codec_config_data(struct hci_dev *hdev,
					 __u8 link, struct bt_codec *codec,
					 __u8 *ven_len, __u8 **ven_data)
{}

static int btintel_get_data_path_id(struct hci_dev *hdev, __u8 *data_path_id)
{}

static int btintel_configure_offload(struct hci_dev *hdev)
{}

static void btintel_set_ppag(struct hci_dev *hdev, struct intel_version_tlv *ver)
{}

static int btintel_acpi_reset_method(struct hci_dev *hdev)
{}

static void btintel_set_dsm_reset_method(struct hci_dev *hdev,
					 struct intel_version_tlv *ver_tlv)
{}

#define BTINTEL_ISODATA_HANDLE_BASE

static u8 btintel_classify_pkt_type(struct hci_dev *hdev, struct sk_buff *skb)
{}

/*
 * UefiCnvCommonDSBR UEFI variable provides information from the OEM platforms
 * if they have replaced the BRI (Bluetooth Radio Interface) resistor to
 * overcome the potential STEP errors on their designs. Based on the
 * configauration, bluetooth firmware shall adjust the BRI response line drive
 * strength. The below structure represents DSBR data.
 * struct {
 *	u8 header;
 *	u32 dsbr;
 * } __packed;
 *
 * header - defines revision number of the structure
 * dsbr - defines drive strength BRI response
 *	bit0
 *		0 - instructs bluetooth firmware to use default values
 *		1 - instructs bluetooth firmware to override default values
 *	bit3:1
 *		Reserved
 *	bit7:4
 *		DSBR override values (only if bit0 is set. Default value is 0xF
 *	bit31:7
 *		Reserved
 * Expected values for dsbr field:
 *	1. 0xF1 - indicates that the resistor on board is 33 Ohm
 *	2. 0x00 or 0xB1 - indicates that the resistor on board is 10 Ohm
 *	3. Non existing UEFI variable or invalid (none of the above) - indicates
 *	   that the resistor on board is 10 Ohm
 * Even if uefi variable is not present, driver shall send 0xfc0a command to
 * firmware to use default values.
 *
 */
static int btintel_uefi_get_dsbr(u32 *dsbr_var)
{}

static int btintel_set_dsbr(struct hci_dev *hdev, struct intel_version_tlv *ver)
{}

int btintel_bootloader_setup_tlv(struct hci_dev *hdev,
				 struct intel_version_tlv *ver)
{}
EXPORT_SYMBOL_GPL();

void btintel_set_msft_opcode(struct hci_dev *hdev, u8 hw_variant)
{}
EXPORT_SYMBOL_GPL();

void btintel_print_fseq_info(struct hci_dev *hdev)
{}
EXPORT_SYMBOL_GPL();

static int btintel_setup_combined(struct hci_dev *hdev)
{}

int btintel_shutdown_combined(struct hci_dev *hdev)
{}
EXPORT_SYMBOL_GPL();

int btintel_configure_setup(struct hci_dev *hdev, const char *driver_name)
{}
EXPORT_SYMBOL_GPL();

static int btintel_diagnostics(struct hci_dev *hdev, struct sk_buff *skb)
{}

int btintel_recv_event(struct hci_dev *hdev, struct sk_buff *skb)
{}
EXPORT_SYMBOL_GPL();

void btintel_bootup(struct hci_dev *hdev, const void *ptr, unsigned int len)
{}
EXPORT_SYMBOL_GPL();

void btintel_secure_send_result(struct hci_dev *hdev,
				const void *ptr, unsigned int len)
{}
EXPORT_SYMBOL_GPL();

MODULE_AUTHOR();
MODULE_DESCRIPTION();
MODULE_VERSION();
MODULE_LICENSE();
MODULE_FIRMWARE();
MODULE_FIRMWARE();
MODULE_FIRMWARE();
MODULE_FIRMWARE();