diff --git a/platform/generic/include/mips/p8700.h b/platform/generic/include/mips/p8700.h index 06756355..3752bdf2 100644 --- a/platform/generic/include/mips/p8700.h +++ b/platform/generic/include/mips/p8700.h @@ -144,6 +144,24 @@ extern const struct p8700_cm_info *p8700_cm_info; #define L2SM_COP_RESULT_ABORT_OK 3 #define L2SM_COP_RESULT_ABORT_ERROR 4 #define GCR_L2SM_COP_PRESENT BIT(31) +/* MMIO regions. Actual count in GCR_GLOBAL_CONFIG.GCR_GC_NUM_MMIOS */ +#define GCR_MMIO_BOTTOM(n) (0x700 + (n) * 0x10) /* n = 0..7 */ +#define GCR_MMIO_TOP(n) (0x708 + (n) * 0x10) /* n = 0..7 */ +#define GCR_MMIO_ADDR GENMASK(47, 16) /* both top and bottom */ +#define GCR_MMIO_BOTTOM_CCA GENMASK(9, 8) +#define GCR_MMIO_BOTTOM_FORCE_NC BIT(6) +/* + * 15:12 - reserved + * 11 - AUX3 + * 10 - AUX2 + * 9 - AUX1 + * 8 - AUX0 + * 7:1 - reserved + * 0 - Main memory port; MEM + */ +#define GCR_MMIO_BOTTOM_PORT GENMASK(5, 2) +#define GCR_MMIO_BOTTOM_DIS_RQ_LIM BIT(1) +#define GCR_MMIO_BOTTOM_EN BIT(0) /* CPC Block offsets */ #define CPC_PWRUP_CTL 0x0030 diff --git a/platform/generic/mips/eyeq7h.c b/platform/generic/mips/eyeq7h.c index 281848e7..b7bffad7 100644 --- a/platform/generic/mips/eyeq7h.c +++ b/platform/generic/mips/eyeq7h.c @@ -37,6 +37,7 @@ #define OLB_ACC1 0x65000000 #define OLB_XNN0 0x43600000 #define OLB_XNN1 0x63600000 +#define NCORE 0x67800000 #define OLB_WEST 0x48600000 #define OLB_WEST_TSTCSR 0x60 #define TSTCSR_PALLADIUM BIT(0) @@ -369,6 +370,12 @@ static int eyeq7h_nascent_init(void) (void *)(cm_base + L2_PFT_CONTROL_OFFSET)); __raw_writel(0x15ff, (void *)(cm_base + L2_PFT_CONTROL_B_OFFSET)); + /* + * Remove access to NCORE CSRs from mmio region 1 + * which is routed to AUX. NCORE to use default route through MEM. + */ + __raw_writeq(NCORE-1, (void *)(cm_base + GCR_MMIO_TOP(1))); + mb(); } /* Per core set up */