#include <rte_compat.h>
#include <rte_ethdev.h>
#include <rte_ether.h>
#include <rte_security.h>
Go to the source code of this file.
|
__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) |
|
CNXK PMD specific functions.
Definition in file rte_pmd_cnxk.h.
◆ RTE_PMD_CNXK_AR_WIN_SIZE_MIN
#define RTE_PMD_CNXK_AR_WIN_SIZE_MIN 64 |
◆ RTE_PMD_CNXK_AR_WINBITS_SZ
#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.
◆ 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.
◆ 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.
◆ rte_pmd_cnxk_hw_sa_read()
__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 *. |
[out] | 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_pmd_cnxk_hw_sa_write()
__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 *. |
[in] | 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_pmd_cnxk_inl_ipsec_res()
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
-
◆ rte_pmd_cnxk_hw_session_base_get()
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_pmd_cnxk_sa_flush()
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_pmd_cnxk_inl_dev_qptr_get()
__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_pmd_cnxk_inl_dev_submit()
__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_pmd_cnxk_cpt_q_stats_get()
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_pmd_cnxk_hw_inline_inb_cfg_set()
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_pmd_cnxk_model_str_get()
__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"