crypto/octeontx2: discover capabilities

Populate capabilities based on device features.

Signed-off-by: Anoob Joseph <anoobj@marvell.com>
Signed-off-by: Tejasree Kondoj <ktejasree@marvell.com>
This commit is contained in:
Tejasree Kondoj 2020-06-16 18:32:15 +05:30 committed by Thomas Monjalon
parent b69f927d52
commit a0645ed0d6
9 changed files with 428 additions and 296 deletions

View File

@ -198,6 +198,7 @@ M(CPT_INLINE_IPSEC_CFG, 0xA04, cpt_inline_ipsec_cfg, \
cpt_inline_ipsec_cfg_msg, msg_rsp) \ cpt_inline_ipsec_cfg_msg, msg_rsp) \
M(CPT_RX_INLINE_LF_CFG, 0xBFE, cpt_rx_inline_lf_cfg, \ M(CPT_RX_INLINE_LF_CFG, 0xBFE, cpt_rx_inline_lf_cfg, \
cpt_rx_inline_lf_cfg_msg, msg_rsp) \ cpt_rx_inline_lf_cfg_msg, msg_rsp) \
M(CPT_GET_CAPS, 0xBFD, cpt_caps_get, msg_req, cpt_caps_rsp_msg) \
/* NPC mbox IDs (range 0x6000 - 0x7FFF) */ \ /* NPC mbox IDs (range 0x6000 - 0x7FFF) */ \
M(NPC_MCAM_ALLOC_ENTRY, 0x6000, npc_mcam_alloc_entry, \ M(NPC_MCAM_ALLOC_ENTRY, 0x6000, npc_mcam_alloc_entry, \
npc_mcam_alloc_entry_req, \ npc_mcam_alloc_entry_req, \
@ -1258,6 +1259,38 @@ struct cpt_rx_inline_lf_cfg_msg {
uint16_t __otx2_io sso_pf_func; uint16_t __otx2_io sso_pf_func;
}; };
enum cpt_eng_type {
CPT_ENG_TYPE_AE = 1,
CPT_ENG_TYPE_SE = 2,
CPT_ENG_TYPE_IE = 3,
CPT_MAX_ENG_TYPES,
};
/* CPT HW capabilities */
union cpt_eng_caps {
uint64_t __otx2_io u;
struct {
uint64_t __otx2_io reserved_0_4:5;
uint64_t __otx2_io mul:1;
uint64_t __otx2_io sha1_sha2:1;
uint64_t __otx2_io chacha20:1;
uint64_t __otx2_io zuc_snow3g:1;
uint64_t __otx2_io sha3:1;
uint64_t __otx2_io aes:1;
uint64_t __otx2_io kasumi:1;
uint64_t __otx2_io des:1;
uint64_t __otx2_io crc:1;
uint64_t __otx2_io reserved_14_63:50;
};
};
struct cpt_caps_rsp_msg {
struct mbox_msghdr hdr;
uint16_t __otx2_io cpt_pf_drv_version;
uint8_t __otx2_io cpt_revision;
union cpt_eng_caps eng_caps[CPT_MAX_ENG_TYPES];
};
/* NPC mbox message structs */ /* NPC mbox message structs */
#define NPC_MCAM_ENTRY_INVALID 0xFFFF #define NPC_MCAM_ENTRY_INVALID 0xFFFF

View File

@ -14,6 +14,7 @@
#include "otx2_common.h" #include "otx2_common.h"
#include "otx2_cryptodev.h" #include "otx2_cryptodev.h"
#include "otx2_cryptodev_capabilities.h"
#include "otx2_cryptodev_mbox.h" #include "otx2_cryptodev_mbox.h"
#include "otx2_cryptodev_ops.h" #include "otx2_cryptodev_ops.h"
#include "otx2_dev.h" #include "otx2_dev.h"
@ -94,6 +95,12 @@ otx2_cpt_pci_probe(struct rte_pci_driver *pci_drv __rte_unused,
CPT_LOG_INFO("Max queues supported by device: %d", vf->max_queues); CPT_LOG_INFO("Max queues supported by device: %d", vf->max_queues);
ret = otx2_cpt_hardware_caps_get(dev, vf->hw_caps);
if (ret) {
CPT_LOG_ERR("Could not determine hardware capabilities");
goto otx2_dev_fini;
}
dev->feature_flags = RTE_CRYPTODEV_FF_SYMMETRIC_CRYPTO | dev->feature_flags = RTE_CRYPTODEV_FF_SYMMETRIC_CRYPTO |
RTE_CRYPTODEV_FF_HW_ACCELERATED | RTE_CRYPTODEV_FF_HW_ACCELERATED |
RTE_CRYPTODEV_FF_SYM_OPERATION_CHAINING | RTE_CRYPTODEV_FF_SYM_OPERATION_CHAINING |

View File

@ -29,6 +29,8 @@ struct otx2_cpt_vf {
/**< MSI-X offsets */ /**< MSI-X offsets */
uint8_t err_intr_registered:1; uint8_t err_intr_registered:1;
/**< Are error interrupts registered? */ /**< Are error interrupts registered? */
union cpt_eng_caps hw_caps[CPT_MAX_ENG_TYPES];
/**< CPT device capabilities */
}; };
#define CPT_LOGTYPE otx2_cpt_logtype #define CPT_LOGTYPE otx2_cpt_logtype

View File

@ -5,115 +5,87 @@
#include <rte_cryptodev.h> #include <rte_cryptodev.h>
#include "otx2_cryptodev_capabilities.h" #include "otx2_cryptodev_capabilities.h"
#include "otx2_mbox.h"
static const struct #define CPT_EGRP_GET(hw_caps, name, egrp) do { \
rte_cryptodev_capabilities otx2_cpt_capabilities[] = { if ((hw_caps[CPT_ENG_TYPE_SE].name) && \
/* Symmetric capabilities */ (hw_caps[CPT_ENG_TYPE_IE].name)) \
{ /* NULL (AUTH) */ *egrp = OTX2_CPT_EGRP_SE_IE; \
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, else if (hw_caps[CPT_ENG_TYPE_SE].name) \
{.sym = { *egrp = OTX2_CPT_EGRP_SE; \
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH, else if (hw_caps[CPT_ENG_TYPE_AE].name) \
{.auth = { *egrp = OTX2_CPT_EGRP_AE; \
.algo = RTE_CRYPTO_AUTH_NULL, else \
.block_size = 1, *egrp = OTX2_CPT_EGRP_MAX; \
.key_size = { } while (0)
.min = 0,
.max = 0, #define CPT_CAPS_ADD(hw_caps, name) do { \
.increment = 0 enum otx2_cpt_egrp egrp; \
}, CPT_EGRP_GET(hw_caps, name, &egrp); \
.digest_size = { if (egrp < OTX2_CPT_EGRP_MAX) \
.min = 0, cpt_caps_add(caps_##name, RTE_DIM(caps_##name)); \
.max = 0, } while (0)
.increment = 0
}, #define OTX2_CPT_MAX_CAPS 34
}, },
}, }, static struct rte_cryptodev_capabilities otx2_cpt_caps[OTX2_CPT_MAX_CAPS];
static const struct rte_cryptodev_capabilities caps_mul[] = {
{ /* RSA */
.op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC,
{.asym = {
.xform_capa = {
.xform_type = RTE_CRYPTO_ASYM_XFORM_RSA,
.op_types = ((1 << RTE_CRYPTO_ASYM_OP_SIGN) |
(1 << RTE_CRYPTO_ASYM_OP_VERIFY) |
(1 << RTE_CRYPTO_ASYM_OP_ENCRYPT) |
(1 << RTE_CRYPTO_ASYM_OP_DECRYPT)),
{.modlen = {
.min = 17,
.max = 1024,
.increment = 1
}, }
}
}, }
}, },
{ /* AES GMAC (AUTH) */ { /* MOD_EXP */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC,
{.sym = { {.asym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH, .xform_capa = {
{.auth = { .xform_type = RTE_CRYPTO_ASYM_XFORM_MODEX,
.algo = RTE_CRYPTO_AUTH_AES_GMAC, .op_types = 0,
.block_size = 16, {.modlen = {
.key_size = { .min = 17,
.min = 16, .max = 1024,
.max = 32, .increment = 1
.increment = 8 }, }
}, }
.digest_size = { }, }
.min = 8, },
.max = 16, { /* ECDSA */
.increment = 4 .op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC,
}, {.asym = {
.iv_size = { .xform_capa = {
.min = 12, .xform_type = RTE_CRYPTO_ASYM_XFORM_ECDSA,
.max = 12, .op_types = ((1 << RTE_CRYPTO_ASYM_OP_SIGN) |
.increment = 0 (1 << RTE_CRYPTO_ASYM_OP_VERIFY)),
} }
}, } },
}, } }
}, },
{ /* KASUMI (F9) */ { /* ECPM */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC,
{.sym = { {.asym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH, .xform_capa = {
{.auth = { .xform_type = RTE_CRYPTO_ASYM_XFORM_ECPM,
.algo = RTE_CRYPTO_AUTH_KASUMI_F9, .op_types = 0
.block_size = 8, }
.key_size = { },
.min = 16, }
.max = 16,
.increment = 0
},
.digest_size = {
.min = 4,
.max = 4,
.increment = 0
},
}, }
}, }
},
{ /* MD5 */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH,
{.auth = {
.algo = RTE_CRYPTO_AUTH_MD5,
.block_size = 64,
.key_size = {
.min = 0,
.max = 0,
.increment = 0
},
.digest_size = {
.min = 16,
.max = 16,
.increment = 0
},
}, }
}, }
},
{ /* MD5 HMAC */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH,
{.auth = {
.algo = RTE_CRYPTO_AUTH_MD5_HMAC,
.block_size = 64,
.key_size = {
.min = 8,
.max = 64,
.increment = 8
},
.digest_size = {
.min = 16,
.max = 16,
.increment = 0
},
}, }
}, }
}, },
};
static const struct rte_cryptodev_capabilities caps_sha1_sha2[] = {
{ /* SHA1 */ { /* SHA1 */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = { {.sym = {
@ -147,9 +119,9 @@ rte_cryptodev_capabilities otx2_cpt_capabilities[] = {
.increment = 1 .increment = 1
}, },
.digest_size = { .digest_size = {
.min = 20, .min = 12,
.max = 20, .max = 20,
.increment = 0 .increment = 8
}, },
}, } }, }
}, } }, }
@ -227,9 +199,9 @@ rte_cryptodev_capabilities otx2_cpt_capabilities[] = {
.increment = 1 .increment = 1
}, },
.digest_size = { .digest_size = {
.min = 32, .min = 16,
.max = 32, .max = 32,
.increment = 0 .increment = 16
}, },
}, } }, }
}, } }, }
@ -267,9 +239,9 @@ rte_cryptodev_capabilities otx2_cpt_capabilities[] = {
.increment = 1 .increment = 1
}, },
.digest_size = { .digest_size = {
.min = 48, .min = 24,
.max = 48, .max = 48,
.increment = 0 .increment = 24
}, },
}, } }, }
}, } }, }
@ -307,10 +279,93 @@ rte_cryptodev_capabilities otx2_cpt_capabilities[] = {
.increment = 1 .increment = 1
}, },
.digest_size = { .digest_size = {
.min = 64, .min = 32,
.max = 64, .max = 64,
.increment = 32
},
}, }
}, }
},
{ /* MD5 */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH,
{.auth = {
.algo = RTE_CRYPTO_AUTH_MD5,
.block_size = 64,
.key_size = {
.min = 0,
.max = 0,
.increment = 0 .increment = 0
}, },
.digest_size = {
.min = 16,
.max = 16,
.increment = 0
},
}, }
}, }
},
{ /* MD5 HMAC */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH,
{.auth = {
.algo = RTE_CRYPTO_AUTH_MD5_HMAC,
.block_size = 64,
.key_size = {
.min = 8,
.max = 64,
.increment = 8
},
.digest_size = {
.min = 12,
.max = 16,
.increment = 4
},
}, }
}, }
},
};
static const struct rte_cryptodev_capabilities caps_zuc_snow3g[] = {
{ /* SNOW 3G (UEA2) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_SNOW3G_UEA2,
.block_size = 16,
.key_size = {
.min = 16,
.max = 16,
.increment = 0
},
.iv_size = {
.min = 16,
.max = 16,
.increment = 0
}
}, }
}, }
},
{ /* ZUC (EEA3) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_ZUC_EEA3,
.block_size = 16,
.key_size = {
.min = 16,
.max = 16,
.increment = 0
},
.iv_size = {
.min = 16,
.max = 16,
.increment = 0
}
}, } }, }
}, } }, }
}, },
@ -364,61 +419,29 @@ rte_cryptodev_capabilities otx2_cpt_capabilities[] = {
}, } }, }
}, } }, }
}, },
{ /* NULL (CIPHER) */ };
static const struct rte_cryptodev_capabilities caps_aes[] = {
{ /* AES GMAC (AUTH) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = { {.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER, .xform_type = RTE_CRYPTO_SYM_XFORM_AUTH,
{.cipher = { {.auth = {
.algo = RTE_CRYPTO_CIPHER_NULL, .algo = RTE_CRYPTO_AUTH_AES_GMAC,
.block_size = 1, .block_size = 16,
.key_size = { .key_size = {
.min = 0, .min = 16,
.max = 0, .max = 32,
.increment = 0 .increment = 8
}, },
.iv_size = { .digest_size = {
.min = 0,
.max = 0,
.increment = 0
}
}, },
}, }
},
{ /* 3DES CBC */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_3DES_CBC,
.block_size = 8,
.key_size = {
.min = 24,
.max = 24,
.increment = 0
},
.iv_size = {
.min = 8, .min = 8,
.max = 16, .max = 16,
.increment = 8 .increment = 4
}
}, }
}, }
},
{ /* 3DES ECB */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_3DES_ECB,
.block_size = 8,
.key_size = {
.min = 24,
.max = 24,
.increment = 0
}, },
.iv_size = { .iv_size = {
.min = 0, .min = 12,
.max = 0, .max = 12,
.increment = 0 .increment = 0
} }
}, } }, }
@ -484,86 +507,6 @@ rte_cryptodev_capabilities otx2_cpt_capabilities[] = {
}, } }, }
}, } }, }
}, },
{ /* DES CBC */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_DES_CBC,
.block_size = 8,
.key_size = {
.min = 8,
.max = 8,
.increment = 0
},
.iv_size = {
.min = 8,
.max = 8,
.increment = 0
}
}, }
}, }
},
{ /* KASUMI (F8) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_KASUMI_F8,
.block_size = 8,
.key_size = {
.min = 16,
.max = 16,
.increment = 0
},
.iv_size = {
.min = 8,
.max = 8,
.increment = 0
}
}, }
}, }
},
{ /* SNOW 3G (UEA2) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_SNOW3G_UEA2,
.block_size = 16,
.key_size = {
.min = 16,
.max = 16,
.increment = 0
},
.iv_size = {
.min = 16,
.max = 16,
.increment = 0
}
}, }
}, }
},
{ /* ZUC (EEA3) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_ZUC_EEA3,
.block_size = 16,
.key_size = {
.min = 16,
.max = 16,
.increment = 0
},
.iv_size = {
.min = 16,
.max = 16,
.increment = 0
}
}, }
}, }
},
{ /* AES GCM */ { /* AES GCM */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = { {.sym = {
@ -594,67 +537,186 @@ rte_cryptodev_capabilities otx2_cpt_capabilities[] = {
}, } }, }
}, } }, }
}, },
/* End of symmetric capabilities */ };
/* Asymmetric capabilities */ static const struct rte_cryptodev_capabilities caps_kasumi[] = {
{ /* RSA */ { /* KASUMI (F8) */
.op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.asym = { {.sym = {
.xform_capa = { .xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
.xform_type = RTE_CRYPTO_ASYM_XFORM_RSA, {.cipher = {
.op_types = ((1 << RTE_CRYPTO_ASYM_OP_SIGN) | .algo = RTE_CRYPTO_CIPHER_KASUMI_F8,
(1 << RTE_CRYPTO_ASYM_OP_VERIFY) | .block_size = 8,
(1 << RTE_CRYPTO_ASYM_OP_ENCRYPT) | .key_size = {
(1 << RTE_CRYPTO_ASYM_OP_DECRYPT)), .min = 16,
{.modlen = { .max = 16,
.min = 17, .increment = 0
.max = 1024, },
.increment = 1 .iv_size = {
}, } .min = 8,
} .max = 8,
.increment = 0
}
}, }
}, } }, }
}, },
{ /* MOD_EXP */ { /* KASUMI (F9) */
.op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.asym = { {.sym = {
.xform_capa = { .xform_type = RTE_CRYPTO_SYM_XFORM_AUTH,
.xform_type = RTE_CRYPTO_ASYM_XFORM_MODEX, {.auth = {
.op_types = 0, .algo = RTE_CRYPTO_AUTH_KASUMI_F9,
{.modlen = { .block_size = 8,
.min = 17, .key_size = {
.max = 1024, .min = 16,
.increment = 1 .max = 16,
}, } .increment = 0
} },
.digest_size = {
.min = 4,
.max = 4,
.increment = 0
},
}, }
}, } }, }
}, },
{ /* ECDSA */ };
.op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC,
{.asym = { static const struct rte_cryptodev_capabilities caps_des[] = {
.xform_capa = { { /* 3DES CBC */
.xform_type = RTE_CRYPTO_ASYM_XFORM_ECDSA, .op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
.op_types = ((1 << RTE_CRYPTO_ASYM_OP_SIGN) | {.sym = {
(1 << RTE_CRYPTO_ASYM_OP_VERIFY)), .xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_3DES_CBC,
.block_size = 8,
.key_size = {
.min = 24,
.max = 24,
.increment = 0
},
.iv_size = {
.min = 8,
.max = 16,
.increment = 8
} }
}, }, }
} }, }
}, },
{ /* ECPM */ { /* 3DES ECB */
.op = RTE_CRYPTO_OP_TYPE_ASYMMETRIC, .op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.asym = { {.sym = {
.xform_capa = { .xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
.xform_type = RTE_CRYPTO_ASYM_XFORM_ECPM, {.cipher = {
.op_types = 0 .algo = RTE_CRYPTO_CIPHER_3DES_ECB,
.block_size = 8,
.key_size = {
.min = 24,
.max = 24,
.increment = 0
},
.iv_size = {
.min = 0,
.max = 0,
.increment = 0
} }
}, }, }
} }, }
}, },
/* End of asymmetric capabilities */ { /* DES CBC */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_DES_CBC,
.block_size = 8,
.key_size = {
.min = 8,
.max = 8,
.increment = 0
},
.iv_size = {
.min = 8,
.max = 8,
.increment = 0
}
}, }
}, }
},
};
static const struct rte_cryptodev_capabilities caps_null[] = {
{ /* NULL (AUTH) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH,
{.auth = {
.algo = RTE_CRYPTO_AUTH_NULL,
.block_size = 1,
.key_size = {
.min = 0,
.max = 0,
.increment = 0
},
.digest_size = {
.min = 0,
.max = 0,
.increment = 0
},
}, },
}, },
},
{ /* NULL (CIPHER) */
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC,
{.sym = {
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER,
{.cipher = {
.algo = RTE_CRYPTO_CIPHER_NULL,
.block_size = 1,
.key_size = {
.min = 0,
.max = 0,
.increment = 0
},
.iv_size = {
.min = 0,
.max = 0,
.increment = 0
}
}, },
}, }
},
};
static const struct rte_cryptodev_capabilities caps_end[] = {
RTE_CRYPTODEV_END_OF_CAPABILITIES_LIST() RTE_CRYPTODEV_END_OF_CAPABILITIES_LIST()
}; };
const struct rte_cryptodev_capabilities * static void
otx2_cpt_capabilities_get(void) cpt_caps_add(const struct rte_cryptodev_capabilities *caps, int nb_caps)
{ {
return otx2_cpt_capabilities; static int cur_pos;
if (cur_pos + nb_caps > OTX2_CPT_MAX_CAPS)
return;
memcpy(&otx2_cpt_caps[cur_pos], caps, nb_caps * sizeof(caps[0]));
cur_pos += nb_caps;
}
const struct rte_cryptodev_capabilities *
otx2_cpt_capabilities_get(union cpt_eng_caps *hw_caps)
{
CPT_CAPS_ADD(hw_caps, mul);
CPT_CAPS_ADD(hw_caps, sha1_sha2);
CPT_CAPS_ADD(hw_caps, zuc_snow3g);
CPT_CAPS_ADD(hw_caps, aes);
CPT_CAPS_ADD(hw_caps, kasumi);
CPT_CAPS_ADD(hw_caps, des);
cpt_caps_add(caps_null, RTE_DIM(caps_null));
cpt_caps_add(caps_end, RTE_DIM(caps_end));
return otx2_cpt_caps;
} }

