15438e4ecSFan Zhang /* SPDX-License-Identifier: BSD-3-Clause
25438e4ecSFan Zhang * Copyright(c) 2021 Intel Corporation
35438e4ecSFan Zhang */
45438e4ecSFan Zhang
51acb7f54SDavid Marchand #include <dev_driver.h>
65438e4ecSFan Zhang #include <rte_pci.h>
75438e4ecSFan Zhang
85438e4ecSFan Zhang #include "qat_device.h"
95438e4ecSFan Zhang #include "qat_qp.h"
105438e4ecSFan Zhang #include "adf_transport_access_macros_gen4vf.h"
115438e4ecSFan Zhang #include "adf_pf2vf_msg.h"
125438e4ecSFan Zhang #include "qat_pf2vf.h"
1359cda512SCiara Power #include "qat_dev_gens.h"
145438e4ecSFan Zhang
155438e4ecSFan Zhang #include <stdint.h>
165438e4ecSFan Zhang
174c778f1aSFan Zhang /* QAT GEN 4 specific macros */
184c778f1aSFan Zhang #define QAT_GEN4_BUNDLE_NUM 4
194c778f1aSFan Zhang #define QAT_GEN4_QPS_PER_BUNDLE_NUM 1
204c778f1aSFan Zhang
215438e4ecSFan Zhang struct qat_dev_gen4_extra {
225438e4ecSFan Zhang struct qat_qp_hw_data qp_gen4_data[QAT_GEN4_BUNDLE_NUM]
235438e4ecSFan Zhang [QAT_GEN4_QPS_PER_BUNDLE_NUM];
245438e4ecSFan Zhang };
255438e4ecSFan Zhang
265438e4ecSFan Zhang static struct qat_pf2vf_dev qat_pf2vf_gen4 = {
275438e4ecSFan Zhang .pf2vf_offset = ADF_4XXXIOV_PF2VM_OFFSET,
285438e4ecSFan Zhang .vf2pf_offset = ADF_4XXXIOV_VM2PF_OFFSET,
295438e4ecSFan Zhang .pf2vf_type_shift = ADF_PFVF_2X_MSGTYPE_SHIFT,
305438e4ecSFan Zhang .pf2vf_type_mask = ADF_PFVF_2X_MSGTYPE_MASK,
315438e4ecSFan Zhang .pf2vf_data_shift = ADF_PFVF_2X_MSGDATA_SHIFT,
325438e4ecSFan Zhang .pf2vf_data_mask = ADF_PFVF_2X_MSGDATA_MASK,
335438e4ecSFan Zhang };
345438e4ecSFan Zhang
354c778f1aSFan Zhang static int
qat_query_svc_gen4(struct qat_pci_device * qat_dev,uint8_t * val)365438e4ecSFan Zhang qat_query_svc_gen4(struct qat_pci_device *qat_dev, uint8_t *val)
375438e4ecSFan Zhang {
385438e4ecSFan Zhang struct qat_pf2vf_msg pf2vf_msg;
395438e4ecSFan Zhang
405438e4ecSFan Zhang pf2vf_msg.msg_type = ADF_VF2PF_MSGTYPE_GET_SMALL_BLOCK_REQ;
415438e4ecSFan Zhang pf2vf_msg.block_hdr = ADF_VF2PF_BLOCK_MSG_GET_RING_TO_SVC_REQ;
425438e4ecSFan Zhang pf2vf_msg.msg_data = 2;
435438e4ecSFan Zhang return qat_pf2vf_exch_msg(qat_dev, pf2vf_msg, 2, val);
445438e4ecSFan Zhang }
455438e4ecSFan Zhang
464c778f1aSFan Zhang static int
qat_select_valid_queue_gen4(struct qat_pci_device * qat_dev,int qp_id,enum qat_service_type service_type)474c778f1aSFan Zhang qat_select_valid_queue_gen4(struct qat_pci_device *qat_dev, int qp_id,
484c778f1aSFan Zhang enum qat_service_type service_type)
494c778f1aSFan Zhang {
504c778f1aSFan Zhang int i = 0, valid_qps = 0;
514c778f1aSFan Zhang struct qat_dev_gen4_extra *dev_extra = qat_dev->dev_private;
524c778f1aSFan Zhang
534c778f1aSFan Zhang for (; i < QAT_GEN4_BUNDLE_NUM; i++) {
544c778f1aSFan Zhang if (dev_extra->qp_gen4_data[i][0].service_type ==
554c778f1aSFan Zhang service_type) {
564c778f1aSFan Zhang if (valid_qps == qp_id)
574c778f1aSFan Zhang return i;
584c778f1aSFan Zhang ++valid_qps;
594c778f1aSFan Zhang }
604c778f1aSFan Zhang }
614c778f1aSFan Zhang return -1;
624c778f1aSFan Zhang }
634c778f1aSFan Zhang
6459cda512SCiara Power const struct qat_qp_hw_data *
qat_qp_get_hw_data_gen4(struct qat_pci_device * qat_dev,enum qat_service_type service_type,uint16_t qp_id)654c778f1aSFan Zhang qat_qp_get_hw_data_gen4(struct qat_pci_device *qat_dev,
664c778f1aSFan Zhang enum qat_service_type service_type, uint16_t qp_id)
674c778f1aSFan Zhang {
684c778f1aSFan Zhang struct qat_dev_gen4_extra *dev_extra = qat_dev->dev_private;
694c778f1aSFan Zhang int ring_pair = qat_select_valid_queue_gen4(qat_dev, qp_id,
704c778f1aSFan Zhang service_type);
714c778f1aSFan Zhang
724c778f1aSFan Zhang if (ring_pair < 0)
734c778f1aSFan Zhang return NULL;
744c778f1aSFan Zhang
754c778f1aSFan Zhang return &dev_extra->qp_gen4_data[ring_pair][0];
764c778f1aSFan Zhang }
774c778f1aSFan Zhang
7859cda512SCiara Power int
qat_qp_rings_per_service_gen4(struct qat_pci_device * qat_dev,enum qat_service_type service)794c778f1aSFan Zhang qat_qp_rings_per_service_gen4(struct qat_pci_device *qat_dev,
804c778f1aSFan Zhang enum qat_service_type service)
814c778f1aSFan Zhang {
824c778f1aSFan Zhang int i = 0, count = 0, max_ops_per_srv = 0;
834c778f1aSFan Zhang struct qat_dev_gen4_extra *dev_extra = qat_dev->dev_private;
844c778f1aSFan Zhang
854c778f1aSFan Zhang max_ops_per_srv = QAT_GEN4_BUNDLE_NUM;
864c778f1aSFan Zhang for (i = 0, count = 0; i < max_ops_per_srv; i++)
874c778f1aSFan Zhang if (dev_extra->qp_gen4_data[i][0].service_type == service)
884c778f1aSFan Zhang count++;
894c778f1aSFan Zhang return count;
904c778f1aSFan Zhang }
914c778f1aSFan Zhang
925438e4ecSFan Zhang static enum qat_service_type
gen4_pick_service(uint8_t hw_service)935438e4ecSFan Zhang gen4_pick_service(uint8_t hw_service)
945438e4ecSFan Zhang {
955438e4ecSFan Zhang switch (hw_service) {
965438e4ecSFan Zhang case QAT_SVC_SYM:
975438e4ecSFan Zhang return QAT_SERVICE_SYMMETRIC;
985438e4ecSFan Zhang case QAT_SVC_COMPRESSION:
995438e4ecSFan Zhang return QAT_SERVICE_COMPRESSION;
1005438e4ecSFan Zhang case QAT_SVC_ASYM:
1015438e4ecSFan Zhang return QAT_SERVICE_ASYMMETRIC;
1025438e4ecSFan Zhang default:
1035438e4ecSFan Zhang return QAT_SERVICE_INVALID;
1045438e4ecSFan Zhang }
1055438e4ecSFan Zhang }
1065438e4ecSFan Zhang
10759cda512SCiara Power int
qat_dev_read_config_gen4(struct qat_pci_device * qat_dev)1085438e4ecSFan Zhang qat_dev_read_config_gen4(struct qat_pci_device *qat_dev)
1095438e4ecSFan Zhang {
1105438e4ecSFan Zhang int i = 0;
1115438e4ecSFan Zhang uint16_t svc = 0;
1125438e4ecSFan Zhang struct qat_dev_gen4_extra *dev_extra = qat_dev->dev_private;
1135438e4ecSFan Zhang struct qat_qp_hw_data *hw_data;
1145438e4ecSFan Zhang enum qat_service_type service_type;
1155438e4ecSFan Zhang uint8_t hw_service;
1165438e4ecSFan Zhang
1175438e4ecSFan Zhang if (qat_query_svc_gen4(qat_dev, (uint8_t *)&svc))
1185438e4ecSFan Zhang return -EFAULT;
1195438e4ecSFan Zhang for (; i < QAT_GEN4_BUNDLE_NUM; i++) {
1205438e4ecSFan Zhang hw_service = (svc >> (3 * i)) & 0x7;
1215438e4ecSFan Zhang service_type = gen4_pick_service(hw_service);
1225438e4ecSFan Zhang if (service_type == QAT_SERVICE_INVALID) {
1235438e4ecSFan Zhang QAT_LOG(ERR,
1245438e4ecSFan Zhang "Unrecognized service on bundle %d",
1255438e4ecSFan Zhang i);
1265438e4ecSFan Zhang return -ENOTSUP;
1275438e4ecSFan Zhang }
1285438e4ecSFan Zhang hw_data = &dev_extra->qp_gen4_data[i][0];
1295438e4ecSFan Zhang memset(hw_data, 0, sizeof(*hw_data));
1305438e4ecSFan Zhang hw_data->service_type = service_type;
1315438e4ecSFan Zhang if (service_type == QAT_SERVICE_ASYMMETRIC) {
1325438e4ecSFan Zhang hw_data->tx_msg_size = 64;
1335438e4ecSFan Zhang hw_data->rx_msg_size = 32;
1345438e4ecSFan Zhang } else if (service_type == QAT_SERVICE_SYMMETRIC ||
1355438e4ecSFan Zhang service_type ==
1365438e4ecSFan Zhang QAT_SERVICE_COMPRESSION) {
1375438e4ecSFan Zhang hw_data->tx_msg_size = 128;
1385438e4ecSFan Zhang hw_data->rx_msg_size = 32;
1395438e4ecSFan Zhang }
1405438e4ecSFan Zhang hw_data->tx_ring_num = 0;
1415438e4ecSFan Zhang hw_data->rx_ring_num = 1;
1425438e4ecSFan Zhang hw_data->hw_bundle_num = i;
1435438e4ecSFan Zhang }
1445438e4ecSFan Zhang return 0;
1455438e4ecSFan Zhang }
1465438e4ecSFan Zhang
147*2e98e808SArkadiusz Kusztal static int
qat_dev_read_config_vqat(struct qat_pci_device * qat_dev)148*2e98e808SArkadiusz Kusztal qat_dev_read_config_vqat(struct qat_pci_device *qat_dev)
149*2e98e808SArkadiusz Kusztal {
150*2e98e808SArkadiusz Kusztal int i = 0;
151*2e98e808SArkadiusz Kusztal struct qat_dev_gen4_extra *dev_extra = qat_dev->dev_private;
152*2e98e808SArkadiusz Kusztal struct qat_qp_hw_data *hw_data;
153*2e98e808SArkadiusz Kusztal struct qat_device_info *qat_dev_instance =
154*2e98e808SArkadiusz Kusztal &qat_pci_devs[qat_dev->qat_dev_id];
155*2e98e808SArkadiusz Kusztal uint16_t sub_id = qat_dev_instance->pci_dev->id.subsystem_device_id;
156*2e98e808SArkadiusz Kusztal
157*2e98e808SArkadiusz Kusztal for (; i < QAT_GEN4_BUNDLE_NUM; i++) {
158*2e98e808SArkadiusz Kusztal hw_data = &dev_extra->qp_gen4_data[i][0];
159*2e98e808SArkadiusz Kusztal memset(hw_data, 0, sizeof(*hw_data));
160*2e98e808SArkadiusz Kusztal if (sub_id == ADF_VQAT_SYM_PCI_SUBSYSTEM_ID) {
161*2e98e808SArkadiusz Kusztal hw_data->service_type = QAT_SERVICE_SYMMETRIC;
162*2e98e808SArkadiusz Kusztal hw_data->tx_msg_size = 128;
163*2e98e808SArkadiusz Kusztal hw_data->rx_msg_size = 32;
164*2e98e808SArkadiusz Kusztal } else if (sub_id == ADF_VQAT_ASYM_PCI_SUBSYSTEM_ID) {
165*2e98e808SArkadiusz Kusztal hw_data->service_type = QAT_SERVICE_ASYMMETRIC;
166*2e98e808SArkadiusz Kusztal hw_data->tx_msg_size = 64;
167*2e98e808SArkadiusz Kusztal hw_data->rx_msg_size = 32;
168*2e98e808SArkadiusz Kusztal } else if (sub_id == ADF_VQAT_DC_PCI_SUBSYSTEM_ID) {
169*2e98e808SArkadiusz Kusztal hw_data->service_type = QAT_SERVICE_COMPRESSION;
170*2e98e808SArkadiusz Kusztal hw_data->tx_msg_size = 128;
171*2e98e808SArkadiusz Kusztal hw_data->rx_msg_size = 32;
172*2e98e808SArkadiusz Kusztal } else {
173*2e98e808SArkadiusz Kusztal QAT_LOG(ERR, "Unrecognized subsystem id %hu", sub_id);
174*2e98e808SArkadiusz Kusztal return -EINVAL;
175*2e98e808SArkadiusz Kusztal }
176*2e98e808SArkadiusz Kusztal hw_data->tx_ring_num = 0;
177*2e98e808SArkadiusz Kusztal hw_data->rx_ring_num = 1;
178*2e98e808SArkadiusz Kusztal hw_data->hw_bundle_num = i;
179*2e98e808SArkadiusz Kusztal }
180*2e98e808SArkadiusz Kusztal return 0;
181*2e98e808SArkadiusz Kusztal }
182*2e98e808SArkadiusz Kusztal
18359cda512SCiara Power void
qat_qp_build_ring_base_gen4(void * io_addr,struct qat_queue * queue)1844c778f1aSFan Zhang qat_qp_build_ring_base_gen4(void *io_addr,
1854c778f1aSFan Zhang struct qat_queue *queue)
1864c778f1aSFan Zhang {
1874c778f1aSFan Zhang uint64_t queue_base;
1884c778f1aSFan Zhang
1894c778f1aSFan Zhang queue_base = BUILD_RING_BASE_ADDR_GEN4(queue->base_phys_addr,
1904c778f1aSFan Zhang queue->queue_size);
1914c778f1aSFan Zhang WRITE_CSR_RING_BASE_GEN4VF(io_addr, queue->hw_bundle_number,
1924c778f1aSFan Zhang queue->hw_queue_number, queue_base);
1934c778f1aSFan Zhang }
1944c778f1aSFan Zhang
19559cda512SCiara Power void
qat_qp_adf_arb_enable_gen4(const struct qat_queue * txq,void * base_addr,rte_spinlock_t * lock)1964c778f1aSFan Zhang qat_qp_adf_arb_enable_gen4(const struct qat_queue *txq,
1974c778f1aSFan Zhang void *base_addr, rte_spinlock_t *lock)
1984c778f1aSFan Zhang {
1994c778f1aSFan Zhang uint32_t arb_csr_offset = 0, value;
2004c778f1aSFan Zhang
2014c778f1aSFan Zhang rte_spinlock_lock(lock);
2024c778f1aSFan Zhang arb_csr_offset = ADF_ARB_RINGSRVARBEN_OFFSET +
2034c778f1aSFan Zhang (ADF_RING_BUNDLE_SIZE_GEN4 *
2044c778f1aSFan Zhang txq->hw_bundle_number);
2054c778f1aSFan Zhang value = ADF_CSR_RD(base_addr + ADF_RING_CSR_ADDR_OFFSET_GEN4VF,
2064c778f1aSFan Zhang arb_csr_offset);
2074c778f1aSFan Zhang value |= (0x01 << txq->hw_queue_number);
2084c778f1aSFan Zhang ADF_CSR_WR(base_addr, arb_csr_offset, value);
2094c778f1aSFan Zhang rte_spinlock_unlock(lock);
2104c778f1aSFan Zhang }
2114c778f1aSFan Zhang
21259cda512SCiara Power void
qat_qp_adf_arb_disable_gen4(const struct qat_queue * txq,void * base_addr,rte_spinlock_t * lock)2134c778f1aSFan Zhang qat_qp_adf_arb_disable_gen4(const struct qat_queue *txq,
2144c778f1aSFan Zhang void *base_addr, rte_spinlock_t *lock)
2154c778f1aSFan Zhang {
2164c778f1aSFan Zhang uint32_t arb_csr_offset = 0, value;
2174c778f1aSFan Zhang
2184c778f1aSFan Zhang rte_spinlock_lock(lock);
2194c778f1aSFan Zhang arb_csr_offset = ADF_ARB_RINGSRVARBEN_OFFSET +
2204c778f1aSFan Zhang (ADF_RING_BUNDLE_SIZE_GEN4 *
2214c778f1aSFan Zhang txq->hw_bundle_number);
2224c778f1aSFan Zhang value = ADF_CSR_RD(base_addr + ADF_RING_CSR_ADDR_OFFSET_GEN4VF,
2234c778f1aSFan Zhang arb_csr_offset);
2244c778f1aSFan Zhang value &= ~(0x01 << txq->hw_queue_number);
2254c778f1aSFan Zhang ADF_CSR_WR(base_addr, arb_csr_offset, value);
2264c778f1aSFan Zhang rte_spinlock_unlock(lock);
2274c778f1aSFan Zhang }
2284c778f1aSFan Zhang
22959cda512SCiara Power void
qat_qp_adf_configure_queues_gen4(struct qat_qp * qp)2304c778f1aSFan Zhang qat_qp_adf_configure_queues_gen4(struct qat_qp *qp)
2314c778f1aSFan Zhang {
2324c778f1aSFan Zhang uint32_t q_tx_config, q_resp_config;
2334c778f1aSFan Zhang struct qat_queue *q_tx = &qp->tx_q, *q_rx = &qp->rx_q;
2344c778f1aSFan Zhang
2354c778f1aSFan Zhang q_tx_config = BUILD_RING_CONFIG(q_tx->queue_size);
2364c778f1aSFan Zhang q_resp_config = BUILD_RESP_RING_CONFIG(q_rx->queue_size,
2374c778f1aSFan Zhang ADF_RING_NEAR_WATERMARK_512,
2384c778f1aSFan Zhang ADF_RING_NEAR_WATERMARK_0);
2394c778f1aSFan Zhang
2404c778f1aSFan Zhang WRITE_CSR_RING_CONFIG_GEN4VF(qp->mmap_bar_addr,
2414c778f1aSFan Zhang q_tx->hw_bundle_number, q_tx->hw_queue_number,
2424c778f1aSFan Zhang q_tx_config);
2434c778f1aSFan Zhang WRITE_CSR_RING_CONFIG_GEN4VF(qp->mmap_bar_addr,
2444c778f1aSFan Zhang q_rx->hw_bundle_number, q_rx->hw_queue_number,
2454c778f1aSFan Zhang q_resp_config);
2464c778f1aSFan Zhang }
2474c778f1aSFan Zhang
24859cda512SCiara Power void
qat_qp_csr_write_tail_gen4(struct qat_qp * qp,struct qat_queue * q)2494c778f1aSFan Zhang qat_qp_csr_write_tail_gen4(struct qat_qp *qp, struct qat_queue *q)
2504c778f1aSFan Zhang {
2514c778f1aSFan Zhang WRITE_CSR_RING_TAIL_GEN4VF(qp->mmap_bar_addr,
2524c778f1aSFan Zhang q->hw_bundle_number, q->hw_queue_number, q->tail);
2534c778f1aSFan Zhang }
2544c778f1aSFan Zhang
25559cda512SCiara Power void
qat_qp_csr_write_head_gen4(struct qat_qp * qp,struct qat_queue * q,uint32_t new_head)2564c778f1aSFan Zhang qat_qp_csr_write_head_gen4(struct qat_qp *qp, struct qat_queue *q,
2574c778f1aSFan Zhang uint32_t new_head)
2584c778f1aSFan Zhang {
2594c778f1aSFan Zhang WRITE_CSR_RING_HEAD_GEN4VF(qp->mmap_bar_addr,
2604c778f1aSFan Zhang q->hw_bundle_number, q->hw_queue_number, new_head);
2614c778f1aSFan Zhang }
2624c778f1aSFan Zhang
26359cda512SCiara Power void
qat_qp_csr_setup_gen4(struct qat_pci_device * qat_dev,void * io_addr,struct qat_qp * qp)2644c778f1aSFan Zhang qat_qp_csr_setup_gen4(struct qat_pci_device *qat_dev,
2654c778f1aSFan Zhang void *io_addr, struct qat_qp *qp)
2664c778f1aSFan Zhang {
2674c778f1aSFan Zhang qat_qp_build_ring_base_gen4(io_addr, &qp->tx_q);
2684c778f1aSFan Zhang qat_qp_build_ring_base_gen4(io_addr, &qp->rx_q);
2694c778f1aSFan Zhang qat_qp_adf_configure_queues_gen4(qp);
2704c778f1aSFan Zhang qat_qp_adf_arb_enable_gen4(&qp->tx_q, qp->mmap_bar_addr,
2714c778f1aSFan Zhang &qat_dev->arb_csr_lock);
2724c778f1aSFan Zhang }
2734c778f1aSFan Zhang
2744c778f1aSFan Zhang static struct qat_qp_hw_spec_funcs qat_qp_hw_spec_gen4 = {
2754c778f1aSFan Zhang .qat_qp_rings_per_service = qat_qp_rings_per_service_gen4,
2764c778f1aSFan Zhang .qat_qp_build_ring_base = qat_qp_build_ring_base_gen4,
2774c778f1aSFan Zhang .qat_qp_adf_arb_enable = qat_qp_adf_arb_enable_gen4,
2784c778f1aSFan Zhang .qat_qp_adf_arb_disable = qat_qp_adf_arb_disable_gen4,
2794c778f1aSFan Zhang .qat_qp_adf_configure_queues = qat_qp_adf_configure_queues_gen4,
2804c778f1aSFan Zhang .qat_qp_csr_write_tail = qat_qp_csr_write_tail_gen4,
2814c778f1aSFan Zhang .qat_qp_csr_write_head = qat_qp_csr_write_head_gen4,
2824c778f1aSFan Zhang .qat_qp_csr_setup = qat_qp_csr_setup_gen4,
2834c778f1aSFan Zhang .qat_qp_get_hw_data = qat_qp_get_hw_data_gen4,
2844c778f1aSFan Zhang };
2854c778f1aSFan Zhang
28659cda512SCiara Power int
qat_reset_ring_pairs_gen4(struct qat_pci_device * qat_pci_dev)2875438e4ecSFan Zhang qat_reset_ring_pairs_gen4(struct qat_pci_device *qat_pci_dev)
2885438e4ecSFan Zhang {
2895438e4ecSFan Zhang int ret = 0, i;
2905438e4ecSFan Zhang uint8_t data[4];
2915438e4ecSFan Zhang struct qat_pf2vf_msg pf2vf_msg;
2925438e4ecSFan Zhang
2935438e4ecSFan Zhang pf2vf_msg.msg_type = ADF_VF2PF_MSGTYPE_RP_RESET;
2945438e4ecSFan Zhang pf2vf_msg.block_hdr = -1;
2955438e4ecSFan Zhang for (i = 0; i < QAT_GEN4_BUNDLE_NUM; i++) {
2965438e4ecSFan Zhang pf2vf_msg.msg_data = i;
2975438e4ecSFan Zhang ret = qat_pf2vf_exch_msg(qat_pci_dev, pf2vf_msg, 1, data);
2985438e4ecSFan Zhang if (ret) {
2995438e4ecSFan Zhang QAT_LOG(ERR, "QAT error when reset bundle no %d",
3005438e4ecSFan Zhang i);
3015438e4ecSFan Zhang return ret;
3025438e4ecSFan Zhang }
3035438e4ecSFan Zhang }
3045438e4ecSFan Zhang
3055438e4ecSFan Zhang return 0;
3065438e4ecSFan Zhang }
3075438e4ecSFan Zhang
308*2e98e808SArkadiusz Kusztal static int
qat_reset_ring_pairs_vqat(struct qat_pci_device * qat_pci_dev __rte_unused)309*2e98e808SArkadiusz Kusztal qat_reset_ring_pairs_vqat(struct qat_pci_device *qat_pci_dev __rte_unused)
310*2e98e808SArkadiusz Kusztal {
311*2e98e808SArkadiusz Kusztal return 0;
312*2e98e808SArkadiusz Kusztal }
313*2e98e808SArkadiusz Kusztal
31459cda512SCiara Power const struct rte_mem_resource *
qat_dev_get_transport_bar_gen4(struct rte_pci_device * pci_dev)3154c778f1aSFan Zhang qat_dev_get_transport_bar_gen4(struct rte_pci_device *pci_dev)
3165438e4ecSFan Zhang {
3175438e4ecSFan Zhang return &pci_dev->mem_resource[0];
3185438e4ecSFan Zhang }
3195438e4ecSFan Zhang
32059cda512SCiara Power int
qat_dev_get_misc_bar_gen4(struct rte_mem_resource ** mem_resource,struct rte_pci_device * pci_dev)3215438e4ecSFan Zhang qat_dev_get_misc_bar_gen4(struct rte_mem_resource **mem_resource,
3225438e4ecSFan Zhang struct rte_pci_device *pci_dev)
3235438e4ecSFan Zhang {
3245438e4ecSFan Zhang *mem_resource = &pci_dev->mem_resource[2];
3255438e4ecSFan Zhang return 0;
3265438e4ecSFan Zhang }
3275438e4ecSFan Zhang
32859cda512SCiara Power int
qat_dev_get_slice_map_gen4(uint32_t * map __rte_unused,const struct rte_pci_device * pci_dev __rte_unused)329d848fcb8SVikash Poddar qat_dev_get_slice_map_gen4(uint32_t *map __rte_unused,
330b3cbbcdfSArek Kusztal const struct rte_pci_device *pci_dev __rte_unused)
331b3cbbcdfSArek Kusztal {
332b3cbbcdfSArek Kusztal return 0;
333b3cbbcdfSArek Kusztal }
334b3cbbcdfSArek Kusztal
33559cda512SCiara Power int
qat_dev_get_extra_size_gen4(void)3365438e4ecSFan Zhang qat_dev_get_extra_size_gen4(void)
3375438e4ecSFan Zhang {
3385438e4ecSFan Zhang return sizeof(struct qat_dev_gen4_extra);
3395438e4ecSFan Zhang }
3405438e4ecSFan Zhang
3415438e4ecSFan Zhang static struct qat_dev_hw_spec_funcs qat_dev_hw_spec_gen4 = {
3425438e4ecSFan Zhang .qat_dev_reset_ring_pairs = qat_reset_ring_pairs_gen4,
3435438e4ecSFan Zhang .qat_dev_get_transport_bar = qat_dev_get_transport_bar_gen4,
3445438e4ecSFan Zhang .qat_dev_get_misc_bar = qat_dev_get_misc_bar_gen4,
3455438e4ecSFan Zhang .qat_dev_read_config = qat_dev_read_config_gen4,
3465438e4ecSFan Zhang .qat_dev_get_extra_size = qat_dev_get_extra_size_gen4,
347b3cbbcdfSArek Kusztal .qat_dev_get_slice_map = qat_dev_get_slice_map_gen4,
3485438e4ecSFan Zhang };
3495438e4ecSFan Zhang
350*2e98e808SArkadiusz Kusztal static struct qat_dev_hw_spec_funcs qat_dev_hw_spec_vqat = {
351*2e98e808SArkadiusz Kusztal .qat_dev_reset_ring_pairs = qat_reset_ring_pairs_vqat,
352*2e98e808SArkadiusz Kusztal .qat_dev_get_transport_bar = qat_dev_get_transport_bar_gen4,
353*2e98e808SArkadiusz Kusztal .qat_dev_get_misc_bar = qat_dev_get_misc_bar_gen4,
354*2e98e808SArkadiusz Kusztal .qat_dev_read_config = qat_dev_read_config_vqat,
355*2e98e808SArkadiusz Kusztal .qat_dev_get_extra_size = qat_dev_get_extra_size_gen4,
356*2e98e808SArkadiusz Kusztal .qat_dev_get_slice_map = qat_dev_get_slice_map_gen4,
357*2e98e808SArkadiusz Kusztal };
358*2e98e808SArkadiusz Kusztal
RTE_INIT(qat_dev_gen_4_init)3595438e4ecSFan Zhang RTE_INIT(qat_dev_gen_4_init)
3605438e4ecSFan Zhang {
361*2e98e808SArkadiusz Kusztal qat_qp_hw_spec[QAT_VQAT] = qat_qp_hw_spec[QAT_GEN4] = &qat_qp_hw_spec_gen4;
3625438e4ecSFan Zhang qat_dev_hw_spec[QAT_GEN4] = &qat_dev_hw_spec_gen4;
363*2e98e808SArkadiusz Kusztal qat_dev_hw_spec[QAT_VQAT] = &qat_dev_hw_spec_vqat;
3645438e4ecSFan Zhang qat_gen_config[QAT_GEN4].dev_gen = QAT_GEN4;
365*2e98e808SArkadiusz Kusztal qat_gen_config[QAT_VQAT].dev_gen = QAT_VQAT;
3665438e4ecSFan Zhang qat_gen_config[QAT_GEN4].pf2vf_dev = &qat_pf2vf_gen4;
3675438e4ecSFan Zhang }
368