blob: 4b81a276b64a9467c68b50615f428ff7da91184f [file] [log] [blame]
Yidi Lin27be9042021-03-25 17:50:14 +08001/* SPDX-License-Identifier: GPL-2.0-only */
2
3#include <device/mmio.h>
4#include <soc/mcucfg.h>
5#include <soc/mmu_operations.h>
6#include <soc/symbols.h>
7
8DEFINE_BIT(MP0_CLUSTER_CFG0_L3_SHARE_EN, 9)
9DEFINE_BIT(MP0_CLUSTER_CFG0_L3_SHARE_PRE_EN, 8)
10
11void mtk_soc_disable_l2c_sram(void)
12{
13 unsigned long v;
14
Rex-BC Chen7d9bd172021-11-11 15:45:27 +080015 SET32_BITFIELDS(&mtk_mcucfg->mp0_cluster_cfg0,
Yidi Lin27be9042021-03-25 17:50:14 +080016 MP0_CLUSTER_CFG0_L3_SHARE_EN, 0);
17 dsb();
18
19 __asm__ volatile ("mrs %0, S3_0_C15_C3_5" : "=r" (v));
20 v |= (0xf << 4);
21 __asm__ volatile ("msr S3_0_C15_C3_5, %0" : : "r" (v));
22 dsb();
23
24 do {
25 __asm__ volatile ("mrs %0, S3_0_C15_C3_7" : "=r" (v));
26 } while (((v >> 0x4) & 0xf) != 0xf);
27
Rex-BC Chen7d9bd172021-11-11 15:45:27 +080028 SET32_BITFIELDS(&mtk_mcucfg->mp0_cluster_cfg0,
Yidi Lin27be9042021-03-25 17:50:14 +080029 MP0_CLUSTER_CFG0_L3_SHARE_PRE_EN, 0);
30 dsb();
31}
Rex-BC Chen00b43c92021-05-10 20:06:35 +080032
33/* mtk_soc_after_dram is called in romstage */
34void mtk_soc_after_dram(void)
35{
36 mmu_config_range(_dram_dma, REGION_SIZE(dram_dma),
37 NONSECURE_UNCACHED_MEM);
38}