View File

@ -7,10 +7,20 @@
#include <rte_cryptodev.h> #include <rte_cryptodev.h>
#include "otx2_mbox.h"
enum otx2_cpt_egrp {
OTX2_CPT_EGRP_SE = 0,
OTX2_CPT_EGRP_SE_IE = 1,
OTX2_CPT_EGRP_AE = 2,
OTX2_CPT_EGRP_MAX,
};
/* /*
* Get capabilities list for the device * Get capabilities list for the device
* *
*/ */
const struct rte_cryptodev_capabilities *otx2_cpt_capabilities_get(void); const struct rte_cryptodev_capabilities *
otx2_cpt_capabilities_get(union cpt_eng_caps *hw_caps);
#endif /* _OTX2_CRYPTODEV_CAPABILITIES_H_ */ #endif /* _OTX2_CRYPTODEV_CAPABILITIES_H_ */

View File

@ -14,6 +14,27 @@
#include "cpt_pmd_logs.h" #include "cpt_pmd_logs.h"
int
otx2_cpt_hardware_caps_get(const struct rte_cryptodev *dev,
union cpt_eng_caps *hw_caps)
{
struct otx2_cpt_vf *vf = dev->data->dev_private;
struct otx2_dev *otx2_dev = &vf->otx2_dev;
struct cpt_caps_rsp_msg *rsp;
int ret;
otx2_mbox_alloc_msg_cpt_caps_get(otx2_dev->mbox);
ret = otx2_mbox_process_msg(otx2_dev->mbox, (void *)&rsp);
if (ret)
return -EIO;
memcpy(hw_caps, rsp->eng_caps,
sizeof(union cpt_eng_caps) * CPT_MAX_ENG_TYPES);
return 0;
}
int int
otx2_cpt_available_queues_get(const struct rte_cryptodev *dev, otx2_cpt_available_queues_get(const struct rte_cryptodev *dev,
uint16_t *nb_queues) uint16_t *nb_queues)

