f-stack/dpdk/drivers/crypto/octeontx2/otx2_cryptodev.h

57 lines
1.2 KiB
C
Raw Normal View History

2020-06-18 16:55:50 +00:00
/* SPDX-License-Identifier: BSD-3-Clause
* Copyright (C) 2019 Marvell International Ltd.
*/
#ifndef _OTX2_CRYPTODEV_H_
#define _OTX2_CRYPTODEV_H_
#include "cpt_common.h"
2021-02-05 08:48:47 +00:00
#include "cpt_hw_types.h"
2020-06-18 16:55:50 +00:00
#include "otx2_dev.h"
/* Marvell OCTEON TX2 Crypto PMD device name */
#define CRYPTODEV_NAME_OCTEONTX2_PMD crypto_octeontx2
#define OTX2_CPT_MAX_LFS 64
#define OTX2_CPT_MAX_QUEUES_PER_VF 64
2021-02-05 08:48:47 +00:00
#define OTX2_CPT_PMD_VERSION 3
2020-06-18 16:55:50 +00:00
/**
* Device private data
*/
struct otx2_cpt_vf {
struct otx2_dev otx2_dev;
/**< Base class */
uint16_t max_queues;
/**< Max queues supported */
uint8_t nb_queues;
/**< Number of crypto queues attached */
uint16_t lf_msixoff[OTX2_CPT_MAX_LFS];
/**< MSI-X offsets */
uint8_t err_intr_registered:1;
/**< Are error interrupts registered? */
2021-02-05 08:48:47 +00:00
union cpt_eng_caps hw_caps[CPT_MAX_ENG_TYPES];
/**< CPT device capabilities */
};
struct cpt_meta_info {
uint64_t deq_op_info[5];
uint64_t comp_code_sz;
union cpt_res_s cpt_res __rte_aligned(16);
struct cpt_request_info cpt_req;
2020-06-18 16:55:50 +00:00
};
#define CPT_LOGTYPE otx2_cpt_logtype
extern int otx2_cpt_logtype;
/*
* Crypto device driver ID
*/
2021-01-28 17:08:59 +00:00
extern uint8_t otx2_cryptodev_driver_id;
void otx2_cpt_set_enqdeq_fns(struct rte_cryptodev *dev);
2020-06-18 16:55:50 +00:00
#endif /* _OTX2_CRYPTODEV_H_ */