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 DDMA_POLLING_COUNT 1000 11#define C2H_PKT_BUF 256 12#define REPORT_BUF 128 13#define PHY_STATUS_SIZE 4 14#define ILLEGAL_KEY_GROUP 0xFAAAAA00 15 16/* HW memory address */ 17#define OCPBASE_RXBUF_FW_88XX 0x18680000 18#define OCPBASE_TXBUF_88XX 0x18780000 19#define OCPBASE_ROM_88XX 0x00000000 20#define OCPBASE_IMEM_88XX 0x00030000 21#define OCPBASE_DMEM_88XX 0x00200000 22#define OCPBASE_EMEM_88XX 0x00100000 23 24#define RSVD_PG_DRV_NUM 16 25#define RSVD_PG_H2C_EXTRAINFO_NUM 24 26#define RSVD_PG_H2C_STATICINFO_NUM 8 27#define RSVD_PG_H2CQ_NUM 8 28#define RSVD_PG_CPU_INSTRUCTION_NUM 0 29#define RSVD_PG_FW_TXBUF_NUM 4 30 31void rtw_set_channel_mac(struct rtw_dev *rtwdev, u8 channel, u8 bw, 32 u8 primary_ch_idx); 33int rtw_mac_power_on(struct rtw_dev *rtwdev); 34void rtw_mac_power_off(struct rtw_dev *rtwdev); 35int rtw_download_firmware(struct rtw_dev *rtwdev, struct rtw_fw_state *fw); 36int rtw_mac_init(struct rtw_dev *rtwdev); 37void rtw_mac_flush_queues(struct rtw_dev *rtwdev, u32 queues, bool drop); 38int rtw_ddma_to_fw_fifo(struct rtw_dev *rtwdev, u32 ocp_src, u32 size); 39 40static inline void rtw_mac_flush_all_queues(struct rtw_dev *rtwdev, bool drop) 41{ 42 rtw_mac_flush_queues(rtwdev, BIT(rtwdev->hw->queues) - 1, drop); 43} 44 45#endif 46