View File

@ -9,6 +9,9 @@
#include "otx2_cryptodev_hw_access.h" #include "otx2_cryptodev_hw_access.h"
int otx2_cpt_hardware_caps_get(const struct rte_cryptodev *dev,
union cpt_eng_caps *hw_caps);
int otx2_cpt_available_queues_get(const struct rte_cryptodev *dev, int otx2_cpt_available_queues_get(const struct rte_cryptodev *dev,
uint16_t *nb_queues); uint16_t *nb_queues);

View File

@ -1070,7 +1070,7 @@ otx2_cpt_dev_info_get(struct rte_cryptodev *dev,
if (info != NULL) { if (info != NULL) {
info->max_nb_queue_pairs = vf->max_queues; info->max_nb_queue_pairs = vf->max_queues;
info->feature_flags = dev->feature_flags; info->feature_flags = dev->feature_flags;
info->capabilities = otx2_cpt_capabilities_get(); info->capabilities = otx2_cpt_capabilities_get(vf->hw_caps);
info->sym.max_nb_sessions = 0; info->sym.max_nb_sessions = 0;
info->driver_id = otx2_cryptodev_driver_id; info->driver_id = otx2_cryptodev_driver_id;
info->min_mbuf_headroom_req = OTX2_CPT_MIN_HEADROOM_REQ; info->min_mbuf_headroom_req = OTX2_CPT_MIN_HEADROOM_REQ;

View File

@ -10,12 +10,6 @@
#define OTX2_CPT_MIN_HEADROOM_REQ 24 #define OTX2_CPT_MIN_HEADROOM_REQ 24
#define OTX2_CPT_MIN_TAILROOM_REQ 8 #define OTX2_CPT_MIN_TAILROOM_REQ 8
enum otx2_cpt_egrp {
OTX2_CPT_EGRP_SE = 0,
OTX2_CPT_EGRP_SE_IE = 1,
OTX2_CPT_EGRP_AE = 2
};
extern struct rte_cryptodev_ops otx2_cpt_ops; extern struct rte_cryptodev_ops otx2_cpt_ops;
#endif /* _OTX2_CRYPTODEV_OPS_H_ */ #endif /* _OTX2_CRYPTODEV_OPS_H_ */