2022-09-06 04:00:10 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2021 Intel Corporation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "qat_comp.h"
|
|
|
|
#include "qat_comp_pmd.h"
|
|
|
|
#include "qat_comp_pmd_gens.h"
|
|
|
|
#include "icp_qat_hw_gen4_comp.h"
|
|
|
|
#include "icp_qat_hw_gen4_comp_defs.h"
|
|
|
|
|
|
|
|
#define QAT_NUM_INTERM_BUFS_GEN4 0
|
|
|
|
|
|
|
|
static const struct rte_compressdev_capabilities
|
|
|
|
qat_gen4_comp_capabilities[] = {
|
|
|
|
{/* COMPRESSION - deflate */
|
|
|
|
.algo = RTE_COMP_ALGO_DEFLATE,
|
|
|
|
.comp_feature_flags = RTE_COMP_FF_MULTI_PKT_CHECKSUM |
|
|
|
|
RTE_COMP_FF_CRC32_CHECKSUM |
|
|
|
|
RTE_COMP_FF_ADLER32_CHECKSUM |
|
|
|
|
RTE_COMP_FF_CRC32_ADLER32_CHECKSUM |
|
|
|
|
RTE_COMP_FF_SHAREABLE_PRIV_XFORM |
|
|
|
|
RTE_COMP_FF_HUFFMAN_FIXED |
|
|
|
|
RTE_COMP_FF_HUFFMAN_DYNAMIC |
|
|
|
|
RTE_COMP_FF_OOP_SGL_IN_SGL_OUT |
|
|
|
|
RTE_COMP_FF_OOP_SGL_IN_LB_OUT |
|
|
|
|
RTE_COMP_FF_OOP_LB_IN_SGL_OUT,
|
|
|
|
.window_size = {.min = 15, .max = 15, .increment = 0} },
|
2023-09-11 06:58:14 +00:00
|
|
|
RTE_COMP_END_OF_CAPABILITIES_LIST() };
|
2022-09-06 04:00:10 +00:00
|
|
|
|
|
|
|
static int
|
|
|
|
qat_comp_dev_config_gen4(struct rte_compressdev *dev,
|
|
|
|
struct rte_compressdev_config *config)
|
|
|
|
{
|
|
|
|
/* QAT GEN4 doesn't need preallocated intermediate buffers */
|
|
|
|
|
|
|
|
return qat_comp_dev_config(dev, config);
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct rte_compressdev_ops qat_comp_ops_gen4 = {
|
|
|
|
|
|
|
|
/* Device related operations */
|
|
|
|
.dev_configure = qat_comp_dev_config_gen4,
|
|
|
|
.dev_start = qat_comp_dev_start,
|
|
|
|
.dev_stop = qat_comp_dev_stop,
|
|
|
|
.dev_close = qat_comp_dev_close,
|
|
|
|
.dev_infos_get = qat_comp_dev_info_get,
|
|
|
|
|
|
|
|
.stats_get = qat_comp_stats_get,
|
|
|
|
.stats_reset = qat_comp_stats_reset,
|
|
|
|
.queue_pair_setup = qat_comp_qp_setup,
|
|
|
|
.queue_pair_release = qat_comp_qp_release,
|
|
|
|
|
|
|
|
/* Compression related operations */
|
|
|
|
.private_xform_create = qat_comp_private_xform_create,
|
|
|
|
.private_xform_free = qat_comp_private_xform_free,
|
|
|
|
.stream_create = qat_comp_stream_create,
|
|
|
|
.stream_free = qat_comp_stream_free
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct qat_comp_capabilities_info
|
|
|
|
qat_comp_cap_get_gen4(struct qat_pci_device *qat_dev __rte_unused)
|
|
|
|
{
|
|
|
|
struct qat_comp_capabilities_info capa_info = {
|
|
|
|
.data = qat_gen4_comp_capabilities,
|
|
|
|
.size = sizeof(qat_gen4_comp_capabilities)
|
|
|
|
};
|
|
|
|
return capa_info;
|
|
|
|
}
|
|
|
|
|
|
|
|
static uint16_t
|
|
|
|
qat_comp_get_ram_bank_flags_gen4(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
qat_comp_set_slice_cfg_word_gen4(struct qat_comp_xform *qat_xform,
|
|
|
|
const struct rte_comp_xform *xform,
|
|
|
|
enum rte_comp_op_type op_type, uint32_t *comp_slice_cfg_word)
|
|
|
|
{
|
|
|
|
if (qat_xform->qat_comp_request_type ==
|
|
|
|
QAT_COMP_REQUEST_FIXED_COMP_STATELESS ||
|
|
|
|
qat_xform->qat_comp_request_type ==
|
|
|
|
QAT_COMP_REQUEST_DYNAMIC_COMP_STATELESS) {
|
|
|
|
/* Compression */
|
|
|
|
struct icp_qat_hw_comp_20_config_csr_upper hw_comp_upper_csr;
|
|
|
|
struct icp_qat_hw_comp_20_config_csr_lower hw_comp_lower_csr;
|
|
|
|
|
|
|
|
memset(&hw_comp_upper_csr, 0, sizeof(hw_comp_upper_csr));
|
|
|
|
memset(&hw_comp_lower_csr, 0, sizeof(hw_comp_lower_csr));
|
|
|
|
|
|
|
|
hw_comp_lower_csr.lllbd =
|
|
|
|
ICP_QAT_HW_COMP_20_LLLBD_CTRL_LLLBD_DISABLED;
|
|
|
|
|
|
|
|
if (xform->compress.algo == RTE_COMP_ALGO_DEFLATE) {
|
|
|
|
hw_comp_lower_csr.skip_ctrl =
|
|
|
|
ICP_QAT_HW_COMP_20_BYTE_SKIP_3BYTE_LITERAL;
|
|
|
|
|
|
|
|
if (qat_xform->qat_comp_request_type ==
|
|
|
|
QAT_COMP_REQUEST_DYNAMIC_COMP_STATELESS) {
|
|
|
|
hw_comp_lower_csr.algo =
|
|
|
|
ICP_QAT_HW_COMP_20_HW_COMP_FORMAT_ILZ77;
|
|
|
|
hw_comp_lower_csr.lllbd =
|
|
|
|
ICP_QAT_HW_COMP_20_LLLBD_CTRL_LLLBD_ENABLED;
|
|
|
|
} else {
|
|
|
|
hw_comp_lower_csr.algo =
|
|
|
|
ICP_QAT_HW_COMP_20_HW_COMP_FORMAT_DEFLATE;
|
|
|
|
hw_comp_upper_csr.scb_ctrl =
|
|
|
|
ICP_QAT_HW_COMP_20_SCB_CONTROL_DISABLE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (op_type == RTE_COMP_OP_STATEFUL) {
|
|
|
|
hw_comp_upper_csr.som_ctrl =
|
|
|
|
ICP_QAT_HW_COMP_20_SOM_CONTROL_REPLAY_MODE;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
QAT_LOG(ERR, "Compression algorithm not supported");
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (xform->compress.level) {
|
|
|
|
case 1:
|
|
|
|
case 2:
|
|
|
|
case 3:
|
|
|
|
case 4:
|
|
|
|
case 5:
|
|
|
|
hw_comp_lower_csr.sd =
|
|
|
|
ICP_QAT_HW_COMP_20_SEARCH_DEPTH_LEVEL_1;
|
|
|
|
hw_comp_lower_csr.hash_col =
|
|
|
|
ICP_QAT_HW_COMP_20_SKIP_HASH_COLLISION_DONT_ALLOW;
|
|
|
|
break;
|
|
|
|
case 6:
|
|
|
|
case 7:
|
|
|
|
case 8:
|
|
|
|
case RTE_COMP_LEVEL_PMD_DEFAULT:
|
|
|
|
hw_comp_lower_csr.sd =
|
|
|
|
ICP_QAT_HW_COMP_20_SEARCH_DEPTH_LEVEL_6;
|
|
|
|
break;
|
|
|
|
case 9:
|
|
|
|
case 10:
|
|
|
|
case 11:
|
|
|
|
case 12:
|
|
|
|
hw_comp_lower_csr.sd =
|
|
|
|
ICP_QAT_HW_COMP_20_SEARCH_DEPTH_LEVEL_9;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
QAT_LOG(ERR, "Compression level not supported");
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
hw_comp_lower_csr.abd = ICP_QAT_HW_COMP_20_ABD_ABD_DISABLED;
|
|
|
|
hw_comp_lower_csr.hash_update =
|
|
|
|
ICP_QAT_HW_COMP_20_SKIP_HASH_UPDATE_DONT_ALLOW;
|
|
|
|
hw_comp_lower_csr.edmm =
|
|
|
|
ICP_QAT_HW_COMP_20_EXTENDED_DELAY_MATCH_MODE_EDMM_ENABLED;
|
|
|
|
|
|
|
|
hw_comp_upper_csr.nice =
|
|
|
|
ICP_QAT_HW_COMP_20_CONFIG_CSR_NICE_PARAM_DEFAULT_VAL;
|
|
|
|
hw_comp_upper_csr.lazy =
|
|
|
|
ICP_QAT_HW_COMP_20_CONFIG_CSR_LAZY_PARAM_DEFAULT_VAL;
|
|
|
|
|
|
|
|
comp_slice_cfg_word[0] =
|
|
|
|
ICP_QAT_FW_COMP_20_BUILD_CONFIG_LOWER(
|
|
|
|
hw_comp_lower_csr);
|
|
|
|
comp_slice_cfg_word[1] =
|
|
|
|
ICP_QAT_FW_COMP_20_BUILD_CONFIG_UPPER(
|
|
|
|
hw_comp_upper_csr);
|
|
|
|
} else {
|
|
|
|
/* Decompression */
|
|
|
|
struct icp_qat_hw_decomp_20_config_csr_lower
|
|
|
|
hw_decomp_lower_csr;
|
|
|
|
|
|
|
|
memset(&hw_decomp_lower_csr, 0, sizeof(hw_decomp_lower_csr));
|
|
|
|
|
|
|
|
if (xform->compress.algo == RTE_COMP_ALGO_DEFLATE)
|
|
|
|
hw_decomp_lower_csr.algo =
|
|
|
|
ICP_QAT_HW_DECOMP_20_HW_DECOMP_FORMAT_DEFLATE;
|
|
|
|
else {
|
|
|
|
QAT_LOG(ERR, "Compression algorithm not supported");
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
comp_slice_cfg_word[0] =
|
|
|
|
ICP_QAT_FW_DECOMP_20_BUILD_CONFIG_LOWER(
|
|
|
|
hw_decomp_lower_csr);
|
|
|
|
comp_slice_cfg_word[1] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static unsigned int
|
|
|
|
qat_comp_get_num_im_bufs_required_gen4(void)
|
|
|
|
{
|
|
|
|
return QAT_NUM_INTERM_BUFS_GEN4;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
RTE_INIT(qat_comp_pmd_gen4_init)
|
|
|
|
{
|
|
|
|
qat_comp_gen_dev_ops[QAT_GEN4].compressdev_ops =
|
|
|
|
&qat_comp_ops_gen4;
|
|
|
|
qat_comp_gen_dev_ops[QAT_GEN4].qat_comp_get_capabilities =
|
|
|
|
qat_comp_cap_get_gen4;
|
|
|
|
qat_comp_gen_dev_ops[QAT_GEN4].qat_comp_get_num_im_bufs_required =
|
|
|
|
qat_comp_get_num_im_bufs_required_gen4;
|
|
|
|
qat_comp_gen_dev_ops[QAT_GEN4].qat_comp_get_ram_bank_flags =
|
|
|
|
qat_comp_get_ram_bank_flags_gen4;
|
|
|
|
qat_comp_gen_dev_ops[QAT_GEN4].qat_comp_set_slice_cfg_word =
|
|
|
|
qat_comp_set_slice_cfg_word_gen4;
|
|
|
|
qat_comp_gen_dev_ops[QAT_GEN4].qat_comp_get_feature_flags =
|
|
|
|
qat_comp_get_features_gen1;
|
|
|
|
}
|