forked from ~ljy/RK356X_SDK_RELEASE

hc
2023-12-06 d38611ca164021d018c1b23eee65bbebc09c63e0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/* SPDX-License-Identifier: GPL-2.0 */
/******************************************************************************
 *
 * Copyright(c) 2007 - 2017 Realtek Corporation.
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of version 2 of the GNU General Public License as
 * published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
 * more details.
 *
 *****************************************************************************/
#ifndef __RTL8710B_RECV_H__
#define __RTL8710B_RECV_H__
 
#define RECV_BLK_SZ 512
#define RECV_BLK_CNT 16
#define RECV_BLK_TH RECV_BLK_CNT
 
#if defined(CONFIG_USB_HCI)
   #ifndef MAX_RECVBUF_SZ
       #ifdef CONFIG_MINIMAL_MEMORY_USAGE
           #define MAX_RECVBUF_SZ (4000) /* about 4K */
       #else
           #ifdef CONFIG_PLATFORM_MSTAR
               #define MAX_RECVBUF_SZ (8192) /* 8K */
               #elif defined(CONFIG_PLATFORM_HISILICON)
               #define MAX_RECVBUF_SZ (16384) /* 16k */
           #else
               #define MAX_RECVBUF_SZ (15360) /* 15k < 16k */
               /* #define MAX_RECVBUF_SZ (32768) */ /* 32k */
               /* #define MAX_RECVBUF_SZ (20480) */ /* 20K */
               /* #define MAX_RECVBUF_SZ (10240)  */ /* 10K */
               /* #define MAX_RECVBUF_SZ (16384) */ /* 16k - 92E RX BUF :16K */
           #endif
       #endif
   #endif /* !MAX_RECVBUF_SZ */
#endif
 
/* Rx smooth factor */
#define    Rx_Smooth_Factor (20)
 
/*-----------------------------------------------------------------*/
/*    RTL8710B RX BUFFER DESC                                      */
/*-----------------------------------------------------------------*/
/*DWORD 0*/
#define SET_RX_BUFFER_DESC_DATA_LENGTH_8710B(__pRxStatusDesc, __Value)        SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 0, 14, __Value)
#define SET_RX_BUFFER_DESC_LS_8710B(__pRxStatusDesc, __Value)    SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 15, 1, __Value)
#define SET_RX_BUFFER_DESC_FS_8710B(__pRxStatusDesc, __Value)        SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 1, __Value)
#define SET_RX_BUFFER_DESC_TOTAL_LENGTH_8710B(__pRxStatusDesc, __Value)        SET_BITS_TO_LE_4BYTE(__pRxStatusDesc, 16, 15, __Value)
 
#define GET_RX_BUFFER_DESC_OWN_8710B(__pRxStatusDesc)        LE_BITS_TO_4BYTE(__pRxStatusDesc, 31, 1)
#define GET_RX_BUFFER_DESC_LS_8710B(__pRxStatusDesc)        LE_BITS_TO_4BYTE(__pRxStatusDesc, 15, 1)
#define GET_RX_BUFFER_DESC_FS_8710B(__pRxStatusDesc)        LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 1)
#ifdef USING_RX_TAG
   #define GET_RX_BUFFER_DESC_RX_TAG_8710B(__pRxStatusDesc)        LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 13)
#else
   #define GET_RX_BUFFER_DESC_TOTAL_LENGTH_8710B(__pRxStatusDesc)        LE_BITS_TO_4BYTE(__pRxStatusDesc, 16, 15)
#endif
 
/*DWORD 1*/
#define SET_RX_BUFFER_PHYSICAL_LOW_8710B(__pRxStatusDesc, __Value)        SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+4, 0, 32, __Value)
 
/*DWORD 2*/
#ifdef CONFIG_64BIT_DMA
   #define SET_RX_BUFFER_PHYSICAL_HIGH_8710B(__pRxStatusDesc, __Value)        SET_BITS_TO_LE_4BYTE(__pRxStatusDesc+8, 0, 32, __Value)
#else
   #define SET_RX_BUFFER_PHYSICAL_HIGH_8710B(__pRxStatusDesc, __Value)
#endif
 
#ifdef CONFIG_USB_HCI
   int rtl8710bu_init_recv_priv(_adapter *padapter);
   void rtl8710bu_free_recv_priv(_adapter *padapter);
   void rtl8710bu_init_recvbuf(_adapter *padapter, struct recv_buf *precvbuf);
#endif
 
void rtl8710b_query_rx_desc_status(union recv_frame *precvframe, u8 *pdesc);
 
#endif /* __RTL8710B_RECV_H__ */