rte_pmd_cnxk.h - Man Page
Synopsis
#include <rte_compat.h>
#include <rte_ethdev.h>
#include <rte_ether.h>
#include <rte_security.h>
Data Structures
struct rte_pmd_cnxk_cpt_q_stats
union rte_pmd_cnxk_ipsec_outer_ip_hdr
struct rte_pmd_cnxk_ipsec_inb_ctx_update_reg
union rte_pmd_cnxk_ipsec_outb_iv
struct rte_pmd_cnxk_ipsec_outb_ctx_update_reg
struct rte_pmd_cnxk_ipsec_inb_sa
struct rte_pmd_cnxk_ipsec_outb_sa
union rte_pmd_cnxk_ipsec_hw_sa
union rte_pmd_cnxk_cpt_res_s
struct rte_pmd_cnxk_cpt_res_s::rte_pmd_cpt_cn10k_res_s
struct rte_pmd_cnxk_cpt_res_s::rte_pmd_cpt_cn9k_res_s
struct rte_pmd_cnxk_ipsec_inb_cfg
Macros
#define RTE_PMD_CNXK_AR_WIN_SIZE_MIN 64
#define RTE_PMD_CNXK_AR_WINBITS_SZ (RTE_ALIGN_CEIL(RTE_PMD_CNXK_AR_WIN_SIZE_MAX, 64) / 64)
Enumerations
enum rte_pmd_cnxk_sec_action_alg { RTE_PMD_CNXK_SEC_ACTION_ALG0, RTE_PMD_CNXK_SEC_ACTION_ALG1, RTE_PMD_CNXK_SEC_ACTION_ALG2, RTE_PMD_CNXK_SEC_ACTION_ALG3, RTE_PMD_CNXK_SEC_ACTION_ALG4 }
enum rte_pmd_cnxk_cpt_q_stats_type { RTE_PMD_CNXK_CPT_Q_STATS_INL_DEV, RTE_PMD_CNXK_CPT_Q_STATS_KERNEL, RTE_PMD_CNXK_CPT_Q_STATS_ETHDEV }
Functions
__rte_experimental int rte_pmd_cnxk_hw_sa_read (uint16_t portid, void *sess, union rte_pmd_cnxk_ipsec_hw_sa *data, uint32_t len, bool inb)
__rte_experimental int rte_pmd_cnxk_hw_sa_write (uint16_t portid, void *sess, union rte_pmd_cnxk_ipsec_hw_sa *data, uint32_t len, bool inb)
__rte_experimental union rte_pmd_cnxk_cpt_res_s * rte_pmd_cnxk_inl_ipsec_res (struct rte_mbuf *mbuf)
__rte_experimental union rte_pmd_cnxk_ipsec_hw_sa * rte_pmd_cnxk_hw_session_base_get (uint16_t portid, bool inb)
__rte_experimental int rte_pmd_cnxk_sa_flush (uint16_t portid, union rte_pmd_cnxk_ipsec_hw_sa *sess, bool inb)
__rte_experimental struct rte_pmd_cnxk_inl_dev_q * rte_pmd_cnxk_inl_dev_qptr_get (void)
__rte_experimental uint16_t rte_pmd_cnxk_inl_dev_submit (struct rte_pmd_cnxk_inl_dev_q *qptr, void *inst, uint16_t nb_inst)
__rte_experimental int rte_pmd_cnxk_cpt_q_stats_get (uint16_t portid, enum rte_pmd_cnxk_cpt_q_stats_type type, struct rte_pmd_cnxk_cpt_q_stats *stats, uint16_t idx)
__rte_experimental void rte_pmd_cnxk_hw_inline_inb_cfg_set (uint16_t portid, struct rte_pmd_cnxk_ipsec_inb_cfg *cfg)
__rte_experimental const char * rte_pmd_cnxk_model_str_get (void)
Detailed Description
CNXK PMD specific functions.
Definition in file rte_pmd_cnxk.h.
Macro Definition Documentation
#define RTE_PMD_CNXK_AR_WIN_SIZE_MIN 64
Anti reply window size supported
Definition at line 91 of file rte_pmd_cnxk.h.
#define RTE_PMD_CNXK_AR_WINBITS_SZ (RTE_ALIGN_CEIL(RTE_PMD_CNXK_AR_WIN_SIZE_MAX, 64) / 64)
u64 array size to fit anti replay window bits
Definition at line 96 of file rte_pmd_cnxk.h.
Enumeration Type Documentation
enum rte_pmd_cnxk_sec_action_alg
Algorithm type to be used with security action to calculate SA_index
Enumerator
- RTE_PMD_CNXK_SEC_ACTION_ALG0
No swizzling of SPI bits into SA index. SA_index is from SA_XOR if enabled.
- RTE_PMD_CNXK_SEC_ACTION_ALG1
SPI<31:28> has 4 upper bits which segment the sequence number space. Initial SA_index is from SA_XOR if enabled. SA_alg = { 4'b0, SA_mcam[27:0] + SPI[31:28]}
- RTE_PMD_CNXK_SEC_ACTION_ALG2
SPI<27:25> segment the sequence number space. Initial SA_index is from SA_XOR if enabled. SA_alg = { 7'b0, SA_mcam[24:0] + SPI[27:25]}
- RTE_PMD_CNXK_SEC_ACTION_ALG3
SPI<28:25> segment the sequence number space. Initial SA_index is from SA_XOR if enabled. SA_alg = { 7'b0, SA_mcam[24:0] + SPI[28:25]}
- RTE_PMD_CNXK_SEC_ACTION_ALG4
The inbound SPI maybe "random", therefore we want the MCAM to be capable of remapping the SPI to an arbitrary SA_index. SPI to SA is done using a lookup in NIX/NPC cam entry with key as SPI, MATCH_ID, LFID.
Definition at line 22 of file rte_pmd_cnxk.h.
enum rte_pmd_cnxk_cpt_q_stats_type
CPT queue type for obtaining queue hardware statistics.
Enumerator
- RTE_PMD_CNXK_CPT_Q_STATS_INL_DEV
Type to get Inline Device queue(s) statistics
- RTE_PMD_CNXK_CPT_Q_STATS_KERNEL
Type to get Inline Inbound queue which is attached to kernel device statistics.
- RTE_PMD_CNXK_CPT_Q_STATS_ETHDEV
Type to get CPT queue which is attached to ethdev statistics
Definition at line 51 of file rte_pmd_cnxk.h.
Function Documentation
__rte_experimental int rte_pmd_cnxk_hw_sa_read (uint16_t portid, void * sess, union rte_pmd_cnxk_ipsec_hw_sa * data, uint32_t len, bool inb)
Read HW SA context from session.
- Parameters
portid Port identifier of Ethernet device.
sess Handle of the security session as void *.
data Destination pointer to copy SA context for application.
len Length of SA context to copy into data parameter.
inb Determines the type of specified SA.
Returns
0 on success, a negative errno value otherwise.
__rte_experimental int rte_pmd_cnxk_hw_sa_write (uint16_t portid, void * sess, union rte_pmd_cnxk_ipsec_hw_sa * data, uint32_t len, bool inb)
Write HW SA context to session.
- Parameters
portid Port identifier of Ethernet device.
sess Handle of the security session as void *.
data Source data pointer from application to copy SA context into session.
len Length of SA context to copy from data parameter.
inb Determines the type of specified SA.
Returns
0 on success, a negative errno value otherwise.
__rte_experimental union rte_pmd_cnxk_cpt_res_s * rte_pmd_cnxk_inl_ipsec_res (struct rte_mbuf * mbuf)
Get pointer to CPT result info for inline inbound processed pkt.
It is recommended to use this API only when mbuf indicates packet was processed with inline IPsec and there was a failure with the same i.e mbuf->ol_flags indicates (RTE_MBUF_F_RX_SEC_OFFLOAD | RTE_MBUF_F_RX_SEC_OFFLOAD_FAILED).
- Parameters
mbuf Pointer to packet that was just received and was processed with Inline IPsec.
- Returns
- Pointer to mbuf location where union rte_pmd_cnxk_cpt_res_s is stored on success.
- NULL on failure.
__rte_experimental union rte_pmd_cnxk_ipsec_hw_sa * rte_pmd_cnxk_hw_session_base_get (uint16_t portid, bool inb)
Get pointer to the Inline Inbound or Outbound SA table base.
- Parameters
portid Port identifier of Ethernet device.
inb Determines the type of SA base to be returned. When inb is true, the method returns the Inbound SA base. When inb is false, the method returns the Outbound SA base.- Returns
Pointer to Inbound or Outbound SA base.
__rte_experimental int rte_pmd_cnxk_sa_flush (uint16_t portid, union rte_pmd_cnxk_ipsec_hw_sa * sess, bool inb)
Executes a CPT flush on the specified session.
- Parameters
portid Port identifier of Ethernet device.
sess Handle of the session on which the CPT flush will be executed.
inb Determines the type of SA to be flushed, Inbound or Outbound.
Returns
0 Upon success, a negative errno value otherwise.
__rte_experimental struct rte_pmd_cnxk_inl_dev_q * rte_pmd_cnxk_inl_dev_qptr_get (void )
Get queue pointer of Inline Device.
- Returns
- Pointer to queue structure that would be the input to submit API.
- NULL upon failure.
__rte_experimental uint16_t rte_pmd_cnxk_inl_dev_submit (struct rte_pmd_cnxk_inl_dev_q * qptr, void * inst, uint16_t nb_inst)
Submit CPT instruction(s) (cpt_inst_s) to Inline Device.
- Parameters
qptr Pointer obtained with rte_pmd_cnxk_inl_dev_qptr_get.
inst Pointer to an array of cpt_inst_s prapared by application.
nb_inst Number of instructions to be processed.- Returns
Number of instructions processed.
__rte_experimental int rte_pmd_cnxk_cpt_q_stats_get (uint16_t portid, enum rte_pmd_cnxk_cpt_q_stats_type type, struct rte_pmd_cnxk_cpt_q_stats * stats, uint16_t idx)
Retrieves the hardware statistics of a given port and stats type.
- Parameters
portid Port identifier of Ethernet device.
type The type of hardware statistics to retrieve, as defined in the enum rte_pmd_cnxk_cpt_q_stats_type.
stats Pointer where the retrieved statistics will be stored.
idx The index of the queue of a given type.
Returns
0 Upon success, a negative errno value otherwise.
__rte_experimental void rte_pmd_cnxk_hw_inline_inb_cfg_set (uint16_t portid, struct rte_pmd_cnxk_ipsec_inb_cfg * cfg)
Set the configuration for hardware inline inbound IPsec processing. This API must be called before calling the rte_eth_dev_configure API.
- Parameters
portid Port identifier of Ethernet device.
cfg Pointer to the IPsec inbound configuration structure.
__rte_experimental const char * rte_pmd_cnxk_model_str_get (void )
Retrieves model name on which it is running as a string.
- Returns
Returns model string, ex."cn10ka_a1"
Author
Generated automatically by Doxygen for DPDK from the source code.
Referenced By
The man pages RTE_PMD_CNXK_AR_WINBITS_SZ(3), RTE_PMD_CNXK_AR_WIN_SIZE_MIN(3), RTE_PMD_CNXK_CPT_Q_STATS_ETHDEV(3), rte_pmd_cnxk_cpt_q_stats_get(3), RTE_PMD_CNXK_CPT_Q_STATS_INL_DEV(3), RTE_PMD_CNXK_CPT_Q_STATS_KERNEL(3), rte_pmd_cnxk_cpt_q_stats_type(3), rte_pmd_cnxk_hw_inline_inb_cfg_set(3), rte_pmd_cnxk_hw_sa_read(3), rte_pmd_cnxk_hw_sa_write(3), rte_pmd_cnxk_hw_session_base_get(3), rte_pmd_cnxk_inl_dev_qptr_get(3), rte_pmd_cnxk_inl_dev_submit(3), rte_pmd_cnxk_inl_ipsec_res(3), rte_pmd_cnxk_model_str_get(3), rte_pmd_cnxk_sa_flush(3), rte_pmd_cnxk_sec_action_alg(3), RTE_PMD_CNXK_SEC_ACTION_ALG0(3), RTE_PMD_CNXK_SEC_ACTION_ALG1(3), RTE_PMD_CNXK_SEC_ACTION_ALG2(3), RTE_PMD_CNXK_SEC_ACTION_ALG3(3) and RTE_PMD_CNXK_SEC_ACTION_ALG4(3) are aliases of rte_pmd_cnxk.h(3).