1 /* SPDX-License-Identifier: ISC */
2 /* Copyright (C) 2021 MediaTek Inc. */
4 #define FIRMWARE_MT7622 "mediatek/mt7622pr2h.bin"
5 #define FIRMWARE_MT7663 "mediatek/mt7663pr2h.bin"
6 #define FIRMWARE_MT7668 "mediatek/mt7668pr2h.bin"
7 #define FIRMWARE_MT7961 "mediatek/BT_RAM_CODE_MT7961_1_2_hdr.bin"
8 #define FIRMWARE_MT7925 "mediatek/mt7925/BT_RAM_CODE_MT7925_1_1_hdr.bin"
10 #define HCI_EV_WMT 0xe4
11 #define HCI_WMT_MAX_EVENT_SIZE 64
13 #define BTMTK_WMT_REG_WRITE 0x1
14 #define BTMTK_WMT_REG_READ 0x2
16 #define MT7921_BTSYS_RST 0x70002610
17 #define MT7921_BTSYS_RST_WITH_GPIO BIT(7)
19 #define MT7921_PINMUX_0 0x70005050
20 #define MT7921_PINMUX_1 0x70005054
22 #define MT7921_DLSTATUS 0x7c053c10
23 #define BT_DL_STATE BIT(1)
25 #define MTK_COREDUMP_SIZE (1024 * 1000)
26 #define MTK_COREDUMP_END "coredump end"
27 #define MTK_COREDUMP_END_LEN (sizeof(MTK_COREDUMP_END))
28 #define MTK_COREDUMP_NUM 255
31 BTMTK_WMT_PATCH_DWNLD = 0x1,
33 BTMTK_WMT_WAKEUP = 0x3,
35 BTMTK_WMT_FUNC_CTRL = 0x6,
37 BTMTK_WMT_REGISTER = 0x8,
38 BTMTK_WMT_SEMAPHORE = 0x17,
43 BTMTK_WMT_PATCH_UNDONE,
44 BTMTK_WMT_PATCH_PROGRESS,
48 BTMTK_WMT_ON_PROGRESS,
51 struct btmtk_wmt_hdr {
58 struct btmtk_hci_wmt_cmd {
59 struct btmtk_wmt_hdr hdr;
63 struct btmtk_hci_wmt_evt {
64 struct hci_event_hdr hhdr;
65 struct btmtk_wmt_hdr whdr;
68 struct btmtk_hci_wmt_evt_funcc {
69 struct btmtk_hci_wmt_evt hwhdr;
73 struct btmtk_hci_wmt_evt_reg {
74 struct btmtk_hci_wmt_evt hwhdr;
81 struct btmtk_tci_sleep {
99 u8 transmit_format_config;
100 u8 channel_format_config;
101 u8 channel_select_config;
104 struct reg_read_cmd {
111 struct reg_write_cmd {
120 struct btmtk_hci_wmt_params {
128 typedef int (*btmtk_reset_sync_func_t)(struct hci_dev *, void *);
130 struct btmtk_coredump_info {
131 const char *driver_name;
137 struct btmediatek_data {
139 btmtk_reset_sync_func_t reset_sync;
140 struct btmtk_coredump_info cd_info;
143 typedef int (*wmt_cmd_sync_func_t)(struct hci_dev *,
144 struct btmtk_hci_wmt_params *);
146 #if IS_ENABLED(CONFIG_BT_MTK)
148 int btmtk_set_bdaddr(struct hci_dev *hdev, const bdaddr_t *bdaddr);
150 int btmtk_setup_firmware_79xx(struct hci_dev *hdev, const char *fwname,
151 wmt_cmd_sync_func_t wmt_cmd_sync);
153 int btmtk_setup_firmware(struct hci_dev *hdev, const char *fwname,
154 wmt_cmd_sync_func_t wmt_cmd_sync);
156 void btmtk_reset_sync(struct hci_dev *hdev);
158 int btmtk_register_coredump(struct hci_dev *hdev, const char *name,
161 int btmtk_process_coredump(struct hci_dev *hdev, struct sk_buff *skb);
164 static inline int btmtk_set_bdaddr(struct hci_dev *hdev,
165 const bdaddr_t *bdaddr)
170 static int btmtk_setup_firmware_79xx(struct hci_dev *hdev, const char *fwname,
171 wmt_cmd_sync_func_t wmt_cmd_sync)
176 static int btmtk_setup_firmware(struct hci_dev *hdev, const char *fwname,
177 wmt_cmd_sync_func_t wmt_cmd_sync)
182 static void btmtk_reset_sync(struct hci_dev *hdev)
186 static int btmtk_register_coredump(struct hci_dev *hdev, const char *name,
192 static int btmtk_process_coredump(struct hci_dev *hdev, struct sk_buff *skb)