mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-30 22:51:41 +01:00 
			
		
		
		
	
		
			
	
	
		
			140 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			140 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /*
 | ||
|  |  * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD | ||
|  |  * | ||
|  |  * SPDX-License-Identifier: Apache-2.0 | ||
|  |  */ | ||
|  | 
 | ||
|  | #ifndef _ROM_LLDESC_H_
 | ||
|  | #define _ROM_LLDESC_H_
 | ||
|  | 
 | ||
|  | #include <stdint.h>
 | ||
|  | 
 | ||
|  | #include "sys/queue.h"
 | ||
|  | #include "esp_rom_lldesc.h"
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #define LLDESC_TX_MBLK_SIZE                 268 /* */
 | ||
|  | #define LLDESC_RX_SMBLK_SIZE                64  /* small block size, for small mgmt frame */
 | ||
|  | #define LLDESC_RX_MBLK_SIZE                 524 /* rx is large sinec we want to contain mgmt frame in one block*/
 | ||
|  | #define LLDESC_RX_AMPDU_ENTRY_MBLK_SIZE    64  /* it is a small buffer which is a cycle link*/
 | ||
|  | #define LLDESC_RX_AMPDU_LEN_MBLK_SIZE      256 /*for ampdu entry*/
 | ||
|  | #ifdef ESP_MAC_5
 | ||
|  | #define LLDESC_TX_MBLK_NUM                  116  /* 64K / 256 */
 | ||
|  | #define LLDESC_RX_MBLK_NUM                  82 /* 64K / 512 MAX 172*/
 | ||
|  | #define LLDESC_RX_AMPDU_ENTRY_MBLK_NUM     4
 | ||
|  | #define LLDESC_RX_AMPDU_LEN_MLBK_NUM       12
 | ||
|  | #else
 | ||
|  | #ifdef SBUF_RXTX
 | ||
|  | #define LLDESC_TX_MBLK_NUM_MAX    (2 * 48) /* 23K / 260 - 8 */
 | ||
|  | #define LLDESC_RX_MBLK_NUM_MAX    (2 * 48) /* 23K / 524 */
 | ||
|  | #define LLDESC_TX_MBLK_NUM_MIN    (2 * 16) /* 23K / 260 - 8 */
 | ||
|  | #define LLDESC_RX_MBLK_NUM_MIN    (2 * 16) /* 23K / 524 */
 | ||
|  | #endif
 | ||
|  | #define LLDESC_TX_MBLK_NUM      10      //(2 * 32) /* 23K / 260 - 8 */
 | ||
|  | 
 | ||
|  | #ifdef IEEE80211_RX_AMPDU
 | ||
|  | #define LLDESC_RX_MBLK_NUM      30
 | ||
|  | #else
 | ||
|  | #define LLDESC_RX_MBLK_NUM      10
 | ||
|  | #endif /*IEEE80211_RX_AMPDU*/
 | ||
|  | 
 | ||
|  | #define LLDESC_RX_AMPDU_ENTRY_MBLK_NUM  4
 | ||
|  | #define LLDESC_RX_AMPDU_LEN_MLBK_NUM    8
 | ||
|  | #endif /* !ESP_MAC_5 */
 | ||
|  | 
 | ||
|  | typedef struct tx_ampdu_entry_s { | ||
|  |     uint32_t sub_len  : 12, | ||
|  |              dili_num : 7, | ||
|  |              : 1, | ||
|  |              null_byte: 2, | ||
|  |              data     : 1, | ||
|  |              enc      : 1, | ||
|  |              seq      : 8; | ||
|  | } tx_ampdu_entry_t; | ||
|  | 
 | ||
|  | typedef struct lldesc_chain_s { | ||
|  |     lldesc_t *head; | ||
|  |     lldesc_t *tail; | ||
|  | } lldesc_chain_t; | ||
|  | 
 | ||
|  | #ifdef SBUF_RXTX
 | ||
