xref: /linux/drivers/net/ethernet/marvell/octeontx2/af/cn20k/reg.h (revision 8be4d31cb8aaeea27bde4b7ddb26e28a89062ebf)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Marvell RVU Admin Function driver
3  *
4  * Copyright (C) 2024 Marvell.
5  *
6  */
7 
8 #ifndef RVU_MBOX_REG_H
9 #define RVU_MBOX_REG_H
10 #include "../rvu.h"
11 #include "../rvu_reg.h"
12 
13 /* RVUM block registers */
14 #define RVU_PF_DISC				(0x0)
15 #define RVU_PRIV_PFX_DISC(a)			(0x8000208 | (a) << 16)
16 #define RVU_PRIV_HWVFX_DISC(a)			(0xD000000 | (a) << 12)
17 
18 /* Mbox Registers */
19 /* RVU AF BAR0 Mbox registers for AF => PFx */
20 #define RVU_MBOX_AF_PFX_ADDR(a)			(0x5000 | (a) << 4)
21 #define RVU_MBOX_AF_PFX_CFG(a)			(0x6000 | (a) << 4)
22 #define RVU_MBOX_AF_AFPFX_TRIGX(a)		(0x9000 | (a) << 3)
23 #define RVU_MBOX_AF_PFAF_INT(a)			(0x2980 | (a) << 6)
24 #define RVU_MBOX_AF_PFAF_INT_W1S(a)		(0x2988 | (a) << 6)
25 #define RVU_MBOX_AF_PFAF_INT_ENA_W1S(a)		(0x2990 | (a) << 6)
26 #define RVU_MBOX_AF_PFAF_INT_ENA_W1C(a)		(0x2998 | (a) << 6)
27 #define RVU_MBOX_AF_PFAF1_INT(a)		(0x29A0 | (a) << 6)
28 #define RVU_MBOX_AF_PFAF1_INT_W1S(a)		(0x29A8 | (a) << 6)
29 #define RVU_MBOX_AF_PFAF1_INT_ENA_W1S(a)	(0x29B0 | (a) << 6)
30 #define RVU_MBOX_AF_PFAF1_INT_ENA_W1C(a)	(0x29B8 | (a) << 6)
31 
32 /* RVU PF => AF mbox registers */
33 #define RVU_MBOX_PF_PFAF_TRIGX(a)		(0xC00 | (a) << 3)
34 #define RVU_MBOX_PF_INT				(0xC20)
35 #define RVU_MBOX_PF_INT_W1S			(0xC28)
36 #define RVU_MBOX_PF_INT_ENA_W1S			(0xC30)
37 #define RVU_MBOX_PF_INT_ENA_W1C			(0xC38)
38 
39 #define RVU_AF_BAR2_SEL				(0x9000000)
40 #define RVU_AF_BAR2_PFID			(0x16400)
41 #define NIX_CINTX_INT_W1S(a)			(0xd30 | (a) << 12)
42 #define NIX_QINTX_CNT(a)			(0xc00 | (a) << 12)
43 
44 #define RVU_MBOX_AF_VFAF_INT(a)			(0x3000 | (a) << 6)
45 #define RVU_MBOX_AF_VFAF_INT_W1S(a)		(0x3008 | (a) << 6)
46 #define RVU_MBOX_AF_VFAF_INT_ENA_W1S(a)		(0x3010 | (a) << 6)
47 #define RVU_MBOX_AF_VFAF_INT_ENA_W1C(a)		(0x3018 | (a) << 6)
48 #define RVU_MBOX_AF_VFAF_INT_ENA_W1C(a)		(0x3018 | (a) << 6)
49 #define RVU_MBOX_AF_VFAF1_INT(a)		(0x3020 | (a) << 6)
50 #define RVU_MBOX_AF_VFAF1_INT_W1S(a)		(0x3028 | (a) << 6)
51 #define RVU_MBOX_AF_VFAF1_IN_ENA_W1S(a)		(0x3030 | (a) << 6)
52 #define RVU_MBOX_AF_VFAF1_IN_ENA_W1C(a)		(0x3038 | (a) << 6)
53 
54 #define RVU_MBOX_AF_AFVFX_TRIG(a, b)		(0x10000 | (a) << 4 | (b) << 3)
55 #define RVU_MBOX_AF_VFX_ADDR(a)			(0x20000 | (a) << 4)
56 #define RVU_MBOX_AF_VFX_CFG(a)			(0x28000 | (a) << 4)
57 
58 #define RVU_MBOX_PF_VFX_PFVF_TRIGX(a)		(0x2000 | (a) << 3)
59 
60 #define RVU_MBOX_PF_VFPF_INTX(a)		(0x1000 | (a) << 3)
61 #define RVU_MBOX_PF_VFPF_INT_W1SX(a)		(0x1020 | (a) << 3)
62 #define RVU_MBOX_PF_VFPF_INT_ENA_W1SX(a)	(0x1040 | (a) << 3)
63 #define RVU_MBOX_PF_VFPF_INT_ENA_W1CX(a)	(0x1060 | (a) << 3)
64 
65 #define RVU_MBOX_PF_VFPF1_INTX(a)		(0x1080 | (a) << 3)
66 #define RVU_MBOX_PF_VFPF1_INT_W1SX(a)		(0x10a0 | (a) << 3)
67 #define RVU_MBOX_PF_VFPF1_INT_ENA_W1SX(a)	(0x10c0 | (a) << 3)
68 #define RVU_MBOX_PF_VFPF1_INT_ENA_W1CX(a)	(0x10e0 | (a) << 3)
69 
70 #define RVU_MBOX_PF_VF_ADDR			(0xC40)
71 #define RVU_MBOX_PF_LMTLINE_ADDR		(0xC48)
72 #define RVU_MBOX_PF_VF_CFG			(0xC60)
73 
74 #define RVU_MBOX_VF_VFPF_TRIGX(a)		(0x3000 | (a) << 3)
75 #define RVU_MBOX_VF_INT				(0x20)
76 #define RVU_MBOX_VF_INT_W1S			(0x28)
77 #define RVU_MBOX_VF_INT_ENA_W1S			(0x30)
78 #define RVU_MBOX_VF_INT_ENA_W1C			(0x38)
79 
80 #define RVU_MBOX_VF_VFAF_TRIGX(a)		(0x2000 | (a) << 3)
81 #endif /* RVU_MBOX_REG_H */
82