mac.h 1.7 KB

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