|  | enum sbuf_mask_s  { | ||
|  |     SBUF_MOVE_NO = 0, | ||
|  |     SBUF_MOVE_TX2RX, | ||
|  |     SBUF_MOVE_RX2TX, | ||
|  | } ; | ||
|  | 
 | ||
|  | #define SBUF_MOVE_STEP 8
 | ||
|  | #endif
 | ||
|  | #define LLDESC_SIZE  sizeof(struct lldesc_s)
 | ||
|  | 
 | ||
|  | /* SLC Descriptor  */ | ||
|  | #define LLDESC_OWNER_MASK                  0x80000000
 | ||
|  | #define LLDESC_OWNER_SHIFT                         31
 | ||
|  | #define LLDESC_SW_OWNED                             0
 | ||
|  | #define LLDESC_HW_OWNED                             1
 | ||
|  | 
 | ||
|  | #define LLDESC_EOF_MASK                    0x40000000
 | ||
|  | #define LLDESC_EOF_SHIFT                           30
 | ||
|  | 
 | ||
|  | #define LLDESC_SOSF_MASK                   0x20000000
 | ||
|  | #define LLDESC_SOSF_SHIFT                          29
 | ||
|  | 
 | ||
|  | #define LLDESC_LENGTH_MASK                 0x00fff000
 | ||
|  | #define LLDESC_LENGTH_SHIFT                        12
 | ||
|  | 
 | ||
|  | #define LLDESC_SIZE_MASK                   0x00000fff
 | ||
|  | #define LLDESC_SIZE_SHIFT                           0
 | ||
|  | 
 | ||
|  | #define LLDESC_ADDR_MASK                    0x000fffff
 | ||
|  | 
 | ||
|  | void lldesc_build_chain(uint8_t *descptr, uint32_t desclen, uint8_t *mblkptr, uint32_t buflen, uint32_t blksz, uint8_t owner, | ||
|  |                         lldesc_t **head, | ||
|  | #ifdef TO_HOST_RESTART
 | ||
|  |                         lldesc_t **one_before_tail, | ||
|  | #endif
 | ||
|  |                         lldesc_t **tail); | ||
|  | 
 | ||
|  | static inline uint32_t lldesc_get_chain_length(lldesc_t *head) | ||
|  | { | ||
|  |     lldesc_t *ds = head; | ||
|  |     uint32_t len = 0; | ||
|  | 
 | ||
|  |     while (ds) { | ||
|  |         len += ds->length; | ||
|  |         ds = STAILQ_NEXT(ds, qe); | ||
|  |     } | ||
|  | 
 | ||
|  |     return len; | ||
|  | } | ||
|  | 
 | ||
|  | static inline void lldesc_config(lldesc_t *ds, uint8_t owner, uint8_t eof, uint8_t sosf, uint16_t len) | ||
|  | { | ||
|  |     ds->owner  = owner; | ||
|  |     ds->eof    = eof; | ||
|  |     ds->sosf   = sosf; | ||
|  |     ds->length = len; | ||
|  | } | ||
|  | 
 | ||
|  | #define LLDESC_CONFIG(_desc, _owner, _eof, _sosf, _len)        do { \
 | ||
|  |         (_desc)->owner  = (_owner); \ | ||
|  |         (_desc)->eof    = (_eof);   \ | ||
|  |         (_desc)->sosf   = (_sosf);  \ | ||
|  |         (_desc)->length = (_len);   \ | ||
|  | } while(0) | ||
|  | 
 | ||
|  | #define LLDESC_FROM_HOST_CLEANUP(ds) LLDESC_CONFIG((ds), LLDESC_HW_OWNED, 0, 0, 0)
 | ||
|  | 
 | ||
|  | #define LLDESC_MAC_RX_CLEANUP(ds) LLDESC_CONFIG((ds), LLDESC_HW_OWNED, 0, 0, (ds)->size)
 | ||
|  | 
 | ||
|  | #define LLDESC_TO_HOST_CLEANUP(ds) LLDESC_CONFIG((ds), LLDESC_HW_OWNED, 0, 0, 0)
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #endif /* _ROM_LLDESC_H_ */
 |