1 /* SPDX-License-Identifier: GPL-2.0-only
2  * Copyright (C) 2020 Marvell.
3  */
4 
5 #ifndef __OTX2_CPT_COMMON_H
6 #define __OTX2_CPT_COMMON_H
7 
8 #include <linux/pci.h>
9 #include <linux/types.h>
10 #include <linux/module.h>
11 #include <linux/delay.h>
12 #include <linux/crypto.h>
13 #include "otx2_cpt_hw_types.h"
14 #include "rvu.h"
15 #include "mbox.h"
16 
17 #define OTX2_CPT_MAX_VFS_NUM 128
18 #define OTX2_CPT_RVU_FUNC_ADDR_S(blk, slot, offs) \
19 		(((blk) << 20) | ((slot) << 12) | (offs))
20 #define OTX2_CPT_RVU_PFFUNC(pf, func)	\
21 		((((pf) & RVU_PFVF_PF_MASK) << RVU_PFVF_PF_SHIFT) | \
22 		(((func) & RVU_PFVF_FUNC_MASK) << RVU_PFVF_FUNC_SHIFT))
23 
24 #define OTX2_CPT_INVALID_CRYPTO_ENG_GRP 0xFF
25 #define OTX2_CPT_NAME_LENGTH 64
26 #define OTX2_CPT_DMA_MINALIGN 128
27 
28 #define BAD_OTX2_CPT_ENG_TYPE OTX2_CPT_MAX_ENG_TYPES
29 
30 enum otx2_cpt_eng_type {
31 	OTX2_CPT_AE_TYPES = 1,
32 	OTX2_CPT_SE_TYPES = 2,
33 	OTX2_CPT_IE_TYPES = 3,
34 	OTX2_CPT_MAX_ENG_TYPES,
35 };
36 
37 /* Take mbox id from end of CPT mbox range in AF (range 0xA00 - 0xBFF) */
38 #define MBOX_MSG_GET_ENG_GRP_NUM        0xBFF
39 #define MBOX_MSG_GET_CAPS               0xBFD
40 #define MBOX_MSG_GET_KVF_LIMITS         0xBFC
41 
42 /*
43  * Message request and response to get engine group number
44  * which has attached a given type of engines (SE, AE, IE)
45  * This messages are only used between CPT PF <=> CPT VF
46  */
47 struct otx2_cpt_egrp_num_msg {
48 	struct mbox_msghdr hdr;
49 	u8 eng_type;
50 };
51 
52 struct otx2_cpt_egrp_num_rsp {
53 	struct mbox_msghdr hdr;
54 	u8 eng_type;
55 	u8 eng_grp_num;
56 };
57 
58 /*
59  * Message request and response to get kernel crypto limits
60  * This messages are only used between CPT PF <-> CPT VF
61  */
62 struct otx2_cpt_kvf_limits_msg {
63 	struct mbox_msghdr hdr;
64 };
65 
66 struct otx2_cpt_kvf_limits_rsp {
67 	struct mbox_msghdr hdr;
68 	u8 kvf_limits;
69 };
70 
71 /* CPT HW capabilities */
72 union otx2_cpt_eng_caps {
73 	u64 u;
74 	struct {
75 		u64 reserved_0_4:5;
76 		u64 mul:1;
77 		u64 sha1_sha2:1;
78 		u64 chacha20:1;
79 		u64 zuc_snow3g:1;
80 		u64 sha3:1;
81 		u64 aes:1;
82 		u64 kasumi:1;
83 		u64 des:1;
84 		u64 crc:1;
85 		u64 reserved_14_63:50;
86 	};
87 };
88 
89 /*
90  * Message request and response to get HW capabilities for each
91  * engine type (SE, IE, AE).
92  * This messages are only used between CPT PF <=> CPT VF
93  */
94 struct otx2_cpt_caps_msg {
95 	struct mbox_msghdr hdr;
96 };
97 
98 struct otx2_cpt_caps_rsp {
99 	struct mbox_msghdr hdr;
100 	u16 cpt_pf_drv_version;
101 	u8 cpt_revision;
102 	union otx2_cpt_eng_caps eng_caps[OTX2_CPT_MAX_ENG_TYPES];
103 };
104 
105 static inline void otx2_cpt_write64(void __iomem *reg_base, u64 blk, u64 slot,
106 				    u64 offs, u64 val)
107 {
108 	writeq_relaxed(val, reg_base +
109 		       OTX2_CPT_RVU_FUNC_ADDR_S(blk, slot, offs));
110 }
111 
112 static inline u64 otx2_cpt_read64(void __iomem *reg_base, u64 blk, u64 slot,
113 				  u64 offs)
114 {
115 	return readq_relaxed(reg_base +
116 			     OTX2_CPT_RVU_FUNC_ADDR_S(blk, slot, offs));
117 }
118 
119 int otx2_cpt_send_ready_msg(struct otx2_mbox *mbox, struct pci_dev *pdev);
120 int otx2_cpt_send_mbox_msg(struct otx2_mbox *mbox, struct pci_dev *pdev);
121 
122 int otx2_cpt_send_af_reg_requests(struct otx2_mbox *mbox,
123 				  struct pci_dev *pdev);
124 int otx2_cpt_add_read_af_reg(struct otx2_mbox *mbox,
125 			     struct pci_dev *pdev, u64 reg, u64 *val);
126 int otx2_cpt_add_write_af_reg(struct otx2_mbox *mbox, struct pci_dev *pdev,
127 			      u64 reg, u64 val);
128 int otx2_cpt_read_af_reg(struct otx2_mbox *mbox, struct pci_dev *pdev,
129 			 u64 reg, u64 *val);
130 int otx2_cpt_write_af_reg(struct otx2_mbox *mbox, struct pci_dev *pdev,
131 			  u64 reg, u64 val);
132 struct otx2_cptlfs_info;
133 int otx2_cpt_attach_rscrs_msg(struct otx2_cptlfs_info *lfs);
134 int otx2_cpt_detach_rsrcs_msg(struct otx2_cptlfs_info *lfs);
135 int otx2_cpt_msix_offset_msg(struct otx2_cptlfs_info *lfs);
136 
137 #endif /* __OTX2_CPT_COMMON_H */
138