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_ */
|