1 /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2 /* Copyright(c) 2018-2019 Realtek Corporation
3 */
4
5 #ifndef __RTW_MAC_H__
6 #define __RTW_MAC_H__
7
8 #define RTW_HW_PORT_NUM 5
9 #define cut_version_to_mask(cut) (0x1 << ((cut) + 1))
10 #define SDIO_LOCAL_OFFSET 0x10250000
11 #define DDMA_POLLING_COUNT 1000
12 #define C2H_PKT_BUF 256
13 #define REPORT_BUF 128
14 #define PHY_STATUS_SIZE 4
15 #define ILLEGAL_KEY_GROUP 0xFAAAAA00
16
17 /* HW memory address */
18 #define OCPBASE_RXBUF_FW_88XX 0x18680000
19 #define OCPBASE_TXBUF_88XX 0x18780000
20 #define OCPBASE_ROM_88XX 0x00000000
21 #define OCPBASE_IMEM_88XX 0x00030000
22 #define OCPBASE_DMEM_88XX 0x00200000
23 #define OCPBASE_EMEM_88XX 0x00100000
24
25 #define RSVD_PG_DRV_NUM 16
26 #define RSVD_PG_H2C_EXTRAINFO_NUM 24
27 #define RSVD_PG_H2C_STATICINFO_NUM 8
28 #define RSVD_PG_H2CQ_NUM 8
29 #define RSVD_PG_CPU_INSTRUCTION_NUM 0
30 #define RSVD_PG_FW_TXBUF_NUM 4
31
32 void rtw_set_channel_mac(struct rtw_dev *rtwdev, u8 channel, u8 bw,
33 u8 primary_ch_idx);
34 int rtw_mac_power_on(struct rtw_dev *rtwdev);
35 void rtw_mac_power_off(struct rtw_dev *rtwdev);
36 int rtw_download_firmware(struct rtw_dev *rtwdev, struct rtw_fw_state *fw);
37 int rtw_mac_init(struct rtw_dev *rtwdev);
38 void rtw_mac_flush_queues(struct rtw_dev *rtwdev, u32 queues, bool drop);
39 int rtw_ddma_to_fw_fifo(struct rtw_dev *rtwdev, u32 ocp_src, u32 size);
40
rtw_mac_flush_all_queues(struct rtw_dev * rtwdev,bool drop)41 static inline void rtw_mac_flush_all_queues(struct rtw_dev *rtwdev, bool drop)
42 {
43 rtw_mac_flush_queues(rtwdev, BIT(rtwdev->hw->queues) - 1, drop);
44 }
45
46 #endif
47