2019-06-25 11:12:58 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2015-2018 Intel Corporation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _QAT_SYM_PMD_H_
|
|
|
|
#define _QAT_SYM_PMD_H_
|
|
|
|
|
|
|
|
#ifdef BUILD_QAT_SYM
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
#include <rte_ether.h>
|
2019-06-25 11:12:58 +00:00
|
|
|
#include <rte_cryptodev.h>
|
2021-02-05 08:48:47 +00:00
|
|
|
#ifdef RTE_LIB_SECURITY
|
|
|
|
#include <rte_security.h>
|
|
|
|
#endif
|
2019-06-25 11:12:58 +00:00
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
#include "qat_crypto.h"
|
2019-06-25 11:12:58 +00:00
|
|
|
#include "qat_device.h"
|
|
|
|
|
2022-09-02 04:40:05 +00:00
|
|
|
/** Intel(R) QAT Symmetric Crypto PMD name */
|
2019-06-25 11:12:58 +00:00
|
|
|
#define CRYPTODEV_NAME_QAT_SYM_PMD crypto_qat
|
|
|
|
|
2021-01-28 17:08:59 +00:00
|
|
|
/* Internal capabilities */
|
|
|
|
#define QAT_SYM_CAP_MIXED_CRYPTO (1 << 0)
|
|
|
|
#define QAT_SYM_CAP_VALID (1 << 31)
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
/**
|
|
|
|
* Macro to add a sym capability
|
|
|
|
* helper function to add an sym capability
|
|
|
|
* <n: name> <b: block size> <k: key size> <d: digest size>
|
|
|
|
* <a: aad_size> <i: iv_size>
|
|
|
|
**/
|
|
|
|
#define QAT_SYM_PLAIN_AUTH_CAP(n, b, d) \
|
|
|
|
{ \
|
|
|
|
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, \
|
|
|
|
{.sym = { \
|
|
|
|
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH, \
|
|
|
|
{.auth = { \
|
|
|
|
.algo = RTE_CRYPTO_AUTH_##n, \
|
|
|
|
b, d \
|
|
|
|
}, } \
|
|
|
|
}, } \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define QAT_SYM_AUTH_CAP(n, b, k, d, a, i) \
|
|
|
|
{ \
|
|
|
|
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, \
|
|
|
|
{.sym = { \
|
|
|
|
.xform_type = RTE_CRYPTO_SYM_XFORM_AUTH, \
|
|
|
|
{.auth = { \
|
|
|
|
.algo = RTE_CRYPTO_AUTH_##n, \
|
|
|
|
b, k, d, a, i \
|
|
|
|
}, } \
|
|
|
|
}, } \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define QAT_SYM_AEAD_CAP(n, b, k, d, a, i) \
|
|
|
|
{ \
|
|
|
|
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, \
|
|
|
|
{.sym = { \
|
|
|
|
.xform_type = RTE_CRYPTO_SYM_XFORM_AEAD, \
|
|
|
|
{.aead = { \
|
|
|
|
.algo = RTE_CRYPTO_AEAD_##n, \
|
|
|
|
b, k, d, a, i \
|
|
|
|
}, } \
|
|
|
|
}, } \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define QAT_SYM_CIPHER_CAP(n, b, k, i) \
|
|
|
|
{ \
|
|
|
|
.op = RTE_CRYPTO_OP_TYPE_SYMMETRIC, \
|
|
|
|
{.sym = { \
|
|
|
|
.xform_type = RTE_CRYPTO_SYM_XFORM_CIPHER, \
|
|
|
|
{.cipher = { \
|
|
|
|
.algo = RTE_CRYPTO_CIPHER_##n, \
|
|
|
|
b, k, i \
|
|
|
|
}, } \
|
|
|
|
}, } \
|
|
|
|
}
|
|
|
|
|
2021-01-28 17:08:59 +00:00
|
|
|
extern uint8_t qat_sym_driver_id;
|
2019-06-25 11:12:58 +00:00
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
extern struct qat_crypto_gen_dev_ops qat_sym_gen_dev_ops[];
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
int
|
2021-01-28 17:08:59 +00:00
|
|
|
qat_sym_dev_create(struct qat_pci_device *qat_pci_dev,
|
|
|
|
struct qat_dev_cmd_param *qat_dev_cmd_param);
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
int
|
|
|
|
qat_sym_dev_destroy(struct qat_pci_device *qat_pci_dev);
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
void
|
|
|
|
qat_sym_init_op_cookie(void *op_cookie);
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
#endif
|
|
|
|
#endif /* _QAT_SYM_PMD_H_ */
|