C++程序  |  132行  |  4.94 KB

/*
 * RxBuf.h
 *
 * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved.      
 * All rights reserved.                                                  
 *                                                                       
 * Redistribution and use in source and binary forms, with or without    
 * modification, are permitted provided that the following conditions    
 * are met:                                                              
 *                                                                       
 *  * Redistributions of source code must retain the above copyright     
 *    notice, this list of conditions and the following disclaimer.      
 *  * Redistributions in binary form must reproduce the above copyright  
 *    notice, this list of conditions and the following disclaimer in    
 *    the documentation and/or other materials provided with the         
 *    distribution.                                                      
 *  * Neither the name Texas Instruments nor the names of its            
 *    contributors may be used to endorse or promote products derived    
 *    from this software without specific prior written permission.      
 *                                                                       
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS   
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT     
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT  
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT      
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT   
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */


/***************************************************************************/
/*																		   */
/*	  MODULE:	buf.h												       */
/*    PURPOSE:	manages the allocation/free and field access of the BUF    */
/*																		   */
/***************************************************************************/
#ifndef _BUF_H_
#define _BUF_H_

#include "tidef.h"
#include "queue.h"
#include "public_descriptors.h"



#define WSPI_PAD_BYTES          	16     /* Add padding before data buffer for WSPI overhead */
#define PAYLOAD_ALIGN_PAD_BYTES   	4      /* Add an extra word for alignment the MAC payload in case of QoS MSDU */



/**
 * \brief Buffer for Tx/Rx packets 
 */ 
typedef void BUF, *PBUF;

/* Packet types */


/**
 * \def RX_BUF_DATA
 * \brief Macro which gets a pointer to BUF packet header and returns the pointer to the start address of the WLAN packet's data
 */
#define RX_BUF_DATA(pBuf)   ((void*)((TI_UINT8 *)pBuf + sizeof(RxIfDescriptor_t)))
/**
 * \def RX_BUF_LEN
 * \brief Macro which gets a pointer to BUF packet header and returns the buffer length (without Rx Descriptor) of the WLAN packet
 */
#define RX_BUF_LEN(pBuf)    ( (((RxIfDescriptor_t *)(pBuf))->length << 2) -  \
                              ((RxIfDescriptor_t *)(pBuf))->extraBytes -     \
                              sizeof(RxIfDescriptor_t) )

/**
 * \def RX_ETH_PKT_DATA
 * \brief Macro which gets a pointer to BUF packet header and returns the pointer to the start address of the ETH packet's data
 */
#define RX_ETH_PKT_DATA(pBuf)   *((void **)(((TI_UINT32)pBuf + sizeof(RxIfDescriptor_t) + 2) & ~3))
/**
 * \def RX_ETH_PKT_LEN
 * \brief Macro which gets a pointer to BUF packet header and returns the buffer length (without Rx Descriptor) of the ETH packet
 */
#define RX_ETH_PKT_LEN(pBuf)    *((TI_UINT32 *)(((TI_UINT32)pBuf + sizeof(RxIfDescriptor_t) + 6) & ~3))


/** \brief BUF Allocation
 * 
 * \param  hOs		- OS module object handle
 * \param  len		- Length of allocated WBUF
 * \param  ePacketClassTag	- The RX packet type (used only in EMP)
 * \return On success: Pointer to WBUF	;	Otherwise: NULL
 * 
 * \par Description
 * This function allocates BUF element for Tx/Rx packet
 * 
 * \sa
 */ 
BUF* RxBufAlloc         (TI_HANDLE hOs, TI_UINT32 len, PacketClassTag_e ePacketClassTag);


/** \brief BUF Free
 * 
 * \param  hOs		- OS module object handle
 * \param  pWbuf	- Pointer to WBUF which was previously created by user
 * \return void
 * 
 * \par Description
 * This function frees the memory allocated for BUF element
 * 
 * \sa
 */ 
void  RxBufFree          (TI_HANDLE hOs, void* pBuf);


/** \brief BUF Free
 * 
 * \param  hOs		- OS module object handle
 * \param  pWbuf	- Pointer to WBUF which was previously created by user
 * \return void
 * 
 * \par Description
 * This function increment the start address of data held in BUF element in len.
 * 
 * \sa
 */ 
void  RxBufReserve       (TI_HANDLE hOs, void* pBuf, TI_UINT32 len); 

#endif