Skip to content
Permalink
0a6aa58c97
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Go to file
 
 
Cannot retrieve contributors at this time
187 lines (170 sloc) 8.17 KB
/***********************************************************************************************//**
* \file cy_network_buffer.h
*
* \brief
* Basic set of APIs for dealing with network packet buffers. This is used by WHD
* for relaying data between the network stack and the connectivity chip.
*
***************************************************************************************************
* \copyright
* Copyright 2018-2022 Cypress Semiconductor Corporation (an Infineon company) or
* an affiliate of Cypress Semiconductor Corporation
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
**************************************************************************************************/
/**
* \addtogroup group_bsp_network_buffer Buffer management
* \{
* Basic set of APIs for dealing with network packet buffers
*/
#pragma once
#include <stdint.h>
#include <stdbool.h>
#include "cy_result.h"
#include "whd.h"
#include "whd_network_types.h"
#if defined(__cplusplus)
extern "C" {
#endif
/** Initialize the buffer pools
*
* Initialize the buffer pools used by the buffer management routines.
* A pair of pools, one for RX buffers and one for TX buffers in passed
* in for use by the management routines.
*
* Not all implementations use preallocated buffer pools.
*
* @param tx_packet_pool : Pointer to the initialized NetXDuo TX packet buffer pool
* @param rx_packet_pool : Pointer to the initialized NetXDuo RX packet buffer pool
*
* @return : CY_RSLT_SUCCESS or WHD_BADARG
*/
whd_result_t cy_buffer_pool_init(void* tx_packet_pool, void* rx_packet_pool);
/** Allocates a packet buffer
*
* Attempts to allocate a packet buffer of the size requested. It can do this
* by allocating a pre-existing packet from a pool, using a static buffer,
* or by dynamically allocating memory. The method of allocation does not
* concern WHD, however it must match the way the network stack expects packet
* buffers to be allocated. Usually WHD requires packet of size of WHD_LINK_MTU
* which includes the MTU. Refer to whd_types.h to find the size of WHD_LINK_MTU.
*
* @param buffer : A pointer which receives the allocated packet buffer handle
* @param direction : Indicates transmit/receive direction that the packet buffer is
* used for. This may be needed if tx/rx pools are separate.
* @param size : The number of bytes to allocate.
* @param timeout_ms: Time to wait for a packet buffer to be available
*
* @return : CY_RSLT_SUCCESS or WHD_BUFFER_ALLOC_FAIL if the buffer could not be allocated
*/
whd_result_t cy_host_buffer_get(whd_buffer_t* buffer, whd_buffer_dir_t direction,
uint16_t size, uint32_t timeout_ms);
/** Releases a packet buffer
*
* This function is used by WHD to indicate that it no longer requires
* a packet buffer. The buffer can then be released back into a pool for
* reuse, or the dynamically allocated memory can be freed, according to
* how the packet was allocated.
* Returns void since WHD cannot do anything about failures
*
* @param buffer : The handle of the packet buffer to be released
* @param direction : Indicates transmit/receive direction that the packet buffer has
* been used for. This might be needed if tx/rx pools are separate.
*/
void cy_buffer_release(whd_buffer_t buffer, whd_buffer_dir_t direction);
/** Retrieves the current pointer of a packet buffer
*
* Since packet buffers usually need to be created with space at the
* front for additional headers, this function allows WHD to get
* the current 'front' location pointer.
*
* @param buffer : The handle of the packet buffer whose pointer is to be retrieved
*
* @return : The packet buffer's current pointer.
*/
uint8_t* cy_buffer_get_current_piece_data_pointer(whd_buffer_t buffer);
/** Retrieves the size of a packet buffer
*
* Since packet buffers usually need to be created with space at the
* front for additional headers, the memory block used to contain a packet buffer
* will often be larger than the current size of the packet buffer data.
* This function allows WHD to retrieve the current size of a packet buffer's data.
*
* @param buffer : The handle of the packet buffer whose size is to be retrieved
*
* @return : The size of the packet buffer.
*/
uint16_t cy_buffer_get_current_piece_size(whd_buffer_t buffer);
/** Sets the current size of a WHD packet
*
* This function sets the current length of a WHD packet buffer
*
* @param buffer : The packet to be modified
* @param size : The new size of the packet buffer
*
* @return : CY_RSLT_SUCCESS or WHD_BUFFER_SIZE_SET_ERROR if the requested size is not valid
*/
whd_result_t cy_buffer_set_size(whd_buffer_t buffer, uint16_t size);
/** Moves the current pointer of a packet buffer
*
* Since packet buffers usually need to be created with space at the front for additional headers,
* this function allows WHD to move the current 'front' location pointer so that it has space to
* add headers to transmit packets, and so that the network stack does not see the internal WHD
* headers on received packets.
*
* @param buffer : A pointer to the handle of the current packet buffer for which the
* current pointer will be moved. On return this may contain a pointer
* to a newly allocated packet buffer which has been daisy chained to
* the front of the given one. This would be the case if the given
* packet buffer didn't have enough space at the front.
* @param add_remove_amount : This is the number of bytes to move the current pointer of the packet
* buffer - a negative value increases the space for headers at the
* front of the packet, a positive value decreases the space.
*
* @return : CY_RSLT_SUCCESS or WHD_BUFFER_POINTER_MOVE_ERROR if the added amount
* is outside the size of the buffer
*/
whd_result_t cy_buffer_add_remove_at_front(whd_buffer_t* buffer, int32_t add_remove_amount);
/** Called by WHD to pass received data to the network stack
*
* Packets received from the Wi-Fi network by WHD are forwarded to by calling function ptr which
* must be implemented in the network interface. Ethernet headers
* are present at the start of these packet buffers.
*
* This function is called asynchronously in the context of the
* WHD thread whenever new data has arrived.
* Packet buffers are allocated within WHD, and ownership is transferred
* to the network stack. The network stack or application is thus
* responsible for releasing the packet buffers.
* Most packet buffering systems have a pointer to the 'current point' within
* the packet buffer. When this function is called, the pointer points
* to the start of the Ethernet header. There is other inconsequential data
* before the Ethernet header.
*
* It is preferable that the (whd_network_process_ethernet_data)() function simply puts
* the received packet on a queue for processing by another thread. This avoids the
* WHD thread being unnecessarily tied up which would delay other packets
* being transmitted or received.
*
* @param interface : The interface on which the packet was received.
* @param buffer : Handle of the packet which has just been received. Responsibility for
* releasing this buffer is transferred from WHD at this point.
*
*/
void cy_network_process_ethernet_data(whd_interface_t interface, whd_buffer_t buffer);
#ifdef __cplusplus
}
#endif // __cplusplus
/** \} group_bsp_network_buffer */