xref: /freebsd/sys/contrib/dev/rtw88/mac.h (revision 90aac0d8)
12774f206SBjoern A. Zeeb /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
22774f206SBjoern A. Zeeb /* Copyright(c) 2018-2019  Realtek Corporation
32774f206SBjoern A. Zeeb  */
42774f206SBjoern A. Zeeb 
52774f206SBjoern A. Zeeb #ifndef __RTW_MAC_H__
62774f206SBjoern A. Zeeb #define __RTW_MAC_H__
72774f206SBjoern A. Zeeb 
82774f206SBjoern A. Zeeb #define RTW_HW_PORT_NUM		5
92774f206SBjoern A. Zeeb #define cut_version_to_mask(cut) (0x1 << ((cut) + 1))
102774f206SBjoern A. Zeeb #define DDMA_POLLING_COUNT	1000
112774f206SBjoern A. Zeeb #define C2H_PKT_BUF		256
122774f206SBjoern A. Zeeb #define REPORT_BUF		128
132774f206SBjoern A. Zeeb #define PHY_STATUS_SIZE		4
142774f206SBjoern A. Zeeb #define ILLEGAL_KEY_GROUP	0xFAAAAA00
152774f206SBjoern A. Zeeb 
162774f206SBjoern A. Zeeb /* HW memory address */
172774f206SBjoern A. Zeeb #define OCPBASE_RXBUF_FW_88XX		0x18680000
182774f206SBjoern A. Zeeb #define OCPBASE_TXBUF_88XX		0x18780000
192774f206SBjoern A. Zeeb #define OCPBASE_ROM_88XX		0x00000000
202774f206SBjoern A. Zeeb #define OCPBASE_IMEM_88XX		0x00030000
212774f206SBjoern A. Zeeb #define OCPBASE_DMEM_88XX		0x00200000
222774f206SBjoern A. Zeeb #define OCPBASE_EMEM_88XX		0x00100000
232774f206SBjoern A. Zeeb 
242774f206SBjoern A. Zeeb #define RSVD_PG_DRV_NUM			16
252774f206SBjoern A. Zeeb #define RSVD_PG_H2C_EXTRAINFO_NUM	24
262774f206SBjoern A. Zeeb #define RSVD_PG_H2C_STATICINFO_NUM	8
272774f206SBjoern A. Zeeb #define RSVD_PG_H2CQ_NUM		8
282774f206SBjoern A. Zeeb #define RSVD_PG_CPU_INSTRUCTION_NUM	0
292774f206SBjoern A. Zeeb #define RSVD_PG_FW_TXBUF_NUM		4
302774f206SBjoern A. Zeeb 
312774f206SBjoern A. Zeeb void rtw_set_channel_mac(struct rtw_dev *rtwdev, u8 channel, u8 bw,
322774f206SBjoern A. Zeeb 			 u8 primary_ch_idx);
332774f206SBjoern A. Zeeb int rtw_mac_power_on(struct rtw_dev *rtwdev);
342774f206SBjoern A. Zeeb void rtw_mac_power_off(struct rtw_dev *rtwdev);
352774f206SBjoern A. Zeeb int rtw_download_firmware(struct rtw_dev *rtwdev, struct rtw_fw_state *fw);
362774f206SBjoern A. Zeeb int rtw_mac_init(struct rtw_dev *rtwdev);
372774f206SBjoern A. Zeeb void rtw_mac_flush_queues(struct rtw_dev *rtwdev, u32 queues, bool drop);
382774f206SBjoern A. Zeeb int rtw_ddma_to_fw_fifo(struct rtw_dev *rtwdev, u32 ocp_src, u32 size);
392774f206SBjoern A. Zeeb 
rtw_mac_flush_all_queues(struct rtw_dev * rtwdev,bool drop)402774f206SBjoern A. Zeeb static inline void rtw_mac_flush_all_queues(struct rtw_dev *rtwdev, bool drop)
412774f206SBjoern A. Zeeb {
422774f206SBjoern A. Zeeb 	rtw_mac_flush_queues(rtwdev, BIT(rtwdev->hw->queues) - 1, drop);
432774f206SBjoern A. Zeeb }
442774f206SBjoern A. Zeeb 
452774f206SBjoern A. Zeeb #endif
46