1
2 #ifndef __SOC_MEDIATEK_INFRACFG_H
3 #define __SOC_MEDIATEK_INFRACFG_H
4
5 #define MT8173_TOP_AXI_PROT_EN_MCI_M2 BIT(0)
6 #define MT8173_TOP_AXI_PROT_EN_MM_M0 BIT(1)
7 #define MT8173_TOP_AXI_PROT_EN_MM_M1 BIT(2)
8 #define MT8173_TOP_AXI_PROT_EN_MMAPB_S BIT(6)
9 #define MT8173_TOP_AXI_PROT_EN_L2C_M2 BIT(9)
10 #define MT8173_TOP_AXI_PROT_EN_L2SS_SMI BIT(11)
11 #define MT8173_TOP_AXI_PROT_EN_L2SS_ADD BIT(12)
12 #define MT8173_TOP_AXI_PROT_EN_CCI_M2 BIT(13)
13 #define MT8173_TOP_AXI_PROT_EN_MFG_S BIT(14)
14 #define MT8173_TOP_AXI_PROT_EN_PERI_M0 BIT(15)
15 #define MT8173_TOP_AXI_PROT_EN_PERI_M1 BIT(16)
16 #define MT8173_TOP_AXI_PROT_EN_DEBUGSYS BIT(17)
17 #define MT8173_TOP_AXI_PROT_EN_CQ_DMA BIT(18)
18 #define MT8173_TOP_AXI_PROT_EN_GCPU BIT(19)
19 #define MT8173_TOP_AXI_PROT_EN_IOMMU BIT(20)
20 #define MT8173_TOP_AXI_PROT_EN_MFG_M0 BIT(21)
21 #define MT8173_TOP_AXI_PROT_EN_MFG_M1 BIT(22)
22 #define MT8173_TOP_AXI_PROT_EN_MFG_SNOOP_OUT BIT(23)
23
24 #define MT2701_TOP_AXI_PROT_EN_MM_M0 BIT(1)
25 #define MT2701_TOP_AXI_PROT_EN_CONN_M BIT(2)
26 #define MT2701_TOP_AXI_PROT_EN_CONN_S BIT(8)
27
28 #define MT7622_TOP_AXI_PROT_EN_ETHSYS (BIT(3) | BIT(17))
29 #define MT7622_TOP_AXI_PROT_EN_HIF0 (BIT(24) | BIT(25))
30 #define MT7622_TOP_AXI_PROT_EN_HIF1 (BIT(26) | BIT(27) | \
31 BIT(28))
32 #define MT7622_TOP_AXI_PROT_EN_WB (BIT(2) | BIT(6) | \
33 BIT(7) | BIT(8))
34
35 int mtk_infracfg_set_bus_protection(struct regmap *infracfg, u32 mask,
36 bool reg_update);
37 int mtk_infracfg_clear_bus_protection(struct regmap *infracfg, u32 mask,
38 bool reg_update);
39 #endif