1 /****************************************************************************** 2 * 3 * Copyright(c) 2007 - 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 __RTL8188E_RECV_H__ 16 #define __RTL8188E_RECV_H__ 17 18 #define RECV_BLK_SZ 512 19 #define RECV_BLK_CNT 16 20 #define RECV_BLK_TH RECV_BLK_CNT 21 22 #if defined(CONFIG_USB_HCI) 23 #ifndef MAX_RECVBUF_SZ 24 #ifndef CONFIG_MINIMAL_MEMORY_USAGE 25 /* #define MAX_RECVBUF_SZ (32768) */ /* 32k */ 26 /* #define MAX_RECVBUF_SZ (16384) */ /* 16K */ 27 /* #define MAX_RECVBUF_SZ (10240) */ /* 10K */ 28 #define MAX_RECVBUF_SZ (15360) /* 15k < 16k */ 29 /* #define MAX_RECVBUF_SZ (8192+1024) */ /* 8K+1k */ 30 #else 31 #define MAX_RECVBUF_SZ (4000) /* about 4K */ 32 #endif 33 #endif /* !MAX_RECVBUF_SZ */ 34 35 #elif defined(CONFIG_PCI_HCI) 36 /* #ifndef CONFIG_MINIMAL_MEMORY_USAGE */ 37 /* #define MAX_RECVBUF_SZ (9100) */ 38 /* #else */ 39 #define MAX_RECVBUF_SZ (4000) /* about 4K 40 * #endif */ 41 42 43 #elif defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) 44 45 #define MAX_RECVBUF_SZ (10240) 46 47 #endif 48 49 /* Rx smooth factor */ 50 #define Rx_Smooth_Factor (20) 51 52 #define TX_RPT1_PKT_LEN 8 53 54 typedef struct rxreport_8188e { 55 /* Offset 0 */ 56 u32 pktlen:14; 57 u32 crc32:1; 58 u32 icverr:1; 59 u32 drvinfosize:4; 60 u32 security:3; 61 u32 qos:1; 62 u32 shift:2; 63 u32 physt:1; 64 u32 swdec:1; 65 u32 ls:1; 66 u32 fs:1; 67 u32 eor:1; 68 u32 own:1; 69 70 /* Offset 4 */ 71 u32 macid:5; 72 u32 tid:4; 73 u32 hwrsvd:4; 74 u32 amsdu:1; 75 u32 paggr:1; 76 u32 faggr:1; 77 u32 a1fit:4; 78 u32 a2fit:4; 79 u32 pam:1; 80 u32 pwr:1; 81 u32 md:1; 82 u32 mf:1; 83 u32 type:2; 84 u32 mc:1; 85 u32 bc:1; 86 87 /* Offset 8 */ 88 u32 seq:12; 89 u32 frag:4; 90 u32 nextpktlen:14; 91 u32 nextind:1; 92 u32 rsvd0831:1; 93 94 /* Offset 12 */ 95 u32 rxmcs:6; 96 u32 rxht:1; 97 u32 gf:1; 98 u32 splcp:1; 99 u32 bw:1; 100 u32 htc:1; 101 u32 eosp:1; 102 u32 bssidfit:2; 103 u32 rpt_sel:2; 104 u32 rsvd1216:13; 105 u32 pattern_match:1; 106 u32 unicastwake:1; 107 u32 magicwake:1; 108 109 /* Offset 16 */ 110 /* 111 u32 pattern0match:1; 112 u32 pattern1match:1; 113 u32 pattern2match:1; 114 u32 pattern3match:1; 115 u32 pattern4match:1; 116 u32 pattern5match:1; 117 u32 pattern6match:1; 118 u32 pattern7match:1; 119 u32 pattern8match:1; 120 u32 pattern9match:1; 121 u32 patternamatch:1; 122 u32 patternbmatch:1; 123 u32 patterncmatch:1; 124 u32 rsvd1613:19; 125 */ 126 u32 rsvd16; 127 128 /* Offset 20 */ 129 u32 tsfl; 130 131 /* Offset 24 */ 132 u32 bassn:12; 133 u32 bavld:1; 134 u32 rsvd2413:19; 135 } RXREPORT, *PRXREPORT; 136 137 138 #if defined(CONFIG_SDIO_HCI) || defined(CONFIG_GSPI_HCI) 139 s32 rtl8188es_init_recv_priv(PADAPTER padapter); 140 void rtl8188es_free_recv_priv(PADAPTER padapter); 141 #endif 142 143 #ifdef CONFIG_USB_HCI 144 void rtl8188eu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf); 145 s32 rtl8188eu_init_recv_priv(PADAPTER padapter); 146 void rtl8188eu_free_recv_priv(PADAPTER padapter); 147 #endif 148 149 #ifdef CONFIG_PCI_HCI 150 s32 rtl8188ee_init_recv_priv(PADAPTER padapter); 151 void rtl8188ee_free_recv_priv(PADAPTER padapter); 152 #endif 153 154 void rtl8188e_query_rx_desc_status(union recv_frame *precvframe, struct recv_stat *prxstat); 155 156 #endif /* __RTL8188E_RECV_H__ */ 157