DPDK  24.03.0
Data Structures | Typedefs | Functions
rte_pdcp.h File Reference
#include <rte_compat.h>
#include <rte_common.h>
#include <rte_mempool.h>
#include <rte_pdcp_hdr.h>
#include <rte_security.h>
#include <rte_pdcp_group.h>

Go to the source code of this file.

Data Structures

struct  rte_pdcp_entity
 
struct  rte_pdcp_t_reordering
 
struct  rte_pdcp_entity_conf
 

Typedefs

typedef void(* rte_pdcp_t_reordering_start_cb_t) (void *timer, void *args)
 
typedef void(* rte_pdcp_t_reordering_stop_cb_t) (void *timer, void *args)
 

Functions

__rte_experimental struct rte_pdcp_entityrte_pdcp_entity_establish (const struct rte_pdcp_entity_conf *conf)
 
__rte_experimental int rte_pdcp_entity_release (struct rte_pdcp_entity *pdcp_entity, struct rte_mbuf *out_mb[])
 
__rte_experimental int rte_pdcp_entity_suspend (struct rte_pdcp_entity *pdcp_entity, struct rte_mbuf *out_mb[])
 
__rte_experimental struct rte_mbufrte_pdcp_control_pdu_create (struct rte_pdcp_entity *pdcp_entity, enum rte_pdcp_ctrl_pdu_type type)
 
static __rte_experimental uint16_t rte_pdcp_pkt_pre_process (const struct rte_pdcp_entity *entity, struct rte_mbuf *mb[], struct rte_crypto_op *cop[], uint16_t num, uint16_t *nb_err)
 
static __rte_experimental uint16_t rte_pdcp_pkt_post_process (const struct rte_pdcp_entity *entity, struct rte_mbuf *in_mb[], struct rte_mbuf *out_mb[], uint16_t num, uint16_t *nb_err)
 
__rte_experimental uint16_t rte_pdcp_t_reordering_expiry_handle (const struct rte_pdcp_entity *entity, struct rte_mbuf *out_mb[])
 

Detailed Description

RTE PDCP support.

A framework for PDCP protocol processing.

Definition in file rte_pdcp.h.

Typedef Documentation

◆ rte_pdcp_t_reordering_start_cb_t

typedef void(* rte_pdcp_t_reordering_start_cb_t) (void *timer, void *args)

Callback function type for t-Reordering timer start, set during PDCP entity establish. This callback is invoked by PDCP library, during t-Reordering timer start event. Only one t-Reordering per receiving PDCP entity would be running at a given time.

See also
struct rte_pdcp_timer
rte_pdcp_entity_establish()
Parameters
timerPointer to timer.
argsPointer to timer arguments.

Definition at line 84 of file rte_pdcp.h.

◆ rte_pdcp_t_reordering_stop_cb_t

typedef void(* rte_pdcp_t_reordering_stop_cb_t) (void *timer, void *args)

Callback function type for t-Reordering timer stop, set during PDCP entity establish. This callback will be invoked by PDCP library, during t-Reordering timer stop event.

See also
struct rte_pdcp_timer
rte_pdcp_entity_establish()
Parameters
timerPointer to timer.
argsPointer to timer arguments.

Definition at line 98 of file rte_pdcp.h.

Function Documentation

◆ rte_pdcp_entity_establish()

__rte_experimental struct rte_pdcp_entity* rte_pdcp_entity_establish ( const struct rte_pdcp_entity_conf conf)
Warning
EXPERIMENTAL: this API may change without prior notice.

5.1.1 PDCP entity establishment

Establish PDCP entity based on provided input configuration.

Parameters
confParameters to be used for initializing PDCP entity object.
Returns
  • Valid handle if success
  • NULL in case of failure. rte_errno will be set to error code.

◆ rte_pdcp_entity_release()

__rte_experimental int rte_pdcp_entity_release ( struct rte_pdcp_entity pdcp_entity,
struct rte_mbuf out_mb[] 
)
Warning
EXPERIMENTAL: this API may change without prior notice.

5.1.3 PDCP entity release

Release PDCP entity.

For UL/transmitting PDCP entity, all stored PDCP SDUs would be dropped. For DL/receiving PDCP entity, the stored PDCP SDUs would be returned in out_mb buffer. The buffer should be large enough to hold all cached packets in the entity.

Entity release would result in freeing all memory associated with the PDCP entity as well as any crypto/security sessions created.

Parameters
pdcp_entityPointer to the PDCP entity to be released.
[out]out_mbThe address of an array that can hold up to rte_pdcp_entity.max_pkt_cache pointers to rte_mbuf structures.
Returns
  • 0: Success and no cached packets to return
  • >0: Success and the number of packets returned in out_mb
  • <0: Error code in case of failures

◆ rte_pdcp_entity_suspend()

__rte_experimental int rte_pdcp_entity_suspend ( struct rte_pdcp_entity pdcp_entity,
struct rte_mbuf out_mb[] 
)
Warning
EXPERIMENTAL: this API may change without prior notice.

5.1.4 PDCP entity suspend

Suspend PDCP entity.

For DL/receiving PDCP entity, the stored PDCP SDUs would be returned in out_mb buffer. The buffer should be large enough to hold all cached packets in the entity.

For UL/transmitting PDCP entity, out_mb buffer would be unused.

Parameters
pdcp_entityPointer to the PDCP entity to be suspended.
[out]out_mbThe address of an array that can hold up to rte_pdcp_entity.max_pkt_cache pointers to rte_mbuf structures.
Returns
  • 0: Success and no cached packets to return.
  • >0: Success and the number of packets returned in out_mb.
  • <0: Error code in case of failures.

◆ rte_pdcp_control_pdu_create()

__rte_experimental struct rte_mbuf* rte_pdcp_control_pdu_create ( struct rte_pdcp_entity pdcp_entity,
enum rte_pdcp_ctrl_pdu_type  type 
)
Warning
EXPERIMENTAL: this API may change without prior notice.

Create control PDU packet of the type specified. The control PDU packet would be allocated from rte_pdcp_entity_conf.ctrl_pdu_pool by lib PDCP.

Parameters
pdcp_entityPointer to the PDCP entity for which the control PDU need to be generated.
typeType of control PDU to be generated.
Returns
  • Control PDU generated, in case of success.
  • NULL in case of failure. rte_errno will be set to error code.

◆ rte_pdcp_pkt_pre_process()

static __rte_experimental uint16_t rte_pdcp_pkt_pre_process ( const struct rte_pdcp_entity entity,
struct rte_mbuf mb[],
struct rte_crypto_op cop[],
uint16_t  num,
uint16_t *  nb_err 
)
inlinestatic
Warning
EXPERIMENTAL: this API may change without prior notice.

For input mbufs and given PDCP entity pre-process the mbufs and prepare crypto ops that can be enqueued to the cryptodev associated with given session. Only error packets would be moved returned in the input buffer, mb, and it is the responsibility of the application to free the same.

Parameters
entityPointer to the rte_pdcp_entity object the packets belong to.
[in,out]mbThe address of an array of num pointers to rte_mbuf structures which contain the input packets. Any error packets would be returned in the same buffer.
[out]copThe address of an array that can hold up to num pointers to rte_crypto_op structures. Crypto ops would be allocated by rte_pdcp_pkt_pre_process API.
numThe maximum number of packets to process.
[out]nb_errPointer to return the number of error packets returned in mb.
Returns
Count of crypto_ops prepared.

Definition at line 293 of file rte_pdcp.h.

◆ rte_pdcp_pkt_post_process()

static __rte_experimental uint16_t rte_pdcp_pkt_post_process ( const struct rte_pdcp_entity entity,
struct rte_mbuf in_mb[],
struct rte_mbuf out_mb[],
uint16_t  num,
uint16_t *  nb_err 
)
inlinestatic
Warning
EXPERIMENTAL: this API may change without prior notice.

For input mbufs and given PDCP entity, perform PDCP post-processing of the mbufs.

Input mbufs are the ones retrieved from rte_crypto_ops dequeued from cryptodev and grouped by rte_pdcp_pkt_crypto_group().

The post-processed packets would be returned in the out_mb buffer. The resultant mbufs would be grouped into success packets and error packets. Error packets would be grouped in the end of the array and it is the responsibility of the application to handle the same.

When in-order delivery is enabled, PDCP entity may buffer packets and would deliver packets only when all prior packets have been post-processed. That would result in returning more/less packets than enqueued.

Parameters
entityPointer to the rte_pdcp_entity object the packets belong to.
in_mbThe address of an array of num pointers to rte_mbuf structures.
[out]out_mbThe address of an array that can hold up to rte_pdcp_entity.max_pkt_cache pointers to rte_mbuf structures to output packets after PDCP post-processing.
numThe maximum number of packets to process.
[out]nb_errThe number of error packets returned in out_mb buffer.
Returns
Count of packets returned in out_mb buffer.

Definition at line 334 of file rte_pdcp.h.

◆ rte_pdcp_t_reordering_expiry_handle()

__rte_experimental uint16_t rte_pdcp_t_reordering_expiry_handle ( const struct rte_pdcp_entity entity,
struct rte_mbuf out_mb[] 
)
Warning
EXPERIMENTAL: this API may change without prior notice

5.2.2.2 Actions when a t-Reordering expires

When t-Reordering timer expires, PDCP is required to slide the reception window by updating state variables such as RX_REORD & RX_DELIV. PDCP would need to deliver some of the buffered packets based on the state variables and conditions described.

The expiry handle need to be invoked by the application when t-Reordering timer expires. In addition to returning buffered packets, it may also restart timer based on the state variables.

Parameters
entityPointer to the rte_pdcp_entity for which the timer expired.
[out]out_mbThe address of an array that can hold up to rte_pdcp_entity.max_pkt_cache pointers to rte_mbuf structures. Used to return buffered packets that are expired.
Returns
Number of packets returned in out_mb buffer.