rtl8821ce.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2016 - 2017 Realtek Corporation.
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of version 2 of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  12. * more details.
  13. *
  14. *****************************************************************************/
  15. #ifndef _RTL8821CE_H_
  16. #define _RTL8821CE_H_
  17. #include <drv_types.h> /* PADAPTER */
  18. #define TX_BD_NUM_8821CE 128
  19. #define RX_BD_NUM_8821CE 128
  20. #define TX_BD_NUM_8821CE_BCN 2
  21. #define TX_BD_NUM_8821CE_CMD 128
  22. #define RTL8821CE_SEG_NUM 1 /* 0:2 seg, 1: 4 seg, 2: 8 seg */
  23. #ifndef MAX_RECVBUF_SZ
  24. #ifdef PLATFORM_OS_CE
  25. #define MAX_RECVBUF_SZ (8192+1024)
  26. #else /* !PLATFORM_OS_CE */
  27. #ifndef CONFIG_MINIMAL_MEMORY_USAGE
  28. #define MAX_RECVBUF_SZ (32768)
  29. #else
  30. #define MAX_RECVBUF_SZ (4000)
  31. #endif
  32. #endif /* PLATFORM_OS_CE */
  33. #endif /* !MAX_RECVBUF_SZ */
  34. #define TX_BUFFER_SEG_NUM 1 /* 0:2 seg, 1: 4 seg, 2: 8 seg. */
  35. #define MAX_RECVBUF_SZ_8821C 16384 /* 16k */
  36. #ifdef CONFIG_64BIT_DMA
  37. #define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) \
  38. SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 0, 16, __Valeu)
  39. #define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) \
  40. SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16), 31, 1, __Valeu)
  41. #define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) \
  42. SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+4, 0, 32, __Valeu)
  43. #define SET_TXBUFFER_DESC_ADD_HIGH_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) \
  44. SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*16)+8, 0, 32, __Valeu)
  45. #else
  46. /* TX BD */
  47. #define SET_TXBUFFER_DESC_LEN_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) \
  48. SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 0, 16, __Valeu)
  49. #define SET_TXBUFFER_DESC_AMSDU_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) \
  50. SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8), 31, 1, __Valeu)
  51. #define SET_TXBUFFER_DESC_ADD_LOW_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) \
  52. SET_BITS_TO_LE_4BYTE(__pTxDesc+(__Offset*8)+4, 0, 32, __Valeu)
  53. #define SET_TXBUFFER_DESC_ADD_HIGH_WITH_OFFSET(__pTxDesc, __Offset, __Valeu) 0
  54. #endif
  55. /* RX BD */
  56. #define SET_RX_BD_PHYSICAL_ADDR_LOW(__pRxBd, __Value) \
  57. SET_BITS_TO_LE_4BYTE(__pRxBd + 0x04, 0, 32, __Value)
  58. #ifdef CONFIG_64BIT_DMA
  59. #define SET_RX_BD_PHYSICAL_ADDR_HIGH(__pRxBd, __Value) \
  60. SET_BITS_TO_LE_4BYTE(__pRxBd + 0x08, 0, 32, __Value)
  61. #else
  62. #define SET_RX_BD_PHYSICAL_ADDR_HIGH(__pRxBd, __Value) 0
  63. #endif
  64. #define SET_RX_BD_RXBUFFSIZE(__pRxBd, __Value) \
  65. SET_BITS_TO_LE_4BYTE(__pRxBd + 0x00, 0, 14, __Value)
  66. #define SET_RX_BD_LS(__pRxBd, __Value) \
  67. SET_BITS_TO_LE_4BYTE(__pRxBd + 0x00, 14, 1, __Value)
  68. #define SET_RX_BD_FS(__pRxBd, __Value) \
  69. SET_BITS_TO_LE_4BYTE(__pRxBd + 0x00, 15, 1, __Value)
  70. #define SET_RX_BD_TOTALRXPKTSIZE(__pRxBd, __Value) \
  71. SET_BITS_TO_LE_4BYTE(__pRxBd + 0x00, 16, 13, __Value)
  72. /* rtl8821ce_halinit.c */
  73. u32 rtl8821ce_hal_init(PADAPTER);
  74. u32 rtl8821ce_hal_deinit(PADAPTER);
  75. void rtl8821ce_init_default_value(PADAPTER);
  76. /* rtl8821ce_halmac.c */
  77. int rtl8821ce_halmac_init_adapter(PADAPTER);
  78. /* rtl8821ce_io.c */
  79. /* rtl8821ce_led.c */
  80. void rtl8821ce_initswleds(PADAPTER);
  81. void rtl8821ce_deinitswleds(PADAPTER);
  82. /* rtl8821ce_xmit.c */
  83. #define OFFSET_SZ 0
  84. s32 rtl8821ce_init_xmit_priv(PADAPTER);
  85. void rtl8821ce_free_xmit_priv(PADAPTER);
  86. struct xmit_buf *rtl8821ce_dequeue_xmitbuf(struct rtw_tx_ring *);
  87. void rtl8821ce_fill_fake_txdesc(PADAPTER, u8 *pDesc, u32 BufferLen,
  88. u8 IsPsPoll, u8 IsBTQosNull, u8 bDataFrame);
  89. int rtl8821ce_init_txbd_ring(PADAPTER, unsigned int q_idx,
  90. unsigned int entries);
  91. void rtl8821ce_free_txbd_ring(PADAPTER, unsigned int prio);
  92. void rtl8821ce_tx_isr(PADAPTER, int prio);
  93. s32 rtl8821ce_mgnt_xmit(PADAPTER, struct xmit_frame *);
  94. s32 rtl8821ce_hal_xmit(PADAPTER, struct xmit_frame *);
  95. s32 rtl8821ce_hal_xmitframe_enqueue(PADAPTER, struct xmit_frame *);
  96. #ifdef CONFIG_XMIT_THREAD_MODE
  97. s32 rtl8821ce_xmit_buf_handler(PADAPTER);
  98. #endif
  99. void rtl8821ce_xmitframe_resume(PADAPTER);
  100. /* rtl8821ce_recv.c */
  101. s32 rtl8821ce_init_recv_priv(PADAPTER);
  102. void rtl8821ce_free_recv_priv(PADAPTER);
  103. int rtl8821ce_init_rxbd_ring(PADAPTER);
  104. void rtl8821ce_free_rxbd_ring(PADAPTER);
  105. /* rtl8821cs_ops.c */
  106. #endif /* _RTL8821CE_H_ */