aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/mediatek/mt76/mt7603/mcu.h
blob: 1bba369d5c8afe79f1187c55a5db0033bf163166 (plain) (blame)
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/* SPDX-License-Identifier: ISC */

#ifndef __MT7603_MCU_H
#define __MT7603_MCU_H

struct mt7603_mcu_txd {
	__le16 len;
	__le16 pq_id;

	u8 cid;
	u8 pkt_type;
	u8 set_query;
	u8 seq;

	u8 uc_d2b0_rev;
	u8 ext_cid;
	u8 uc_d2b2_rev;
	u8 ext_cid_ack;

	u32 au4_d3_to_d7_rev[5];
} __packed __aligned(4);

struct mt7603_mcu_rxd {
	__le16 len;
	__le16 pkt_type_id;

	u8 eid;
	u8 seq;
	__le16 __rsv;

	u8 ext_eid;
	u8 __rsv1[3];
};

#define MCU_PKT_ID		0xa0
#define MCU_PORT_QUEUE		0x8000
#define MCU_PORT_QUEUE_FW	0xc000

#define MCU_FIRMWARE_ADDRESS	0x100000

enum {
	MCU_Q_QUERY,
	MCU_Q_SET,
	MCU_Q_RESERVED,
	MCU_Q_NA
};

enum {
	MCU_CMD_TARGET_ADDRESS_LEN_REQ = 0x01,
	MCU_CMD_FW_START_REQ = 0x02,
	MCU_CMD_INIT_ACCESS_REG = 0x3,
	MCU_CMD_PATCH_START_REQ = 0x05,
	MCU_CMD_PATCH_FINISH_REQ = 0x07,
	MCU_CMD_PATCH_SEM_CONTROL = 0x10,
	MCU_CMD_HIF_LOOPBACK = 0x20,
	MCU_CMD_CH_PRIVILEGE = 0x20,
	MCU_CMD_ACCESS_REG = 0xC2,
	MCU_CMD_EXT_CID = 0xED,
	MCU_CMD_FW_SCATTER = 0xEE,
	MCU_CMD_RESTART_DL_REQ = 0xEF,
};

enum {
	MCU_EXT_CMD_RF_REG_ACCESS = 0x02,
	MCU_EXT_CMD_RF_TEST = 0x04,
	MCU_EXT_CMD_RADIO_ON_OFF_CTRL = 0x05,
	MCU_EXT_CMD_WIFI_RX_DISABLE = 0x06,
	MCU_EXT_CMD_PM_STATE_CTRL = 0x07,
	MCU_EXT_CMD_CHANNEL_SWITCH = 0x08,
	MCU_EXT_CMD_NIC_CAPABILITY = 0x09,
	MCU_EXT_CMD_PWR_SAVING = 0x0A,
	MCU_EXT_CMD_MULTIPLE_REG_ACCESS = 0x0E,
	MCU_EXT_CMD_AP_PWR_SAVING_CAPABILITY = 0xF,
	MCU_EXT_CMD_SEC_ADDREMOVE_KEY = 0x10,
	MCU_EXT_CMD_SET_TX_POWER_CTRL = 0x11,
	MCU_EXT_CMD_FW_LOG_2_HOST = 0x13,
	MCU_EXT_CMD_PS_RETRIEVE_START = 0x14,
	MCU_EXT_CMD_LED_CTRL = 0x17,
	MCU_EXT_CMD_PACKET_FILTER = 0x18,
	MCU_EXT_CMD_PWR_MGT_BIT_WIFI = 0x1B,
	MCU_EXT_CMD_EFUSE_BUFFER_MODE = 0x21,
	MCU_EXT_CMD_THERMAL_PROTECT = 0x23,
	MCU_EXT_CMD_EDCA_SET = 0x27,
	MCU_EXT_CMD_SLOT_TIME_SET = 0x28,
	MCU_EXT_CMD_CONFIG_INTERNAL_SETTING = 0x29,
	MCU_EXT_CMD_NOA_OFFLOAD_CTRL = 0x2B,
	MCU_EXT_CMD_GET_THEMAL_SENSOR = 0x2C,
	MCU_EXT_CMD_WAKEUP_OPTION = 0x2E,
	MCU_EXT_CMD_AC_QUEUE_CONTROL = 0x31,
	MCU_EXT_CMD_BCN_UPDATE = 0x33
};

enum {
	MCU_EXT_EVENT_CMD_RESULT = 0x0,
	MCU_EXT_EVENT_RF_REG_ACCESS = 0x2,
	MCU_EXT_EVENT_MULTI_CR_ACCESS = 0x0E,
	MCU_EXT_EVENT_FW_LOG_2_HOST = 0x13,
	MCU_EXT_EVENT_BEACON_LOSS = 0x1A,
	MCU_EXT_EVENT_THERMAL_PROTECT = 0x22,
	MCU_EXT_EVENT_BCN_UPDATE = 0x31,
};

static inline struct sk_buff *
mt7603_mcu_msg_alloc(const void *data, int len)
{
	return mt76_mcu_msg_alloc(data, sizeof(struct mt7603_mcu_txd),
				  len, 0);
}

#endif