Path: blob/master/drivers/net/wireless/realtek/rtw88/fw.h
25924 views
/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */1/* Copyright(c) 2018-2019 Realtek Corporation2*/34#ifndef __RTW_FW_H_5#define __RTW_FW_H_67#define H2C_PKT_SIZE 328#define H2C_PKT_HDR_SIZE 8910/* FW bin information */11#define FW_HDR_SIZE 6412#define FW_HDR_CHKSUM_SIZE 81314#define FW_NLO_INFO_CHECK_SIZE 41516#define FIFO_PAGE_SIZE_SHIFT 1217#define FIFO_PAGE_SIZE 409618#define FIFO_DUMP_ADDR 0x80001920#define DLFW_PAGE_SIZE_SHIFT_LEGACY 1221#define DLFW_PAGE_SIZE_LEGACY 0x100022#define DLFW_BLK_SIZE_SHIFT_LEGACY 223#define DLFW_BLK_SIZE_LEGACY 424#define FW_START_ADDR_LEGACY 0x10002526#define BCN_LOSS_CNT 1027#define BCN_FILTER_NOTIFY_SIGNAL_CHANGE 028#define BCN_FILTER_CONNECTION_LOSS 129#define BCN_FILTER_CONNECTED 230#define BCN_FILTER_NOTIFY_BEACON_LOSS 331#define RTW_DEFAULT_CQM_THOLD -7032#define RTW_DEFAULT_CQM_HYST 43334#define SCAN_NOTIFY_TIMEOUT msecs_to_jiffies(10)3536#define RTW_CHANNEL_TIME 4537#define RTW_OFF_CHAN_TIME 10038#define RTW_PASS_CHAN_TIME 10539#define RTW_DFS_CHAN_TIME 2040#define RTW_CH_INFO_SIZE 441#define RTW_EX_CH_INFO_SIZE 342#define RTW_EX_CH_INFO_HDR_SIZE 243#define RTW_SCAN_WIDTH 044#define RTW_PRI_CH_IDX 145#define RTW_OLD_PROBE_PG_CNT 246#define RTW_PROBE_PG_CNT 44748#define RTW_DEBUG_DUMP_TIMES 104950enum rtw_c2h_cmd_id {51C2H_CCX_TX_RPT = 0x03,52C2H_BT_INFO = 0x09,53C2H_BT_MP_INFO = 0x0b,54C2H_BT_HID_INFO = 0x45,55C2H_RA_RPT = 0x0c,56C2H_HW_FEATURE_REPORT = 0x19,57C2H_WLAN_INFO = 0x27,58C2H_WLAN_RFON = 0x32,59C2H_BCN_FILTER_NOTIFY = 0x36,60C2H_ADAPTIVITY = 0x37,61C2H_SCAN_RESULT = 0x38,62C2H_HW_FEATURE_DUMP = 0xfd,63C2H_HALMAC = 0xff,64};6566enum rtw_c2h_cmd_id_ext {67C2H_SCAN_STATUS_RPT = 0x3,68C2H_CCX_RPT = 0x0f,69C2H_CHAN_SWITCH = 0x22,70};7172struct rtw_c2h_cmd {73u8 id;74u8 seq;75u8 payload[];76} __packed;7778struct rtw_c2h_adaptivity {79u8 density;80u8 igi;81u8 l2h_th_init;82u8 l2h;83u8 h2l;84u8 option;85} __packed;8687struct rtw_c2h_ra_rpt {88u8 rate_sgi;89u8 mac_id;90u8 byte2;91u8 status;92u8 byte4;93u8 ra_ratio;94u8 bw;95} __packed;9697#define RTW_C2H_RA_RPT_RATE GENMASK(6, 0)98#define RTW_C2H_RA_RPT_SGI BIT(7)99100struct rtw_h2c_register {101u32 w0;102u32 w1;103} __packed;104105#define RTW_H2C_W0_CMDID GENMASK(7, 0)106107/* H2C_CMD_DEFAULT_PORT command */108#define RTW_H2C_DEFAULT_PORT_W0_PORTID GENMASK(15, 8)109#define RTW_H2C_DEFAULT_PORT_W0_MACID GENMASK(23, 16)110111struct rtw_h2c_cmd {112__le32 msg;113__le32 msg_ext;114} __packed;115116enum rtw_rsvd_packet_type {117RSVD_BEACON,118RSVD_DUMMY,119RSVD_PS_POLL,120RSVD_PROBE_RESP,121RSVD_NULL,122RSVD_QOS_NULL,123RSVD_LPS_PG_DPK,124RSVD_LPS_PG_INFO,125RSVD_PROBE_REQ,126RSVD_NLO_INFO,127RSVD_CH_INFO,128};129130enum rtw_fw_rf_type {131FW_RF_1T2R = 0,132FW_RF_2T4R = 1,133FW_RF_2T2R = 2,134FW_RF_2T3R = 3,135FW_RF_1T1R = 4,136FW_RF_2T2R_GREEN = 5,137FW_RF_3T3R = 6,138FW_RF_3T4R = 7,139FW_RF_4T4R = 8,140FW_RF_MAX_TYPE = 0xF,141};142143enum rtw_fw_feature {144FW_FEATURE_SIG = BIT(0),145FW_FEATURE_LPS_C2H = BIT(1),146FW_FEATURE_LCLK = BIT(2),147FW_FEATURE_PG = BIT(3),148FW_FEATURE_TX_WAKE = BIT(4),149FW_FEATURE_BCN_FILTER = BIT(5),150FW_FEATURE_NOTIFY_SCAN = BIT(6),151FW_FEATURE_ADAPTIVITY = BIT(7),152FW_FEATURE_SCAN_OFFLOAD = BIT(8),153FW_FEATURE_MAX = BIT(31),154};155156enum rtw_fw_feature_ext {157FW_FEATURE_EXT_OLD_PAGE_NUM = BIT(0),158};159160enum rtw_beacon_filter_offload_mode {161BCN_FILTER_OFFLOAD_MODE_0 = 0,162BCN_FILTER_OFFLOAD_MODE_1,163BCN_FILTER_OFFLOAD_MODE_2,164BCN_FILTER_OFFLOAD_MODE_3,165166BCN_FILTER_OFFLOAD_MODE_DEFAULT = BCN_FILTER_OFFLOAD_MODE_0,167};168169struct rtw_coex_info_req {170u8 seq;171u8 op_code;172u8 para1;173u8 para2;174u8 para3;175};176177struct rtw_iqk_para {178u8 clear;179u8 segment_iqk;180};181182struct rtw_lps_pg_dpk_hdr {183u16 dpk_path_ok;184u8 dpk_txagc[2];185u16 dpk_gs[2];186u32 coef[2][20];187u8 dpk_ch;188} __packed;189190struct rtw_lps_pg_info_hdr {191u8 macid;192u8 mbssid;193u8 pattern_count;194u8 mu_tab_group_id;195u8 sec_cam_count;196u8 tx_bu_page_count;197u16 rsvd;198u8 sec_cam[MAX_PG_CAM_BACKUP_NUM];199} __packed;200201struct rtw_rsvd_page {202/* associated with each vif */203struct list_head vif_list;204struct rtw_vif *rtwvif;205206/* associated when build rsvd page */207struct list_head build_list;208209struct sk_buff *skb;210enum rtw_rsvd_packet_type type;211u8 page;212u16 tim_offset;213bool add_txdesc;214struct cfg80211_ssid *ssid;215u16 probe_req_size;216};217218enum rtw_keep_alive_pkt_type {219KEEP_ALIVE_NULL_PKT = 0,220KEEP_ALIVE_ARP_RSP = 1,221};222223struct rtw_nlo_info_hdr {224u8 nlo_count;225u8 hidden_ap_count;226u8 rsvd1[2];227u8 pattern_check[FW_NLO_INFO_CHECK_SIZE];228u8 rsvd2[8];229u8 ssid_len[16];230u8 chiper[16];231u8 rsvd3[16];232u8 location[8];233} __packed;234235enum rtw_packet_type {236RTW_PACKET_PROBE_REQ = 0x00,237238RTW_PACKET_UNDEFINE = 0x7FFFFFFF,239};240241struct rtw_fw_wow_keep_alive_para {242bool adopt;243u8 pkt_type;244u8 period; /* unit: sec */245};246247struct rtw_fw_wow_disconnect_para {248bool adopt;249u8 period; /* unit: sec */250u8 retry_count;251};252253enum rtw_channel_type {254RTW_CHANNEL_PASSIVE,255RTW_CHANNEL_ACTIVE,256RTW_CHANNEL_RADAR,257};258259enum rtw_scan_extra_id {260RTW_SCAN_EXTRA_ID_DFS,261};262263enum rtw_scan_extra_info {264RTW_SCAN_EXTRA_ACTION_SCAN,265};266267enum rtw_scan_report_code {268RTW_SCAN_REPORT_SUCCESS = 0x00,269RTW_SCAN_REPORT_ERR_PHYDM = 0x01,270RTW_SCAN_REPORT_ERR_ID = 0x02,271RTW_SCAN_REPORT_ERR_TX = 0x03,272RTW_SCAN_REPORT_CANCELED = 0x10,273RTW_SCAN_REPORT_CANCELED_EXT = 0x11,274RTW_SCAN_REPORT_FW_DISABLED = 0xF0,275};276277enum rtw_scan_notify_id {278RTW_SCAN_NOTIFY_ID_PRESWITCH = 0x00,279RTW_SCAN_NOTIFY_ID_POSTSWITCH = 0x01,280RTW_SCAN_NOTIFY_ID_PROBE_PRETX = 0x02,281RTW_SCAN_NOTIFY_ID_PROBE_ISSUETX = 0x03,282RTW_SCAN_NOTIFY_ID_NULL0_PRETX = 0x04,283RTW_SCAN_NOTIFY_ID_NULL0_ISSUETX = 0x05,284RTW_SCAN_NOTIFY_ID_NULL0_POSTTX = 0x06,285RTW_SCAN_NOTIFY_ID_NULL1_PRETX = 0x07,286RTW_SCAN_NOTIFY_ID_NULL1_ISSUETX = 0x08,287RTW_SCAN_NOTIFY_ID_NULL1_POSTTX = 0x09,288RTW_SCAN_NOTIFY_ID_DWELLEXT = 0x0A,289};290291enum rtw_scan_notify_status {292RTW_SCAN_NOTIFY_STATUS_SUCCESS = 0x00,293RTW_SCAN_NOTIFY_STATUS_FAILURE = 0x01,294RTW_SCAN_NOTIFY_STATUS_RESOURCE = 0x02,295RTW_SCAN_NOTIFY_STATUS_TIMEOUT = 0x03,296};297298struct rtw_ch_switch_option {299u8 periodic_option;300u32 tsf_high;301u32 tsf_low;302u8 dest_ch_en;303u8 absolute_time_en;304u8 dest_ch;305u8 normal_period;306u8 normal_period_sel;307u8 normal_cycle;308u8 slow_period;309u8 slow_period_sel;310u8 nlo_en;311bool switch_en;312bool back_op_en;313};314315struct rtw_fw_hdr {316__le16 signature;317u8 category;318u8 function;319__le16 version; /* 0x04 */320u8 subversion;321u8 subindex;322__le32 rsvd; /* 0x08 */323__le32 feature; /* 0x0C */324u8 month; /* 0x10 */325u8 day;326u8 hour;327u8 min;328__le16 year; /* 0x14 */329__le16 rsvd3;330u8 mem_usage; /* 0x18 */331u8 rsvd4[3];332__le16 h2c_fmt_ver; /* 0x1C */333__le16 rsvd5;334__le32 dmem_addr; /* 0x20 */335__le32 dmem_size;336__le32 rsvd6;337__le32 rsvd7;338__le32 imem_size; /* 0x30 */339__le32 emem_size;340__le32 emem_addr;341__le32 imem_addr;342} __packed;343344struct rtw_fw_hdr_legacy {345__le16 signature;346u8 category;347u8 function;348__le16 version; /* 0x04 */349u8 subversion1;350u8 subversion2;351u8 month; /* 0x08 */352u8 day;353u8 hour;354u8 minute;355__le16 size;356__le16 rsvd2;357__le32 idx; /* 0x10 */358__le32 rsvd3;359__le32 rsvd4; /* 0x18 */360__le32 rsvd5;361} __packed;362363#define RTW_FW_VER_CODE(ver, sub_ver, idx) \364(((ver) << 16) | ((sub_ver) << 8) | (idx))365#define RTW_FW_SUIT_VER_CODE(s) \366RTW_FW_VER_CODE((s).version, (s).sub_version, (s).sub_index)367368/* C2H */369#define GET_CCX_REPORT_SEQNUM_V0(c2h_payload) (c2h_payload[6] & 0xfc)370#define GET_CCX_REPORT_STATUS_V0(c2h_payload) (c2h_payload[0] & 0xc0)371#define GET_CCX_REPORT_SEQNUM_V1(c2h_payload) (c2h_payload[8] & 0xfc)372#define GET_CCX_REPORT_STATUS_V1(c2h_payload) (c2h_payload[9] & 0xc0)373374#define GET_SCAN_REPORT_RETURN_CODE(c2h_payload) (c2h_payload[2] & 0xff)375376#define GET_CHAN_SWITCH_CENTRAL_CH(c2h_payload) (c2h_payload[2])377#define GET_CHAN_SWITCH_ID(c2h_payload) (c2h_payload[3])378#define GET_CHAN_SWITCH_STATUS(c2h_payload) (c2h_payload[4])379380#define GET_BCN_FILTER_NOTIFY_TYPE(c2h_payload) (c2h_payload[1] & 0xf)381#define GET_BCN_FILTER_NOTIFY_EVENT(c2h_payload) (c2h_payload[1] & 0x10)382#define GET_BCN_FILTER_NOTIFY_RSSI(c2h_payload) (c2h_payload[2] - 100)383384/* PKT H2C */385#define H2C_PKT_CMD_ID 0xFF386#define H2C_PKT_CATEGORY 0x01387388#define H2C_PKT_GENERAL_INFO 0x0D389#define H2C_PKT_PHYDM_INFO 0x11390#define H2C_PKT_IQK 0x0E391392#define H2C_PKT_CH_SWITCH 0x02393#define H2C_PKT_UPDATE_PKT 0x0C394#define H2C_PKT_SCAN_OFFLOAD 0x19395396#define H2C_PKT_CH_SWITCH_LEN 0x20397#define H2C_PKT_UPDATE_PKT_LEN 0x4398399#define SET_PKT_H2C_CATEGORY(h2c_pkt, value) \400le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(6, 0))401#define SET_PKT_H2C_CMD_ID(h2c_pkt, value) \402le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))403#define SET_PKT_H2C_SUB_CMD_ID(h2c_pkt, value) \404le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 16))405#define SET_PKT_H2C_TOTAL_LEN(h2c_pkt, value) \406le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(15, 0))407408static inline void rtw_h2c_pkt_set_header(u8 *h2c_pkt, u8 sub_id)409{410SET_PKT_H2C_CATEGORY(h2c_pkt, H2C_PKT_CATEGORY);411SET_PKT_H2C_CMD_ID(h2c_pkt, H2C_PKT_CMD_ID);412SET_PKT_H2C_SUB_CMD_ID(h2c_pkt, sub_id);413}414415#define FW_OFFLOAD_H2C_SET_SEQ_NUM(h2c_pkt, value) \416le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(31, 16))417#define GENERAL_INFO_SET_FW_TX_BOUNDARY(h2c_pkt, value) \418le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(23, 16))419420#define PHYDM_INFO_SET_REF_TYPE(h2c_pkt, value) \421le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(7, 0))422#define PHYDM_INFO_SET_RF_TYPE(h2c_pkt, value) \423le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(15, 8))424#define PHYDM_INFO_SET_CUT_VER(h2c_pkt, value) \425le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(23, 16))426#define PHYDM_INFO_SET_RX_ANT_STATUS(h2c_pkt, value) \427le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(27, 24))428#define PHYDM_INFO_SET_TX_ANT_STATUS(h2c_pkt, value) \429le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(31, 28))430#define IQK_SET_CLEAR(h2c_pkt, value) \431le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(0))432#define IQK_SET_SEGMENT_IQK(h2c_pkt, value) \433le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(1))434435#define CHSW_INFO_SET_CH(pkt, value) \436le32p_replace_bits((__le32 *)(pkt) + 0x00, value, GENMASK(7, 0))437#define CHSW_INFO_SET_PRI_CH_IDX(pkt, value) \438le32p_replace_bits((__le32 *)(pkt) + 0x00, value, GENMASK(11, 8))439#define CHSW_INFO_SET_BW(pkt, value) \440le32p_replace_bits((__le32 *)(pkt) + 0x00, value, GENMASK(15, 12))441#define CHSW_INFO_SET_TIMEOUT(pkt, value) \442le32p_replace_bits((__le32 *)(pkt) + 0x00, value, GENMASK(23, 16))443#define CHSW_INFO_SET_ACTION_ID(pkt, value) \444le32p_replace_bits((__le32 *)(pkt) + 0x00, value, GENMASK(30, 24))445#define CHSW_INFO_SET_EXTRA_INFO(pkt, value) \446le32p_replace_bits((__le32 *)(pkt) + 0x00, value, BIT(31))447448#define CH_INFO_SET_CH(pkt, value) \449u8p_replace_bits((u8 *)(pkt) + 0x00, value, GENMASK(7, 0))450#define CH_INFO_SET_PRI_CH_IDX(pkt, value) \451u8p_replace_bits((u8 *)(pkt) + 0x01, value, GENMASK(3, 0))452#define CH_INFO_SET_BW(pkt, value) \453u8p_replace_bits((u8 *)(pkt) + 0x01, value, GENMASK(7, 4))454#define CH_INFO_SET_TIMEOUT(pkt, value) \455u8p_replace_bits((u8 *)(pkt) + 0x02, value, GENMASK(7, 0))456#define CH_INFO_SET_ACTION_ID(pkt, value) \457u8p_replace_bits((u8 *)(pkt) + 0x03, value, GENMASK(6, 0))458#define CH_INFO_SET_EXTRA_INFO(pkt, value) \459u8p_replace_bits((u8 *)(pkt) + 0x03, value, BIT(7))460461#define EXTRA_CH_INFO_SET_ID(pkt, value) \462u8p_replace_bits((u8 *)(pkt) + 0x04, value, GENMASK(6, 0))463#define EXTRA_CH_INFO_SET_INFO(pkt, value) \464u8p_replace_bits((u8 *)(pkt) + 0x04, value, BIT(7))465#define EXTRA_CH_INFO_SET_SIZE(pkt, value) \466u8p_replace_bits((u8 *)(pkt) + 0x05, value, GENMASK(7, 0))467#define EXTRA_CH_INFO_SET_DFS_EXT_TIME(pkt, value) \468u8p_replace_bits((u8 *)(pkt) + 0x06, value, GENMASK(7, 0))469470#define UPDATE_PKT_SET_SIZE(h2c_pkt, value) \471le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(15, 0))472#define UPDATE_PKT_SET_PKT_ID(h2c_pkt, value) \473le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(23, 16))474#define UPDATE_PKT_SET_LOCATION(h2c_pkt, value) \475le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(31, 24))476477#define CH_SWITCH_SET_START(h2c_pkt, value) \478le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(0))479#define CH_SWITCH_SET_DEST_CH_EN(h2c_pkt, value) \480le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(1))481#define CH_SWITCH_SET_ABSOLUTE_TIME(h2c_pkt, value) \482le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(2))483#define CH_SWITCH_SET_PERIODIC_OPT(h2c_pkt, value) \484le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(4, 3))485#define CH_SWITCH_SET_SCAN_MODE(h2c_pkt, value) \486le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(5))487#define CH_SWITCH_SET_BACK_OP_EN(h2c_pkt, value) \488le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(6))489#define CH_SWITCH_SET_INFO_LOC(h2c_pkt, value) \490le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(15, 8))491#define CH_SWITCH_SET_CH_NUM(h2c_pkt, value) \492le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(23, 16))493#define CH_SWITCH_SET_PRI_CH_IDX(h2c_pkt, value) \494le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(27, 24))495#define CH_SWITCH_SET_DEST_BW(h2c_pkt, value) \496le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(31, 28))497#define CH_SWITCH_SET_DEST_CH(h2c_pkt, value) \498le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(7, 0))499#define CH_SWITCH_SET_NORMAL_PERIOD(h2c_pkt, value) \500le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(13, 8))501#define CH_SWITCH_SET_NORMAL_PERIOD_SEL(h2c_pkt, value) \502le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(15, 14))503#define CH_SWITCH_SET_SLOW_PERIOD(h2c_pkt, value) \504le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(21, 16))505#define CH_SWITCH_SET_SLOW_PERIOD_SEL(h2c_pkt, value) \506le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(23, 22))507#define CH_SWITCH_SET_NORMAL_CYCLE(h2c_pkt, value) \508le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(31, 24))509#define CH_SWITCH_SET_TSF_HIGH(h2c_pkt, value) \510le32p_replace_bits((__le32 *)(h2c_pkt) + 0x04, value, GENMASK(31, 0))511#define CH_SWITCH_SET_TSF_LOW(h2c_pkt, value) \512le32p_replace_bits((__le32 *)(h2c_pkt) + 0x05, value, GENMASK(31, 0))513#define CH_SWITCH_SET_INFO_SIZE(h2c_pkt, value) \514le32p_replace_bits((__le32 *)(h2c_pkt) + 0x06, value, GENMASK(15, 0))515516#define SCAN_OFFLOAD_SET_START(h2c_pkt, value) \517le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(0))518#define SCAN_OFFLOAD_SET_BACK_OP_EN(h2c_pkt, value) \519le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(1))520#define SCAN_OFFLOAD_SET_RANDOM_SEQ_EN(h2c_pkt, value) \521le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(2))522#define SCAN_OFFLOAD_SET_NO_CCK_EN(h2c_pkt, value) \523le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(3))524#define SCAN_OFFLOAD_SET_VERBOSE(h2c_pkt, value) \525le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, BIT(4))526#define SCAN_OFFLOAD_SET_CH_NUM(h2c_pkt, value) \527le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(15, 8))528#define SCAN_OFFLOAD_SET_CH_INFO_SIZE(h2c_pkt, value) \529le32p_replace_bits((__le32 *)(h2c_pkt) + 0x02, value, GENMASK(31, 16))530#define SCAN_OFFLOAD_SET_CH_INFO_LOC(h2c_pkt, value) \531le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(7, 0))532#define SCAN_OFFLOAD_SET_OP_CH(h2c_pkt, value) \533le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(15, 8))534#define SCAN_OFFLOAD_SET_OP_PRI_CH_IDX(h2c_pkt, value) \535le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(19, 16))536#define SCAN_OFFLOAD_SET_OP_BW(h2c_pkt, value) \537le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(23, 20))538#define SCAN_OFFLOAD_SET_OP_PORT_ID(h2c_pkt, value) \539le32p_replace_bits((__le32 *)(h2c_pkt) + 0x03, value, GENMASK(26, 24))540#define SCAN_OFFLOAD_SET_OP_DWELL_TIME(h2c_pkt, value) \541le32p_replace_bits((__le32 *)(h2c_pkt) + 0x04, value, GENMASK(15, 0))542#define SCAN_OFFLOAD_SET_OP_GAP_TIME(h2c_pkt, value) \543le32p_replace_bits((__le32 *)(h2c_pkt) + 0x04, value, GENMASK(31, 16))544#define SCAN_OFFLOAD_SET_MODE(h2c_pkt, value) \545le32p_replace_bits((__le32 *)(h2c_pkt) + 0x05, value, GENMASK(3, 0))546#define SCAN_OFFLOAD_SET_SSID_NUM(h2c_pkt, value) \547le32p_replace_bits((__le32 *)(h2c_pkt) + 0x05, value, GENMASK(7, 4))548#define SCAN_OFFLOAD_SET_PKT_LOC(h2c_pkt, value) \549le32p_replace_bits((__le32 *)(h2c_pkt) + 0x05, value, GENMASK(15, 8))550551/* Command H2C */552#define H2C_CMD_RSVD_PAGE 0x0553#define H2C_CMD_MEDIA_STATUS_RPT 0x01554#define H2C_CMD_SET_PWR_MODE 0x20555#define H2C_CMD_LPS_PG_INFO 0x2b556#define H2C_CMD_DEFAULT_PORT 0x2c557#define H2C_CMD_RA_INFO 0x40558#define H2C_CMD_RSSI_MONITOR 0x42559#define H2C_CMD_RA_INFO_HI 0x46560#define H2C_CMD_BCN_FILTER_OFFLOAD_P0 0x56561#define H2C_CMD_BCN_FILTER_OFFLOAD_P1 0x57562#define H2C_CMD_WL_PHY_INFO 0x58563#define H2C_CMD_SCAN 0x59564#define H2C_CMD_ADAPTIVITY 0x5A565566#define H2C_CMD_COEX_TDMA_TYPE 0x60567#define H2C_CMD_QUERY_BT_INFO 0x61568#define H2C_CMD_FORCE_BT_TX_POWER 0x62569#define H2C_CMD_IGNORE_WLAN_ACTION 0x63570#define H2C_CMD_WL_CH_INFO 0x66571#define H2C_CMD_QUERY_BT_MP_INFO 0x67572#define H2C_CMD_BT_WIFI_CONTROL 0x69573#define H2C_CMD_WIFI_CALIBRATION 0x6d574#define H2C_CMD_QUERY_BT_HID_INFO 0x73575576#define H2C_CMD_KEEP_ALIVE 0x03577#define H2C_CMD_DISCONNECT_DECISION 0x04578#define H2C_CMD_WOWLAN 0x80579#define H2C_CMD_REMOTE_WAKE_CTRL 0x81580#define H2C_CMD_AOAC_GLOBAL_INFO 0x82581#define H2C_CMD_NLO_INFO 0x8C582583#define H2C_CMD_RECOVER_BT_DEV 0xD1584585#define SET_H2C_CMD_ID_CLASS(h2c_pkt, value) \586le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(7, 0))587588#define MEDIA_STATUS_RPT_SET_OP_MODE(h2c_pkt, value) \589le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))590#define MEDIA_STATUS_RPT_SET_MACID(h2c_pkt, value) \591le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))592593#define SET_WL_PHY_INFO_TX_TP(h2c_pkt, value) \594le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(17, 8))595#define SET_WL_PHY_INFO_RX_TP(h2c_pkt, value) \596le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(27, 18))597#define SET_WL_PHY_INFO_TX_RATE_DESC(h2c_pkt, value) \598le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(7, 0))599#define SET_WL_PHY_INFO_RX_RATE_DESC(h2c_pkt, value) \600le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(15, 8))601#define SET_WL_PHY_INFO_RX_EVM(h2c_pkt, value) \602le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(23, 16))603#define SET_BCN_FILTER_OFFLOAD_P1_MACID(h2c_pkt, value) \604le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))605#define SET_BCN_FILTER_OFFLOAD_P1_ENABLE(h2c_pkt, value) \606le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(16))607#define SET_BCN_FILTER_OFFLOAD_P1_HYST(h2c_pkt, value) \608le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(20, 17))609#define SET_BCN_FILTER_OFFLOAD_P1_OFFLOAD_MODE(h2c_pkt, value) \610le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 21))611#define SET_BCN_FILTER_OFFLOAD_P1_THRESHOLD(h2c_pkt, value) \612le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))613#define SET_BCN_FILTER_OFFLOAD_P1_BCN_LOSS_CNT(h2c_pkt, value) \614le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(3, 0))615#define SET_BCN_FILTER_OFFLOAD_P1_BCN_INTERVAL(h2c_pkt, value) \616le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(13, 4))617618#define SET_SCAN_START(h2c_pkt, value) \619le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))620621#define SET_ADAPTIVITY_MODE(h2c_pkt, value) \622le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(11, 8))623#define SET_ADAPTIVITY_OPTION(h2c_pkt, value) \624le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 12))625#define SET_ADAPTIVITY_IGI(h2c_pkt, value) \626le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))627#define SET_ADAPTIVITY_L2H(h2c_pkt, value) \628le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))629#define SET_ADAPTIVITY_DENSITY(h2c_pkt, value) \630le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(7, 0))631632#define SET_PWR_MODE_SET_MODE(h2c_pkt, value) \633le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(14, 8))634#define SET_PWR_MODE_SET_RLBM(h2c_pkt, value) \635le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(19, 16))636#define SET_PWR_MODE_SET_SMART_PS(h2c_pkt, value) \637le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 20))638#define SET_PWR_MODE_SET_AWAKE_INTERVAL(h2c_pkt, value) \639le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))640#define SET_PWR_MODE_SET_PORT_ID(h2c_pkt, value) \641le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(7, 5))642#define SET_PWR_MODE_SET_PWR_STATE(h2c_pkt, value) \643le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(15, 8))644#define LPS_PG_INFO_LOC(h2c_pkt, value) \645le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))646#define LPS_PG_DPK_LOC(h2c_pkt, value) \647le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))648#define LPS_PG_SEC_CAM_EN(h2c_pkt, value) \649le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))650#define LPS_PG_PATTERN_CAM_EN(h2c_pkt, value) \651le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(10))652#define SET_RSSI_INFO_MACID(h2c_pkt, value) \653le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))654#define SET_RSSI_INFO_RSSI(h2c_pkt, value) \655le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))656#define SET_RSSI_INFO_STBC(h2c_pkt, value) \657le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, BIT(1))658#define SET_RA_INFO_MACID(h2c_pkt, value) \659le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))660#define SET_RA_INFO_RATE_ID(h2c_pkt, value) \661le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(20, 16))662#define SET_RA_INFO_INIT_RA_LVL(h2c_pkt, value) \663le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(22, 21))664#define SET_RA_INFO_SGI_EN(h2c_pkt, value) \665le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(23))666#define SET_RA_INFO_BW_MODE(h2c_pkt, value) \667le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(25, 24))668#define SET_RA_INFO_LDPC(h2c_pkt, value) \669le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(26))670#define SET_RA_INFO_NO_UPDATE(h2c_pkt, value) \671le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(27))672#define SET_RA_INFO_VHT_EN(h2c_pkt, value) \673le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(29, 28))674#define SET_RA_INFO_DIS_PT(h2c_pkt, value) \675le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(30))676#define SET_RA_INFO_RA_MASK0(h2c_pkt, value) \677le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(7, 0))678#define SET_RA_INFO_RA_MASK1(h2c_pkt, value) \679le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(15, 8))680#define SET_RA_INFO_RA_MASK2(h2c_pkt, value) \681le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(23, 16))682#define SET_RA_INFO_RA_MASK3(h2c_pkt, value) \683le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(31, 24))684#define SET_QUERY_BT_INFO(h2c_pkt, value) \685le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))686#define SET_WL_CH_INFO_LINK(h2c_pkt, value) \687le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))688#define SET_WL_CH_INFO_CHNL(h2c_pkt, value) \689le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))690#define SET_WL_CH_INFO_BW(h2c_pkt, value) \691le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))692#define SET_BT_MP_INFO_SEQ(h2c_pkt, value) \693le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 12))694#define SET_BT_MP_INFO_OP_CODE(h2c_pkt, value) \695le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))696#define SET_BT_MP_INFO_PARA1(h2c_pkt, value) \697le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))698#define SET_BT_MP_INFO_PARA2(h2c_pkt, value) \699le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(7, 0))700#define SET_BT_MP_INFO_PARA3(h2c_pkt, value) \701le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(15, 8))702#define SET_BT_TX_POWER_INDEX(h2c_pkt, value) \703le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))704#define SET_IGNORE_WLAN_ACTION_EN(h2c_pkt, value) \705le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))706#define SET_COEX_TDMA_TYPE_PARA1(h2c_pkt, value) \707le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))708#define SET_COEX_TDMA_TYPE_PARA2(h2c_pkt, value) \709le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))710#define SET_COEX_TDMA_TYPE_PARA3(h2c_pkt, value) \711le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))712#define SET_COEX_TDMA_TYPE_PARA4(h2c_pkt, value) \713le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(7, 0))714#define SET_COEX_TDMA_TYPE_PARA5(h2c_pkt, value) \715le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(15, 8))716#define SET_BT_WIFI_CONTROL_OP_CODE(h2c_pkt, value) \717le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))718#define SET_BT_WIFI_CONTROL_DATA1(h2c_pkt, value) \719le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))720#define SET_BT_WIFI_CONTROL_DATA2(h2c_pkt, value) \721le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))722#define SET_BT_WIFI_CONTROL_DATA3(h2c_pkt, value) \723le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(7, 0))724#define SET_BT_WIFI_CONTROL_DATA4(h2c_pkt, value) \725le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(15, 8))726#define SET_BT_WIFI_CONTROL_DATA5(h2c_pkt, value) \727le32p_replace_bits((__le32 *)(h2c_pkt) + 0x01, value, GENMASK(23, 16))728729#define SET_COEX_QUERY_HID_INFO_SUBID(h2c_pkt, value) \730le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))731#define SET_COEX_QUERY_HID_INFO_DATA1(h2c_pkt, value) \732le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))733734#define SET_KEEP_ALIVE_ENABLE(h2c_pkt, value) \735le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))736#define SET_KEEP_ALIVE_ADOPT(h2c_pkt, value) \737le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(9))738#define SET_KEEP_ALIVE_PKT_TYPE(h2c_pkt, value) \739le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(10))740#define SET_KEEP_ALIVE_CHECK_PERIOD(h2c_pkt, value) \741le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))742743#define SET_DISCONNECT_DECISION_ENABLE(h2c_pkt, value) \744le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))745#define SET_DISCONNECT_DECISION_ADOPT(h2c_pkt, value) \746le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(9))747#define SET_DISCONNECT_DECISION_CHECK_PERIOD(h2c_pkt, value) \748le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))749#define SET_DISCONNECT_DECISION_TRY_PKT_NUM(h2c_pkt, value) \750le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(31, 24))751752#define SET_WOWLAN_FUNC_ENABLE(h2c_pkt, value) \753le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))754#define SET_WOWLAN_PATTERN_MATCH_ENABLE(h2c_pkt, value) \755le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(9))756#define SET_WOWLAN_MAGIC_PKT_ENABLE(h2c_pkt, value) \757le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(10))758#define SET_WOWLAN_UNICAST_PKT_ENABLE(h2c_pkt, value) \759le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(11))760#define SET_WOWLAN_REKEY_WAKEUP_ENABLE(h2c_pkt, value) \761le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(14))762#define SET_WOWLAN_DEAUTH_WAKEUP_ENABLE(h2c_pkt, value) \763le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(15))764765#define SET_REMOTE_WAKECTRL_ENABLE(h2c_pkt, value) \766le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))767#define SET_REMOTE_WAKE_CTRL_NLO_OFFLOAD_EN(h2c_pkt, value) \768le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(12))769770#define SET_AOAC_GLOBAL_INFO_PAIRWISE_ENC_ALG(h2c_pkt, value) \771le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(15, 8))772#define SET_AOAC_GLOBAL_INFO_GROUP_ENC_ALG(h2c_pkt, value) \773le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))774775#define SET_NLO_FUN_EN(h2c_pkt, value) \776le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))777#define SET_NLO_PS_32K(h2c_pkt, value) \778le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(9))779#define SET_NLO_IGNORE_SECURITY(h2c_pkt, value) \780le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(10))781#define SET_NLO_LOC_NLO_INFO(h2c_pkt, value) \782le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, GENMASK(23, 16))783784#define SET_RECOVER_BT_DEV_EN(h2c_pkt, value) \785le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))786787#define GET_FW_DUMP_LEN(_header) \788le32_get_bits(*((__le32 *)(_header) + 0x00), GENMASK(15, 0))789#define GET_FW_DUMP_SEQ(_header) \790le32_get_bits(*((__le32 *)(_header) + 0x00), GENMASK(22, 16))791#define GET_FW_DUMP_MORE(_header) \792le32_get_bits(*((__le32 *)(_header) + 0x00), BIT(23))793#define GET_FW_DUMP_VERSION(_header) \794le32_get_bits(*((__le32 *)(_header) + 0x00), GENMASK(31, 24))795#define GET_FW_DUMP_TLV_TYPE(_header) \796le32_get_bits(*((__le32 *)(_header) + 0x01), GENMASK(15, 0))797#define GET_FW_DUMP_TLV_LEN(_header) \798le32_get_bits(*((__le32 *)(_header) + 0x01), GENMASK(31, 16))799#define GET_FW_DUMP_TLV_VAL(_header) \800le32_get_bits(*((__le32 *)(_header) + 0x02), GENMASK(31, 0))801802#define RFK_SET_INFORM_START(h2c_pkt, value) \803le32p_replace_bits((__le32 *)(h2c_pkt) + 0x00, value, BIT(8))804static inline struct rtw_c2h_cmd *get_c2h_from_skb(struct sk_buff *skb)805{806u32 pkt_offset;807808pkt_offset = *((u32 *)skb->cb);809return (struct rtw_c2h_cmd *)(skb->data + pkt_offset);810}811812static inline bool rtw_fw_feature_check(struct rtw_fw_state *fw,813enum rtw_fw_feature feature)814{815return !!(fw->feature & feature);816}817818static inline bool rtw_fw_feature_ext_check(struct rtw_fw_state *fw,819enum rtw_fw_feature_ext feature)820{821return !!(fw->feature_ext & feature);822}823824void rtw_fw_dump_dbg_info(struct rtw_dev *rtwdev);825void rtw_fw_c2h_cmd_rx_irqsafe(struct rtw_dev *rtwdev, u32 pkt_offset,826struct sk_buff *skb);827void rtw_fw_c2h_cmd_handle(struct rtw_dev *rtwdev, struct sk_buff *skb);828void rtw_fw_send_general_info(struct rtw_dev *rtwdev);829void rtw_fw_send_phydm_info(struct rtw_dev *rtwdev);830void rtw_fw_default_port(struct rtw_dev *rtwdev, struct rtw_vif *rtwvif);831832void rtw_fw_do_iqk(struct rtw_dev *rtwdev, struct rtw_iqk_para *para);833void rtw_fw_inform_rfk_status(struct rtw_dev *rtwdev, bool start);834void rtw_fw_set_pwr_mode(struct rtw_dev *rtwdev);835void rtw_fw_set_pg_info(struct rtw_dev *rtwdev);836void rtw_fw_query_bt_info(struct rtw_dev *rtwdev);837void rtw_fw_wl_ch_info(struct rtw_dev *rtwdev, u8 link, u8 ch, u8 bw);838void rtw_fw_query_bt_mp_info(struct rtw_dev *rtwdev,839struct rtw_coex_info_req *req);840void rtw_fw_force_bt_tx_power(struct rtw_dev *rtwdev, u8 bt_pwr_dec_lvl);841void rtw_fw_bt_ignore_wlan_action(struct rtw_dev *rtwdev, bool enable);842void rtw_fw_coex_tdma_type(struct rtw_dev *rtwdev,843u8 para1, u8 para2, u8 para3, u8 para4, u8 para5);844void rtw_fw_coex_query_hid_info(struct rtw_dev *rtwdev, u8 sub_id, u8 data);845846void rtw_fw_bt_wifi_control(struct rtw_dev *rtwdev, u8 op_code, u8 *data);847void rtw_fw_send_rssi_info(struct rtw_dev *rtwdev, struct rtw_sta_info *si);848void rtw_fw_send_ra_info(struct rtw_dev *rtwdev, struct rtw_sta_info *si,849bool reset_ra_mask);850void rtw_fw_media_status_report(struct rtw_dev *rtwdev, u8 mac_id, bool conn);851void rtw_fw_update_wl_phy_info(struct rtw_dev *rtwdev);852void rtw_fw_beacon_filter_config(struct rtw_dev *rtwdev, bool connect,853struct ieee80211_vif *vif);854int rtw_fw_write_data_rsvd_page(struct rtw_dev *rtwdev, u16 pg_addr,855u8 *buf, u32 size);856void rtw_remove_rsvd_page(struct rtw_dev *rtwdev,857struct rtw_vif *rtwvif);858void rtw_add_rsvd_page_bcn(struct rtw_dev *rtwdev,859struct rtw_vif *rtwvif);860void rtw_add_rsvd_page_pno(struct rtw_dev *rtwdev,861struct rtw_vif *rtwvif);862void rtw_add_rsvd_page_sta(struct rtw_dev *rtwdev,863struct rtw_vif *rtwvif);864int rtw_fw_download_rsvd_page(struct rtw_dev *rtwdev);865void rtw_fw_update_beacon_work(struct work_struct *work);866void rtw_send_rsvd_page_h2c(struct rtw_dev *rtwdev);867int rtw_dump_drv_rsvd_page(struct rtw_dev *rtwdev,868u32 offset, u32 size, u32 *buf);869void rtw_fw_set_remote_wake_ctrl_cmd(struct rtw_dev *rtwdev, bool enable);870void rtw_fw_set_wowlan_ctrl_cmd(struct rtw_dev *rtwdev, bool enable);871void rtw_fw_set_keep_alive_cmd(struct rtw_dev *rtwdev, bool enable);872void rtw_fw_set_disconnect_decision_cmd(struct rtw_dev *rtwdev, bool enable);873void rtw_fw_set_aoac_global_info_cmd(struct rtw_dev *rtwdev,874u8 pairwise_key_enc,875u8 group_key_enc);876877void rtw_fw_set_nlo_info(struct rtw_dev *rtwdev, bool enable);878void rtw_fw_set_recover_bt_device(struct rtw_dev *rtwdev);879void rtw_fw_update_pkt_probe_req(struct rtw_dev *rtwdev,880struct cfg80211_ssid *ssid);881void rtw_fw_channel_switch(struct rtw_dev *rtwdev, bool enable);882void rtw_fw_h2c_cmd_dbg(struct rtw_dev *rtwdev, u8 *h2c);883void rtw_fw_c2h_cmd_isr(struct rtw_dev *rtwdev);884int rtw_fw_dump_fifo(struct rtw_dev *rtwdev, u8 fifo_sel, u32 addr, u32 size,885u32 *buffer);886void rtw_fw_scan_notify(struct rtw_dev *rtwdev, bool start);887void rtw_fw_adaptivity(struct rtw_dev *rtwdev);888void rtw_store_op_chan(struct rtw_dev *rtwdev, bool backup);889void rtw_clear_op_chan(struct rtw_dev *rtwdev);890void rtw_hw_scan_start(struct rtw_dev *rtwdev, struct ieee80211_vif *vif,891struct ieee80211_scan_request *req);892void rtw_hw_scan_complete(struct rtw_dev *rtwdev, struct ieee80211_vif *vif,893bool aborted);894int rtw_hw_scan_offload(struct rtw_dev *rtwdev, struct ieee80211_vif *vif,895bool enable);896void rtw_hw_scan_status_report(struct rtw_dev *rtwdev, struct sk_buff *skb);897void rtw_hw_scan_chan_switch(struct rtw_dev *rtwdev, struct sk_buff *skb);898void rtw_hw_scan_abort(struct rtw_dev *rtwdev);899#endif900901902