Commit 92508e7f authored by Srujana Challa's avatar Srujana Challa Committed by Herbert Xu

crypto: octeontx2 - add SGv2 support for CN10KB or CN10KA B0

Scatter Gather input format for CPT has changed on CN10KB/CN10KA B0 HW
to make it compatible with NIX Scatter Gather format to support SG mode
for inline IPsec. This patch modifies the code to make the driver works
for the same. This patch also enables CPT firmware load for these chips.
Signed-off-by: default avatarSrujana Challa <schalla@marvell.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent 711b2e2d
...@@ -14,12 +14,14 @@ static struct cpt_hw_ops otx2_hw_ops = { ...@@ -14,12 +14,14 @@ static struct cpt_hw_ops otx2_hw_ops = {
.send_cmd = otx2_cpt_send_cmd, .send_cmd = otx2_cpt_send_cmd,
.cpt_get_compcode = otx2_cpt_get_compcode, .cpt_get_compcode = otx2_cpt_get_compcode,
.cpt_get_uc_compcode = otx2_cpt_get_uc_compcode, .cpt_get_uc_compcode = otx2_cpt_get_uc_compcode,
.cpt_sg_info_create = otx2_sg_info_create,
}; };
static struct cpt_hw_ops cn10k_hw_ops = { static struct cpt_hw_ops cn10k_hw_ops = {
.send_cmd = cn10k_cpt_send_cmd, .send_cmd = cn10k_cpt_send_cmd,
.cpt_get_compcode = cn10k_cpt_get_compcode, .cpt_get_compcode = cn10k_cpt_get_compcode,
.cpt_get_uc_compcode = cn10k_cpt_get_uc_compcode, .cpt_get_uc_compcode = cn10k_cpt_get_uc_compcode,
.cpt_sg_info_create = otx2_sg_info_create,
}; };
static void cn10k_cpt_send_cmd(union otx2_cpt_inst_s *cptinst, u32 insts_num, static void cn10k_cpt_send_cmd(union otx2_cpt_inst_s *cptinst, u32 insts_num,
...@@ -78,12 +80,9 @@ int cn10k_cptvf_lmtst_init(struct otx2_cptvf_dev *cptvf) ...@@ -78,12 +80,9 @@ int cn10k_cptvf_lmtst_init(struct otx2_cptvf_dev *cptvf)
struct pci_dev *pdev = cptvf->pdev; struct pci_dev *pdev = cptvf->pdev;
resource_size_t offset, size; resource_size_t offset, size;
if (!test_bit(CN10K_LMTST, &cptvf->cap_flag)) { if (!test_bit(CN10K_LMTST, &cptvf->cap_flag))
cptvf->lfs.ops = &otx2_hw_ops;
return 0; return 0;
}
cptvf->lfs.ops = &cn10k_hw_ops;
offset = pci_resource_start(pdev, PCI_MBOX_BAR_NUM); offset = pci_resource_start(pdev, PCI_MBOX_BAR_NUM);
size = pci_resource_len(pdev, PCI_MBOX_BAR_NUM); size = pci_resource_len(pdev, PCI_MBOX_BAR_NUM);
/* Map VF LMILINE region */ /* Map VF LMILINE region */
...@@ -96,3 +95,12 @@ int cn10k_cptvf_lmtst_init(struct otx2_cptvf_dev *cptvf) ...@@ -96,3 +95,12 @@ int cn10k_cptvf_lmtst_init(struct otx2_cptvf_dev *cptvf)
return 0; return 0;
} }
EXPORT_SYMBOL_NS_GPL(cn10k_cptvf_lmtst_init, CRYPTO_DEV_OCTEONTX2_CPT); EXPORT_SYMBOL_NS_GPL(cn10k_cptvf_lmtst_init, CRYPTO_DEV_OCTEONTX2_CPT);
void cptvf_hw_ops_get(struct otx2_cptvf_dev *cptvf)
{
if (test_bit(CN10K_LMTST, &cptvf->cap_flag))
cptvf->lfs.ops = &cn10k_hw_ops;
else
cptvf->lfs.ops = &otx2_hw_ops;
}
EXPORT_SYMBOL_NS_GPL(cptvf_hw_ops_get, CRYPTO_DEV_OCTEONTX2_CPT);
...@@ -30,5 +30,6 @@ static inline u8 otx2_cpt_get_uc_compcode(union otx2_cpt_res_s *result) ...@@ -30,5 +30,6 @@ static inline u8 otx2_cpt_get_uc_compcode(union otx2_cpt_res_s *result)
int cn10k_cptpf_lmtst_init(struct otx2_cptpf_dev *cptpf); int cn10k_cptpf_lmtst_init(struct otx2_cptpf_dev *cptpf);
int cn10k_cptvf_lmtst_init(struct otx2_cptvf_dev *cptvf); int cn10k_cptvf_lmtst_init(struct otx2_cptvf_dev *cptvf);
void cptvf_hw_ops_get(struct otx2_cptvf_dev *cptvf);
#endif /* __CN10K_CPTLF_H */ #endif /* __CN10K_CPTLF_H */
...@@ -102,7 +102,10 @@ union otx2_cpt_eng_caps { ...@@ -102,7 +102,10 @@ union otx2_cpt_eng_caps {
u64 kasumi:1; u64 kasumi:1;
u64 des:1; u64 des:1;
u64 crc:1; u64 crc:1;
u64 reserved_14_63:50; u64 mmul:1;
u64 reserved_15_33:19;
u64 pdcp_chain:1;
u64 reserved_35_63:29;
}; };
}; };
...@@ -145,6 +148,35 @@ static inline bool is_dev_otx2(struct pci_dev *pdev) ...@@ -145,6 +148,35 @@ static inline bool is_dev_otx2(struct pci_dev *pdev)
return false; return false;
} }
static inline bool is_dev_cn10ka(struct pci_dev *pdev)
{
return pdev->subsystem_device == CPT_PCI_SUBSYS_DEVID_CN10K_A;
}
static inline bool is_dev_cn10ka_ax(struct pci_dev *pdev)
{
if (pdev->subsystem_device == CPT_PCI_SUBSYS_DEVID_CN10K_A &&
((pdev->revision & 0xFF) == 4 || (pdev->revision & 0xFF) == 0x50 ||
(pdev->revision & 0xff) == 0x51))
return true;
return false;
}
static inline bool is_dev_cn10kb(struct pci_dev *pdev)
{
return pdev->subsystem_device == CPT_PCI_SUBSYS_DEVID_CN10K_B;
}
static inline bool is_dev_cn10ka_b0(struct pci_dev *pdev)
{
if (pdev->subsystem_device == CPT_PCI_SUBSYS_DEVID_CN10K_A &&
(pdev->revision & 0xFF) == 0x54)
return true;
return false;
}
static inline void otx2_cpt_set_hw_caps(struct pci_dev *pdev, static inline void otx2_cpt_set_hw_caps(struct pci_dev *pdev,
unsigned long *cap_flag) unsigned long *cap_flag)
{ {
......
...@@ -13,6 +13,9 @@ ...@@ -13,6 +13,9 @@
#define CN10K_CPT_PCI_PF_DEVICE_ID 0xA0F2 #define CN10K_CPT_PCI_PF_DEVICE_ID 0xA0F2
#define CN10K_CPT_PCI_VF_DEVICE_ID 0xA0F3 #define CN10K_CPT_PCI_VF_DEVICE_ID 0xA0F3
#define CPT_PCI_SUBSYS_DEVID_CN10K_A 0xB900
#define CPT_PCI_SUBSYS_DEVID_CN10K_B 0xBD00
/* Mailbox interrupts offset */ /* Mailbox interrupts offset */
#define OTX2_CPT_PF_MBOX_INT 6 #define OTX2_CPT_PF_MBOX_INT 6
#define OTX2_CPT_PF_INT_VEC_E_MBOXX(x, a) ((x) + (a)) #define OTX2_CPT_PF_INT_VEC_E_MBOXX(x, a) ((x) + (a))
......
...@@ -27,6 +27,13 @@ ...@@ -27,6 +27,13 @@
#define OTX2_CPT_MAX_REQ_SIZE 65535 #define OTX2_CPT_MAX_REQ_SIZE 65535
#define SG_COMPS_MAX 4
#define SGV2_COMPS_MAX 3
#define SG_COMP_3 3
#define SG_COMP_2 2
#define SG_COMP_1 1
union otx2_cpt_opcode { union otx2_cpt_opcode {
u16 flags; u16 flags;
struct { struct {
...@@ -143,6 +150,8 @@ struct otx2_cpt_inst_info { ...@@ -143,6 +150,8 @@ struct otx2_cpt_inst_info {
unsigned long time_in; unsigned long time_in;
u32 dlen; u32 dlen;
u32 dma_len; u32 dma_len;
u64 gthr_sz;
u64 sctr_sz;
u8 extra_time; u8 extra_time;
}; };
...@@ -157,6 +166,16 @@ struct otx2_cpt_sglist_component { ...@@ -157,6 +166,16 @@ struct otx2_cpt_sglist_component {
__be64 ptr3; __be64 ptr3;
}; };
struct cn10kb_cpt_sglist_component {
u16 len0;
u16 len1;
u16 len2;
u16 valid_segs;
u64 ptr0;
u64 ptr1;
u64 ptr2;
};
static inline void otx2_cpt_info_destroy(struct pci_dev *pdev, static inline void otx2_cpt_info_destroy(struct pci_dev *pdev,
struct otx2_cpt_inst_info *info) struct otx2_cpt_inst_info *info)
{ {
...@@ -188,6 +207,283 @@ static inline void otx2_cpt_info_destroy(struct pci_dev *pdev, ...@@ -188,6 +207,283 @@ static inline void otx2_cpt_info_destroy(struct pci_dev *pdev,
kfree(info); kfree(info);
} }
static inline int setup_sgio_components(struct pci_dev *pdev,
struct otx2_cpt_buf_ptr *list,
int buf_count, u8 *buffer)
{
struct otx2_cpt_sglist_component *sg_ptr;
int components;
int i, j;
if (unlikely(!list)) {
dev_err(&pdev->dev, "Input list pointer is NULL\n");
return -EINVAL;
}
for (i = 0; i < buf_count; i++) {
if (unlikely(!list[i].vptr))
continue;
list[i].dma_addr = dma_map_single(&pdev->dev, list[i].vptr,
list[i].size,
DMA_BIDIRECTIONAL);
if (unlikely(dma_mapping_error(&pdev->dev, list[i].dma_addr))) {
dev_err(&pdev->dev, "Dma mapping failed\n");
goto sg_cleanup;
}
}
components = buf_count / SG_COMPS_MAX;
sg_ptr = (struct otx2_cpt_sglist_component *)buffer;
for (i = 0; i < components; i++) {
sg_ptr->len0 = cpu_to_be16(list[i * SG_COMPS_MAX + 0].size);
sg_ptr->len1 = cpu_to_be16(list[i * SG_COMPS_MAX + 1].size);
sg_ptr->len2 = cpu_to_be16(list[i * SG_COMPS_MAX + 2].size);
sg_ptr->len3 = cpu_to_be16(list[i * SG_COMPS_MAX + 3].size);
sg_ptr->ptr0 = cpu_to_be64(list[i * SG_COMPS_MAX + 0].dma_addr);
sg_ptr->ptr1 = cpu_to_be64(list[i * SG_COMPS_MAX + 1].dma_addr);
sg_ptr->ptr2 = cpu_to_be64(list[i * SG_COMPS_MAX + 2].dma_addr);
sg_ptr->ptr3 = cpu_to_be64(list[i * SG_COMPS_MAX + 3].dma_addr);
sg_ptr++;
}
components = buf_count % SG_COMPS_MAX;
switch (components) {
case SG_COMP_3:
sg_ptr->len2 = cpu_to_be16(list[i * SG_COMPS_MAX + 2].size);
sg_ptr->ptr2 = cpu_to_be64(list[i * SG_COMPS_MAX + 2].dma_addr);
fallthrough;
case SG_COMP_2:
sg_ptr->len1 = cpu_to_be16(list[i * SG_COMPS_MAX + 1].size);
sg_ptr->ptr1 = cpu_to_be64(list[i * SG_COMPS_MAX + 1].dma_addr);
fallthrough;
case SG_COMP_1:
sg_ptr->len0 = cpu_to_be16(list[i * SG_COMPS_MAX + 0].size);
sg_ptr->ptr0 = cpu_to_be64(list[i * SG_COMPS_MAX + 0].dma_addr);
break;
default:
break;
}
return 0;
sg_cleanup:
for (j = 0; j < i; j++) {
if (list[j].dma_addr) {
dma_unmap_single(&pdev->dev, list[j].dma_addr,
list[j].size, DMA_BIDIRECTIONAL);
}
list[j].dma_addr = 0;
}
return -EIO;
}
static inline int sgv2io_components_setup(struct pci_dev *pdev,
struct otx2_cpt_buf_ptr *list,
int buf_count, u8 *buffer)
{
struct cn10kb_cpt_sglist_component *sg_ptr;
int components;
int i, j;
if (unlikely(!list)) {
dev_err(&pdev->dev, "Input list pointer is NULL\n");
return -EFAULT;
}
for (i = 0; i < buf_count; i++) {
if (unlikely(!list[i].vptr))
continue;
list[i].dma_addr = dma_map_single(&pdev->dev, list[i].vptr,
list[i].size,
DMA_BIDIRECTIONAL);
if (unlikely(dma_mapping_error(&pdev->dev, list[i].dma_addr))) {
dev_err(&pdev->dev, "Dma mapping failed\n");
goto sg_cleanup;
}
}
components = buf_count / SGV2_COMPS_MAX;
sg_ptr = (struct cn10kb_cpt_sglist_component *)buffer;
for (i = 0; i < components; i++) {
sg_ptr->len0 = list[i * SGV2_COMPS_MAX + 0].size;
sg_ptr->len1 = list[i * SGV2_COMPS_MAX + 1].size;
sg_ptr->len2 = list[i * SGV2_COMPS_MAX + 2].size;
sg_ptr->ptr0 = list[i * SGV2_COMPS_MAX + 0].dma_addr;
sg_ptr->ptr1 = list[i * SGV2_COMPS_MAX + 1].dma_addr;
sg_ptr->ptr2 = list[i * SGV2_COMPS_MAX + 2].dma_addr;
sg_ptr->valid_segs = SGV2_COMPS_MAX;
sg_ptr++;
}
components = buf_count % SGV2_COMPS_MAX;
sg_ptr->valid_segs = components;
switch (components) {
case SG_COMP_2:
sg_ptr->len1 = list[i * SGV2_COMPS_MAX + 1].size;
sg_ptr->ptr1 = list[i * SGV2_COMPS_MAX + 1].dma_addr;
fallthrough;
case SG_COMP_1:
sg_ptr->len0 = list[i * SGV2_COMPS_MAX + 0].size;
sg_ptr->ptr0 = list[i * SGV2_COMPS_MAX + 0].dma_addr;
break;
default:
break;
}
return 0;
sg_cleanup:
for (j = 0; j < i; j++) {
if (list[j].dma_addr) {
dma_unmap_single(&pdev->dev, list[j].dma_addr,
list[j].size, DMA_BIDIRECTIONAL);
}
list[j].dma_addr = 0;
}
return -EIO;
}
static inline struct otx2_cpt_inst_info *
cn10k_sgv2_info_create(struct pci_dev *pdev, struct otx2_cpt_req_info *req,
gfp_t gfp)
{
u32 dlen = 0, g_len, sg_len, info_len;
int align = OTX2_CPT_DMA_MINALIGN;
struct otx2_cpt_inst_info *info;
u16 g_sz_bytes, s_sz_bytes;
u32 total_mem_len;
int i;
g_sz_bytes = ((req->in_cnt + 2) / 3) *
sizeof(struct cn10kb_cpt_sglist_component);
s_sz_bytes = ((req->out_cnt + 2) / 3) *
sizeof(struct cn10kb_cpt_sglist_component);
g_len = ALIGN(g_sz_bytes, align);
sg_len = ALIGN(g_len + s_sz_bytes, align);
info_len = ALIGN(sizeof(*info), align);
total_mem_len = sg_len + info_len + sizeof(union otx2_cpt_res_s);
info = kzalloc(total_mem_len, gfp);
if (unlikely(!info))
return NULL;
for (i = 0; i < req->in_cnt; i++)
dlen += req->in[i].size;
info->dlen = dlen;
info->in_buffer = (u8 *)info + info_len;
info->gthr_sz = req->in_cnt;
info->sctr_sz = req->out_cnt;
/* Setup gather (input) components */
if (sgv2io_components_setup(pdev, req->in, req->in_cnt,
info->in_buffer)) {
dev_err(&pdev->dev, "Failed to setup gather list\n");
goto destroy_info;
}
if (sgv2io_components_setup(pdev, req->out, req->out_cnt,
&info->in_buffer[g_len])) {
dev_err(&pdev->dev, "Failed to setup scatter list\n");
goto destroy_info;
}
info->dma_len = total_mem_len - info_len;
info->dptr_baddr = dma_map_single(&pdev->dev, info->in_buffer,
info->dma_len, DMA_BIDIRECTIONAL);
if (unlikely(dma_mapping_error(&pdev->dev, info->dptr_baddr))) {
dev_err(&pdev->dev, "DMA Mapping failed for cpt req\n");
goto destroy_info;
}
info->rptr_baddr = info->dptr_baddr + g_len;
/*
* Get buffer for union otx2_cpt_res_s response
* structure and its physical address
*/
info->completion_addr = info->in_buffer + sg_len;
info->comp_baddr = info->dptr_baddr + sg_len;
return info;
destroy_info:
otx2_cpt_info_destroy(pdev, info);
return NULL;
}
/* SG list header size in bytes */
#define SG_LIST_HDR_SIZE 8
static inline struct otx2_cpt_inst_info *
otx2_sg_info_create(struct pci_dev *pdev, struct otx2_cpt_req_info *req,
gfp_t gfp)
{
int align = OTX2_CPT_DMA_MINALIGN;
struct otx2_cpt_inst_info *info;
u32 dlen, align_dlen, info_len;
u16 g_sz_bytes, s_sz_bytes;
u32 total_mem_len;
if (unlikely(req->in_cnt > OTX2_CPT_MAX_SG_IN_CNT ||
req->out_cnt > OTX2_CPT_MAX_SG_OUT_CNT)) {
dev_err(&pdev->dev, "Error too many sg components\n");
return NULL;
}
g_sz_bytes = ((req->in_cnt + 3) / 4) *
sizeof(struct otx2_cpt_sglist_component);
s_sz_bytes = ((req->out_cnt + 3) / 4) *
sizeof(struct otx2_cpt_sglist_component);
dlen = g_sz_bytes + s_sz_bytes + SG_LIST_HDR_SIZE;
align_dlen = ALIGN(dlen, align);
info_len = ALIGN(sizeof(*info), align);
total_mem_len = align_dlen + info_len + sizeof(union otx2_cpt_res_s);
info = kzalloc(total_mem_len, gfp);
if (unlikely(!info))
return NULL;
info->dlen = dlen;
info->in_buffer = (u8 *)info + info_len;
((u16 *)info->in_buffer)[0] = req->out_cnt;
((u16 *)info->in_buffer)[1] = req->in_cnt;
((u16 *)info->in_buffer)[2] = 0;
((u16 *)info->in_buffer)[3] = 0;
cpu_to_be64s((u64 *)info->in_buffer);
/* Setup gather (input) components */
if (setup_sgio_components(pdev, req->in, req->in_cnt,
&info->in_buffer[8])) {
dev_err(&pdev->dev, "Failed to setup gather list\n");
goto destroy_info;
}
if (setup_sgio_components(pdev, req->out, req->out_cnt,
&info->in_buffer[8 + g_sz_bytes])) {
dev_err(&pdev->dev, "Failed to setup scatter list\n");
goto destroy_info;
}
info->dma_len = total_mem_len - info_len;
info->dptr_baddr = dma_map_single(&pdev->dev, info->in_buffer,
info->dma_len, DMA_BIDIRECTIONAL);
if (unlikely(dma_mapping_error(&pdev->dev, info->dptr_baddr))) {
dev_err(&pdev->dev, "DMA Mapping failed for cpt req\n");
goto destroy_info;
}
/*
* Get buffer for union otx2_cpt_res_s response
* structure and its physical address
*/
info->completion_addr = info->in_buffer + align_dlen;
info->comp_baddr = info->dptr_baddr + align_dlen;
return info;
destroy_info:
otx2_cpt_info_destroy(pdev, info);
return NULL;
}
struct otx2_cptlf_wqe; struct otx2_cptlf_wqe;
int otx2_cpt_do_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req, int otx2_cpt_do_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req,
int cpu_num); int cpu_num);
......
...@@ -99,6 +99,9 @@ struct cpt_hw_ops { ...@@ -99,6 +99,9 @@ struct cpt_hw_ops {
struct otx2_cptlf_info *lf); struct otx2_cptlf_info *lf);
u8 (*cpt_get_compcode)(union otx2_cpt_res_s *result); u8 (*cpt_get_compcode)(union otx2_cpt_res_s *result);
u8 (*cpt_get_uc_compcode)(union otx2_cpt_res_s *result); u8 (*cpt_get_uc_compcode)(union otx2_cpt_res_s *result);
struct otx2_cpt_inst_info *
(*cpt_sg_info_create)(struct pci_dev *pdev, struct otx2_cpt_req_info *req,
gfp_t gfp);
}; };
struct otx2_cptlfs_info { struct otx2_cptlfs_info {
......
...@@ -14,6 +14,8 @@ ...@@ -14,6 +14,8 @@
#define OTX2_CPT_DRV_STRING "Marvell RVU CPT Physical Function Driver" #define OTX2_CPT_DRV_STRING "Marvell RVU CPT Physical Function Driver"
#define CPT_UC_RID_CN9K_B0 1 #define CPT_UC_RID_CN9K_B0 1
#define CPT_UC_RID_CN10K_A 4
#define CPT_UC_RID_CN10K_B 5
static void cptpf_enable_vfpf_mbox_intr(struct otx2_cptpf_dev *cptpf, static void cptpf_enable_vfpf_mbox_intr(struct otx2_cptpf_dev *cptpf,
int num_vfs) int num_vfs)
...@@ -587,6 +589,24 @@ static int cpt_is_pf_usable(struct otx2_cptpf_dev *cptpf) ...@@ -587,6 +589,24 @@ static int cpt_is_pf_usable(struct otx2_cptpf_dev *cptpf)
return 0; return 0;
} }
static void cptpf_get_rid(struct pci_dev *pdev, struct otx2_cptpf_dev *cptpf)
{
struct otx2_cpt_eng_grps *eng_grps = &cptpf->eng_grps;
u64 reg_val = 0x0;
if (is_dev_otx2(pdev)) {
eng_grps->rid = pdev->revision;
return;
}
otx2_cpt_read_af_reg(&cptpf->afpf_mbox, pdev, CPT_AF_CTL, &reg_val,
BLKADDR_CPT0);
if ((is_dev_cn10ka_b0(pdev) && (reg_val & BIT_ULL(18))) ||
is_dev_cn10ka_ax(pdev))
eng_grps->rid = CPT_UC_RID_CN10K_A;
else if (is_dev_cn10kb(pdev) || is_dev_cn10ka_b0(pdev))
eng_grps->rid = CPT_UC_RID_CN10K_B;
}
static void cptpf_check_block_implemented(struct otx2_cptpf_dev *cptpf) static void cptpf_check_block_implemented(struct otx2_cptpf_dev *cptpf)
{ {
u64 cfg; u64 cfg;
...@@ -658,6 +678,7 @@ static int cptpf_sriov_enable(struct pci_dev *pdev, int num_vfs) ...@@ -658,6 +678,7 @@ static int cptpf_sriov_enable(struct pci_dev *pdev, int num_vfs)
if (ret) if (ret)
goto destroy_flr; goto destroy_flr;
cptpf_get_rid(pdev, cptpf);
/* Get CPT HW capabilities using LOAD_FVC operation. */ /* Get CPT HW capabilities using LOAD_FVC operation. */
ret = otx2_cpt_discover_eng_capabilities(cptpf); ret = otx2_cpt_discover_eng_capabilities(cptpf);
if (ret) if (ret)
......
...@@ -78,7 +78,7 @@ static int handle_msg_get_caps(struct otx2_cptpf_dev *cptpf, ...@@ -78,7 +78,7 @@ static int handle_msg_get_caps(struct otx2_cptpf_dev *cptpf,
rsp->hdr.sig = OTX2_MBOX_RSP_SIG; rsp->hdr.sig = OTX2_MBOX_RSP_SIG;
rsp->hdr.pcifunc = req->pcifunc; rsp->hdr.pcifunc = req->pcifunc;
rsp->cpt_pf_drv_version = OTX2_CPT_PF_DRV_VERSION; rsp->cpt_pf_drv_version = OTX2_CPT_PF_DRV_VERSION;
rsp->cpt_revision = cptpf->pdev->revision; rsp->cpt_revision = cptpf->eng_grps.rid;
memcpy(&rsp->eng_caps, &cptpf->eng_caps, sizeof(rsp->eng_caps)); memcpy(&rsp->eng_caps, &cptpf->eng_caps, sizeof(rsp->eng_caps));
return 0; return 0;
......
...@@ -117,12 +117,10 @@ static char *get_ucode_type_str(int ucode_type) ...@@ -117,12 +117,10 @@ static char *get_ucode_type_str(int ucode_type)
static int get_ucode_type(struct device *dev, static int get_ucode_type(struct device *dev,
struct otx2_cpt_ucode_hdr *ucode_hdr, struct otx2_cpt_ucode_hdr *ucode_hdr,
int *ucode_type) int *ucode_type, u16 rid)
{ {
struct otx2_cptpf_dev *cptpf = dev_get_drvdata(dev);
char ver_str_prefix[OTX2_CPT_UCODE_VER_STR_SZ]; char ver_str_prefix[OTX2_CPT_UCODE_VER_STR_SZ];
char tmp_ver_str[OTX2_CPT_UCODE_VER_STR_SZ]; char tmp_ver_str[OTX2_CPT_UCODE_VER_STR_SZ];
struct pci_dev *pdev = cptpf->pdev;
int i, val = 0; int i, val = 0;
u8 nn; u8 nn;
...@@ -130,7 +128,7 @@ static int get_ucode_type(struct device *dev, ...@@ -130,7 +128,7 @@ static int get_ucode_type(struct device *dev,
for (i = 0; i < strlen(tmp_ver_str); i++) for (i = 0; i < strlen(tmp_ver_str); i++)
tmp_ver_str[i] = tolower(tmp_ver_str[i]); tmp_ver_str[i] = tolower(tmp_ver_str[i]);
sprintf(ver_str_prefix, "ocpt-%02d", pdev->revision); sprintf(ver_str_prefix, "ocpt-%02d", rid);
if (!strnstr(tmp_ver_str, ver_str_prefix, OTX2_CPT_UCODE_VER_STR_SZ)) if (!strnstr(tmp_ver_str, ver_str_prefix, OTX2_CPT_UCODE_VER_STR_SZ))
return -EINVAL; return -EINVAL;
...@@ -359,7 +357,7 @@ static int cpt_attach_and_enable_cores(struct otx2_cpt_eng_grp_info *eng_grp, ...@@ -359,7 +357,7 @@ static int cpt_attach_and_enable_cores(struct otx2_cpt_eng_grp_info *eng_grp,
} }
static int load_fw(struct device *dev, struct fw_info_t *fw_info, static int load_fw(struct device *dev, struct fw_info_t *fw_info,
char *filename) char *filename, u16 rid)
{ {
struct otx2_cpt_ucode_hdr *ucode_hdr; struct otx2_cpt_ucode_hdr *ucode_hdr;
struct otx2_cpt_uc_info_t *uc_info; struct otx2_cpt_uc_info_t *uc_info;
...@@ -375,7 +373,7 @@ static int load_fw(struct device *dev, struct fw_info_t *fw_info, ...@@ -375,7 +373,7 @@ static int load_fw(struct device *dev, struct fw_info_t *fw_info,
goto free_uc_info; goto free_uc_info;
ucode_hdr = (struct otx2_cpt_ucode_hdr *)uc_info->fw->data; ucode_hdr = (struct otx2_cpt_ucode_hdr *)uc_info->fw->data;
ret = get_ucode_type(dev, ucode_hdr, &ucode_type); ret = get_ucode_type(dev, ucode_hdr, &ucode_type, rid);
if (ret) if (ret)
goto release_fw; goto release_fw;
...@@ -389,6 +387,7 @@ static int load_fw(struct device *dev, struct fw_info_t *fw_info, ...@@ -389,6 +387,7 @@ static int load_fw(struct device *dev, struct fw_info_t *fw_info,
set_ucode_filename(&uc_info->ucode, filename); set_ucode_filename(&uc_info->ucode, filename);
memcpy(uc_info->ucode.ver_str, ucode_hdr->ver_str, memcpy(uc_info->ucode.ver_str, ucode_hdr->ver_str,
OTX2_CPT_UCODE_VER_STR_SZ); OTX2_CPT_UCODE_VER_STR_SZ);
uc_info->ucode.ver_str[OTX2_CPT_UCODE_VER_STR_SZ] = 0;
uc_info->ucode.ver_num = ucode_hdr->ver_num; uc_info->ucode.ver_num = ucode_hdr->ver_num;
uc_info->ucode.type = ucode_type; uc_info->ucode.type = ucode_type;
uc_info->ucode.size = ucode_size; uc_info->ucode.size = ucode_size;
...@@ -448,7 +447,8 @@ static void print_uc_info(struct fw_info_t *fw_info) ...@@ -448,7 +447,8 @@ static void print_uc_info(struct fw_info_t *fw_info)
} }
} }
static int cpt_ucode_load_fw(struct pci_dev *pdev, struct fw_info_t *fw_info) static int cpt_ucode_load_fw(struct pci_dev *pdev, struct fw_info_t *fw_info,
u16 rid)
{ {
char filename[OTX2_CPT_NAME_LENGTH]; char filename[OTX2_CPT_NAME_LENGTH];
char eng_type[8] = {0}; char eng_type[8] = {0};
...@@ -462,9 +462,9 @@ static int cpt_ucode_load_fw(struct pci_dev *pdev, struct fw_info_t *fw_info) ...@@ -462,9 +462,9 @@ static int cpt_ucode_load_fw(struct pci_dev *pdev, struct fw_info_t *fw_info)
eng_type[i] = tolower(eng_type[i]); eng_type[i] = tolower(eng_type[i]);
snprintf(filename, sizeof(filename), "mrvl/cpt%02d/%s.out", snprintf(filename, sizeof(filename), "mrvl/cpt%02d/%s.out",
pdev->revision, eng_type); rid, eng_type);
/* Request firmware for each engine type */ /* Request firmware for each engine type */
ret = load_fw(&pdev->dev, fw_info, filename); ret = load_fw(&pdev->dev, fw_info, filename, rid);
if (ret) if (ret)
goto release_fw; goto release_fw;
} }
...@@ -1155,7 +1155,7 @@ int otx2_cpt_create_eng_grps(struct otx2_cptpf_dev *cptpf, ...@@ -1155,7 +1155,7 @@ int otx2_cpt_create_eng_grps(struct otx2_cptpf_dev *cptpf,
if (eng_grps->is_grps_created) if (eng_grps->is_grps_created)
goto unlock; goto unlock;
ret = cpt_ucode_load_fw(pdev, &fw_info); ret = cpt_ucode_load_fw(pdev, &fw_info, eng_grps->rid);
if (ret) if (ret)
goto unlock; goto unlock;
...@@ -1230,14 +1230,16 @@ int otx2_cpt_create_eng_grps(struct otx2_cptpf_dev *cptpf, ...@@ -1230,14 +1230,16 @@ int otx2_cpt_create_eng_grps(struct otx2_cptpf_dev *cptpf,
*/ */
rnm_to_cpt_errata_fixup(&pdev->dev); rnm_to_cpt_errata_fixup(&pdev->dev);
otx2_cpt_read_af_reg(&cptpf->afpf_mbox, pdev, CPT_AF_CTL, &reg_val,
BLKADDR_CPT0);
/* /*
* Configure engine group mask to allow context prefetching * Configure engine group mask to allow context prefetching
* for the groups and enable random number request, to enable * for the groups and enable random number request, to enable
* CPT to request random numbers from RNM. * CPT to request random numbers from RNM.
*/ */
reg_val |= OTX2_CPT_ALL_ENG_GRPS_MASK << 3 | BIT_ULL(16);
otx2_cpt_write_af_reg(&cptpf->afpf_mbox, pdev, CPT_AF_CTL, otx2_cpt_write_af_reg(&cptpf->afpf_mbox, pdev, CPT_AF_CTL,
OTX2_CPT_ALL_ENG_GRPS_MASK << 3 | BIT_ULL(16), reg_val, BLKADDR_CPT0);
BLKADDR_CPT0);
/* /*
* Set interval to periodically flush dirty data for the next * Set interval to periodically flush dirty data for the next
* CTX cache entry. Set the interval count to maximum supported * CTX cache entry. Set the interval count to maximum supported
...@@ -1412,7 +1414,7 @@ static int create_eng_caps_discovery_grps(struct pci_dev *pdev, ...@@ -1412,7 +1414,7 @@ static int create_eng_caps_discovery_grps(struct pci_dev *pdev,
int ret; int ret;
mutex_lock(&eng_grps->lock); mutex_lock(&eng_grps->lock);
ret = cpt_ucode_load_fw(pdev, &fw_info); ret = cpt_ucode_load_fw(pdev, &fw_info, eng_grps->rid);
if (ret) { if (ret) {
mutex_unlock(&eng_grps->lock); mutex_unlock(&eng_grps->lock);
return ret; return ret;
...@@ -1686,13 +1688,14 @@ int otx2_cpt_dl_custom_egrp_create(struct otx2_cptpf_dev *cptpf, ...@@ -1686,13 +1688,14 @@ int otx2_cpt_dl_custom_egrp_create(struct otx2_cptpf_dev *cptpf,
goto err_unlock; goto err_unlock;
} }
INIT_LIST_HEAD(&fw_info.ucodes); INIT_LIST_HEAD(&fw_info.ucodes);
ret = load_fw(dev, &fw_info, ucode_filename[0]);
ret = load_fw(dev, &fw_info, ucode_filename[0], eng_grps->rid);
if (ret) { if (ret) {
dev_err(dev, "Unable to load firmware %s\n", ucode_filename[0]); dev_err(dev, "Unable to load firmware %s\n", ucode_filename[0]);
goto err_unlock; goto err_unlock;
} }
if (ucode_idx > 1) { if (ucode_idx > 1) {
ret = load_fw(dev, &fw_info, ucode_filename[1]); ret = load_fw(dev, &fw_info, ucode_filename[1], eng_grps->rid);
if (ret) { if (ret) {
dev_err(dev, "Unable to load firmware %s\n", dev_err(dev, "Unable to load firmware %s\n",
ucode_filename[1]); ucode_filename[1]);
......
...@@ -73,7 +73,7 @@ struct otx2_cpt_ucode_hdr { ...@@ -73,7 +73,7 @@ struct otx2_cpt_ucode_hdr {
}; };
struct otx2_cpt_ucode { struct otx2_cpt_ucode {
u8 ver_str[OTX2_CPT_UCODE_VER_STR_SZ];/* u8 ver_str[OTX2_CPT_UCODE_VER_STR_SZ + 1];/*
* ucode version in readable * ucode version in readable
* format * format
*/ */
...@@ -150,6 +150,7 @@ struct otx2_cpt_eng_grps { ...@@ -150,6 +150,7 @@ struct otx2_cpt_eng_grps {
int engs_num; /* total number of engines supported */ int engs_num; /* total number of engines supported */
u8 eng_ref_cnt[OTX2_CPT_MAX_ENGINES];/* engines reference count */ u8 eng_ref_cnt[OTX2_CPT_MAX_ENGINES];/* engines reference count */
bool is_grps_created; /* Is the engine groups are already created */ bool is_grps_created; /* Is the engine groups are already created */
u16 rid;
}; };
struct otx2_cptpf_dev; struct otx2_cptpf_dev;
int otx2_cpt_init_eng_grps(struct pci_dev *pdev, int otx2_cpt_init_eng_grps(struct pci_dev *pdev,
......
...@@ -22,6 +22,7 @@ struct otx2_cptvf_dev { ...@@ -22,6 +22,7 @@ struct otx2_cptvf_dev {
int blkaddr; int blkaddr;
void *bbuf_base; void *bbuf_base;
unsigned long cap_flag; unsigned long cap_flag;
u64 eng_caps[OTX2_CPT_MAX_ENG_TYPES];
}; };
irqreturn_t otx2_cptvf_pfvf_mbox_intr(int irq, void *arg); irqreturn_t otx2_cptvf_pfvf_mbox_intr(int irq, void *arg);
...@@ -29,5 +30,6 @@ void otx2_cptvf_pfvf_mbox_handler(struct work_struct *work); ...@@ -29,5 +30,6 @@ void otx2_cptvf_pfvf_mbox_handler(struct work_struct *work);
int otx2_cptvf_send_eng_grp_num_msg(struct otx2_cptvf_dev *cptvf, int eng_type); int otx2_cptvf_send_eng_grp_num_msg(struct otx2_cptvf_dev *cptvf, int eng_type);
int otx2_cptvf_send_kvf_limits_msg(struct otx2_cptvf_dev *cptvf); int otx2_cptvf_send_kvf_limits_msg(struct otx2_cptvf_dev *cptvf);
int otx2_cpt_mbox_bbuf_init(struct otx2_cptvf_dev *cptvf, struct pci_dev *pdev); int otx2_cpt_mbox_bbuf_init(struct otx2_cptvf_dev *cptvf, struct pci_dev *pdev);
int otx2_cptvf_send_caps_msg(struct otx2_cptvf_dev *cptvf);
#endif /* __OTX2_CPTVF_H */ #endif /* __OTX2_CPTVF_H */
...@@ -382,6 +382,17 @@ static int otx2_cptvf_probe(struct pci_dev *pdev, ...@@ -382,6 +382,17 @@ static int otx2_cptvf_probe(struct pci_dev *pdev,
goto destroy_pfvf_mbox; goto destroy_pfvf_mbox;
cptvf->blkaddr = BLKADDR_CPT0; cptvf->blkaddr = BLKADDR_CPT0;
cptvf_hw_ops_get(cptvf);
ret = otx2_cptvf_send_caps_msg(cptvf);
if (ret) {
dev_err(&pdev->dev, "Couldn't get CPT engine capabilities.\n");
goto unregister_interrupts;
}
if (cptvf->eng_caps[OTX2_CPT_SE_TYPES] & BIT_ULL(35))
cptvf->lfs.ops->cpt_sg_info_create = cn10k_sgv2_info_create;
/* Initialize CPT LFs */ /* Initialize CPT LFs */
ret = cptvf_lf_init(cptvf); ret = cptvf_lf_init(cptvf);
if (ret) if (ret)
......
...@@ -72,6 +72,7 @@ static void process_pfvf_mbox_mbox_msg(struct otx2_cptvf_dev *cptvf, ...@@ -72,6 +72,7 @@ static void process_pfvf_mbox_mbox_msg(struct otx2_cptvf_dev *cptvf,
struct otx2_cptlfs_info *lfs = &cptvf->lfs; struct otx2_cptlfs_info *lfs = &cptvf->lfs;
struct otx2_cpt_kvf_limits_rsp *rsp_limits; struct otx2_cpt_kvf_limits_rsp *rsp_limits;
struct otx2_cpt_egrp_num_rsp *rsp_grp; struct otx2_cpt_egrp_num_rsp *rsp_grp;
struct otx2_cpt_caps_rsp *eng_caps;
struct cpt_rd_wr_reg_msg *rsp_reg; struct cpt_rd_wr_reg_msg *rsp_reg;
struct msix_offset_rsp *rsp_msix; struct msix_offset_rsp *rsp_msix;
int i; int i;
...@@ -127,6 +128,11 @@ static void process_pfvf_mbox_mbox_msg(struct otx2_cptvf_dev *cptvf, ...@@ -127,6 +128,11 @@ static void process_pfvf_mbox_mbox_msg(struct otx2_cptvf_dev *cptvf,
rsp_limits = (struct otx2_cpt_kvf_limits_rsp *) msg; rsp_limits = (struct otx2_cpt_kvf_limits_rsp *) msg;
cptvf->lfs.kvf_limits = rsp_limits->kvf_limits; cptvf->lfs.kvf_limits = rsp_limits->kvf_limits;
break; break;
case MBOX_MSG_GET_CAPS:
eng_caps = (struct otx2_cpt_caps_rsp *)msg;
memcpy(cptvf->eng_caps, eng_caps->eng_caps,
sizeof(cptvf->eng_caps));
break;
default: default:
dev_err(&cptvf->pdev->dev, "Unsupported msg %d received.\n", dev_err(&cptvf->pdev->dev, "Unsupported msg %d received.\n",
msg->id); msg->id);
...@@ -205,3 +211,23 @@ int otx2_cptvf_send_kvf_limits_msg(struct otx2_cptvf_dev *cptvf) ...@@ -205,3 +211,23 @@ int otx2_cptvf_send_kvf_limits_msg(struct otx2_cptvf_dev *cptvf)
return otx2_cpt_send_mbox_msg(mbox, pdev); return otx2_cpt_send_mbox_msg(mbox, pdev);
} }
int otx2_cptvf_send_caps_msg(struct otx2_cptvf_dev *cptvf)
{
struct otx2_mbox *mbox = &cptvf->pfvf_mbox;
struct pci_dev *pdev = cptvf->pdev;
struct mbox_msghdr *req;
req = (struct mbox_msghdr *)
otx2_mbox_alloc_msg_rsp(mbox, 0, sizeof(*req),
sizeof(struct otx2_cpt_caps_rsp));
if (!req) {
dev_err(&pdev->dev, "RVU MBOX failed to get message.\n");
return -EFAULT;
}
req->id = MBOX_MSG_GET_CAPS;
req->sig = OTX2_MBOX_REQ_SIG;
req->pcifunc = OTX2_CPT_RVU_PFFUNC(cptvf->vf_id, 0);
return otx2_cpt_send_mbox_msg(mbox, pdev);
}
...@@ -4,9 +4,6 @@ ...@@ -4,9 +4,6 @@
#include "otx2_cptvf.h" #include "otx2_cptvf.h"
#include "otx2_cpt_common.h" #include "otx2_cpt_common.h"
/* SG list header size in bytes */
#define SG_LIST_HDR_SIZE 8
/* Default timeout when waiting for free pending entry in us */ /* Default timeout when waiting for free pending entry in us */
#define CPT_PENTRY_TIMEOUT 1000 #define CPT_PENTRY_TIMEOUT 1000
#define CPT_PENTRY_STEP 50 #define CPT_PENTRY_STEP 50
...@@ -26,9 +23,9 @@ static void otx2_cpt_dump_sg_list(struct pci_dev *pdev, ...@@ -26,9 +23,9 @@ static void otx2_cpt_dump_sg_list(struct pci_dev *pdev,
pr_debug("Gather list size %d\n", req->in_cnt); pr_debug("Gather list size %d\n", req->in_cnt);
for (i = 0; i < req->in_cnt; i++) { for (i = 0; i < req->in_cnt; i++) {
pr_debug("Buffer %d size %d, vptr 0x%p, dmaptr 0x%p\n", i, pr_debug("Buffer %d size %d, vptr 0x%p, dmaptr 0x%llx\n", i,
req->in[i].size, req->in[i].vptr, req->in[i].size, req->in[i].vptr,
(void *) req->in[i].dma_addr); req->in[i].dma_addr);
pr_debug("Buffer hexdump (%d bytes)\n", pr_debug("Buffer hexdump (%d bytes)\n",
req->in[i].size); req->in[i].size);
print_hex_dump_debug("", DUMP_PREFIX_NONE, 16, 1, print_hex_dump_debug("", DUMP_PREFIX_NONE, 16, 1,
...@@ -36,9 +33,9 @@ static void otx2_cpt_dump_sg_list(struct pci_dev *pdev, ...@@ -36,9 +33,9 @@ static void otx2_cpt_dump_sg_list(struct pci_dev *pdev,
} }
pr_debug("Scatter list size %d\n", req->out_cnt); pr_debug("Scatter list size %d\n", req->out_cnt);
for (i = 0; i < req->out_cnt; i++) { for (i = 0; i < req->out_cnt; i++) {
pr_debug("Buffer %d size %d, vptr 0x%p, dmaptr 0x%p\n", i, pr_debug("Buffer %d size %d, vptr 0x%p, dmaptr 0x%llx\n", i,
req->out[i].size, req->out[i].vptr, req->out[i].size, req->out[i].vptr,
(void *) req->out[i].dma_addr); req->out[i].dma_addr);
pr_debug("Buffer hexdump (%d bytes)\n", req->out[i].size); pr_debug("Buffer hexdump (%d bytes)\n", req->out[i].size);
print_hex_dump_debug("", DUMP_PREFIX_NONE, 16, 1, print_hex_dump_debug("", DUMP_PREFIX_NONE, 16, 1,
req->out[i].vptr, req->out[i].size, false); req->out[i].vptr, req->out[i].size, false);
...@@ -84,149 +81,6 @@ static inline void free_pentry(struct otx2_cpt_pending_entry *pentry) ...@@ -84,149 +81,6 @@ static inline void free_pentry(struct otx2_cpt_pending_entry *pentry)
pentry->busy = false; pentry->busy = false;
} }
static inline int setup_sgio_components(struct pci_dev *pdev,
struct otx2_cpt_buf_ptr *list,
int buf_count, u8 *buffer)
{
struct otx2_cpt_sglist_component *sg_ptr = NULL;
int ret = 0, i, j;
int components;
if (unlikely(!list)) {
dev_err(&pdev->dev, "Input list pointer is NULL\n");
return -EFAULT;
}
for (i = 0; i < buf_count; i++) {
if (unlikely(!list[i].vptr))
continue;
list[i].dma_addr = dma_map_single(&pdev->dev, list[i].vptr,
list[i].size,
DMA_BIDIRECTIONAL);
if (unlikely(dma_mapping_error(&pdev->dev, list[i].dma_addr))) {
dev_err(&pdev->dev, "Dma mapping failed\n");
ret = -EIO;
goto sg_cleanup;
}
}
components = buf_count / 4;
sg_ptr = (struct otx2_cpt_sglist_component *)buffer;
for (i = 0; i < components; i++) {
sg_ptr->len0 = cpu_to_be16(list[i * 4 + 0].size);
sg_ptr->len1 = cpu_to_be16(list[i * 4 + 1].size);
sg_ptr->len2 = cpu_to_be16(list[i * 4 + 2].size);
sg_ptr->len3 = cpu_to_be16(list[i * 4 + 3].size);
sg_ptr->ptr0 = cpu_to_be64(list[i * 4 + 0].dma_addr);
sg_ptr->ptr1 = cpu_to_be64(list[i * 4 + 1].dma_addr);
sg_ptr->ptr2 = cpu_to_be64(list[i * 4 + 2].dma_addr);
sg_ptr->ptr3 = cpu_to_be64(list[i * 4 + 3].dma_addr);
sg_ptr++;
}
components = buf_count % 4;
switch (components) {
case 3:
sg_ptr->len2 = cpu_to_be16(list[i * 4 + 2].size);
sg_ptr->ptr2 = cpu_to_be64(list[i * 4 + 2].dma_addr);
fallthrough;
case 2:
sg_ptr->len1 = cpu_to_be16(list[i * 4 + 1].size);
sg_ptr->ptr1 = cpu_to_be64(list[i * 4 + 1].dma_addr);
fallthrough;
case 1:
sg_ptr->len0 = cpu_to_be16(list[i * 4 + 0].size);
sg_ptr->ptr0 = cpu_to_be64(list[i * 4 + 0].dma_addr);
break;
default:
break;
}
return ret;
sg_cleanup:
for (j = 0; j < i; j++) {
if (list[j].dma_addr) {
dma_unmap_single(&pdev->dev, list[j].dma_addr,
list[j].size, DMA_BIDIRECTIONAL);
}
list[j].dma_addr = 0;
}
return ret;
}
static inline struct otx2_cpt_inst_info *info_create(struct pci_dev *pdev,
struct otx2_cpt_req_info *req,
gfp_t gfp)
{
int align = OTX2_CPT_DMA_MINALIGN;
struct otx2_cpt_inst_info *info;
u32 dlen, align_dlen, info_len;
u16 g_sz_bytes, s_sz_bytes;
u32 total_mem_len;
if (unlikely(req->in_cnt > OTX2_CPT_MAX_SG_IN_CNT ||
req->out_cnt > OTX2_CPT_MAX_SG_OUT_CNT)) {
dev_err(&pdev->dev, "Error too many sg components\n");
return NULL;
}
g_sz_bytes = ((req->in_cnt + 3) / 4) *
sizeof(struct otx2_cpt_sglist_component);
s_sz_bytes = ((req->out_cnt + 3) / 4) *
sizeof(struct otx2_cpt_sglist_component);
dlen = g_sz_bytes + s_sz_bytes + SG_LIST_HDR_SIZE;
align_dlen = ALIGN(dlen, align);
info_len = ALIGN(sizeof(*info), align);
total_mem_len = align_dlen + info_len + sizeof(union otx2_cpt_res_s);
info = kzalloc(total_mem_len, gfp);
if (unlikely(!info))
return NULL;
info->dlen = dlen;
info->in_buffer = (u8 *)info + info_len;
((u16 *)info->in_buffer)[0] = req->out_cnt;
((u16 *)info->in_buffer)[1] = req->in_cnt;
((u16 *)info->in_buffer)[2] = 0;
((u16 *)info->in_buffer)[3] = 0;
cpu_to_be64s((u64 *)info->in_buffer);
/* Setup gather (input) components */
if (setup_sgio_components(pdev, req->in, req->in_cnt,
&info->in_buffer[8])) {
dev_err(&pdev->dev, "Failed to setup gather list\n");
goto destroy_info;
}
if (setup_sgio_components(pdev, req->out, req->out_cnt,
&info->in_buffer[8 + g_sz_bytes])) {
dev_err(&pdev->dev, "Failed to setup scatter list\n");
goto destroy_info;
}
info->dma_len = total_mem_len - info_len;
info->dptr_baddr = dma_map_single(&pdev->dev, info->in_buffer,
info->dma_len, DMA_BIDIRECTIONAL);
if (unlikely(dma_mapping_error(&pdev->dev, info->dptr_baddr))) {
dev_err(&pdev->dev, "DMA Mapping failed for cpt req\n");
goto destroy_info;
}
/*
* Get buffer for union otx2_cpt_res_s response
* structure and its physical address
*/
info->completion_addr = info->in_buffer + align_dlen;
info->comp_baddr = info->dptr_baddr + align_dlen;
return info;
destroy_info:
otx2_cpt_info_destroy(pdev, info);
return NULL;
}
static int process_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req, static int process_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req,
struct otx2_cpt_pending_queue *pqueue, struct otx2_cpt_pending_queue *pqueue,
struct otx2_cptlf_info *lf) struct otx2_cptlf_info *lf)
...@@ -247,7 +101,7 @@ static int process_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req, ...@@ -247,7 +101,7 @@ static int process_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req,
if (unlikely(!otx2_cptlf_started(lf->lfs))) if (unlikely(!otx2_cptlf_started(lf->lfs)))
return -ENODEV; return -ENODEV;
info = info_create(pdev, req, gfp); info = lf->lfs->ops->cpt_sg_info_create(pdev, req, gfp);
if (unlikely(!info)) { if (unlikely(!info)) {
dev_err(&pdev->dev, "Setting up cpt inst info failed"); dev_err(&pdev->dev, "Setting up cpt inst info failed");
return -ENOMEM; return -ENOMEM;
...@@ -303,8 +157,8 @@ static int process_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req, ...@@ -303,8 +157,8 @@ static int process_request(struct pci_dev *pdev, struct otx2_cpt_req_info *req,
/* 64-bit swap for microcode data reads, not needed for addresses*/ /* 64-bit swap for microcode data reads, not needed for addresses*/
cpu_to_be64s(&iq_cmd.cmd.u); cpu_to_be64s(&iq_cmd.cmd.u);
iq_cmd.dptr = info->dptr_baddr; iq_cmd.dptr = info->dptr_baddr | info->gthr_sz << 60;
iq_cmd.rptr = 0; iq_cmd.rptr = info->rptr_baddr | info->sctr_sz << 60;
iq_cmd.cptr.u = 0; iq_cmd.cptr.u = 0;
iq_cmd.cptr.s.grp = ctrl->s.grp; iq_cmd.cptr.s.grp = ctrl->s.grp;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment