blob: a23b7948d92d5920347ce70c09d350ea7b6303d0 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Rick Chene76b8042017-12-26 13:55:48 +08002/*
Yu Chien Peter Lin82f0f532023-02-06 16:10:47 +08003 * Copyright (C) 2023 Andes Technology Corporation
Rick Chene76b8042017-12-26 13:55:48 +08004 * Rick Chen, Andes Technology Corporation <rick@andestech.com>
Rick Chene76b8042017-12-26 13:55:48 +08005 */
6
7/* CPU specific code */
Simon Glass1d91ba72019-11-14 12:57:37 -07008#include <cpu_func.h>
Simon Glass63334482019-11-14 12:57:39 -07009#include <irq_func.h>
Rick Chen842d5802018-11-07 09:34:06 +080010#include <asm/cache.h>
Leo Yu-Chi Liang2795bf22021-09-23 10:34:29 +080011#include <asm/csr.h>
Yu Chien Peter Lin82f0f532023-02-06 16:10:47 +080012#include <asm/arch-andes/csr.h>
Rick Chene76b8042017-12-26 13:55:48 +080013
14/*
15 * cleanup_before_linux() is called just before we call linux
16 * it prepares the processor for linux
17 *
18 * we disable interrupt and caches.
19 */
20int cleanup_before_linux(void)
21{
22 disable_interrupts();
23
Rick Chen842d5802018-11-07 09:34:06 +080024 cache_flush();
Rick Chene76b8042017-12-26 13:55:48 +080025
26 return 0;
27}
Leo Yu-Chi Liang2795bf22021-09-23 10:34:29 +080028
29void harts_early_init(void)
30{
Yu Chien Peter Lin82f0f532023-02-06 16:10:47 +080031 /* Enable I/D-cache in SPL */
Leo Yu-Chi Liang2795bf22021-09-23 10:34:29 +080032 if (CONFIG_IS_ENABLED(RISCV_MMODE)) {
Yu Chien Peter Lin82f0f532023-02-06 16:10:47 +080033 unsigned long mcache_ctl_val = csr_read(CSR_MCACHE_CTL);
Leo Yu-Chi Liang96e75a82023-12-26 14:17:34 +080034 unsigned long mmisc_ctl_val = csr_read(CSR_MMISC_CTL);
Leo Yu-Chi Liang2795bf22021-09-23 10:34:29 +080035
Leo Yu-Chi Liang96e75a82023-12-26 14:17:34 +080036 mcache_ctl_val |= (MCACHE_CTL_CCTL_SUEN | \
37 MCACHE_CTL_IC_PREFETCH_EN | MCACHE_CTL_DC_PREFETCH_EN | \
38 MCACHE_CTL_DC_WAROUND_EN | MCACHE_CTL_L2C_WAROUND_EN);
Leo Yu-Chi Liang1eb9f912023-12-26 14:17:33 +080039
40 if (!CONFIG_IS_ENABLED(SYS_ICACHE_OFF))
41 mcache_ctl_val |= MCACHE_CTL_IC_EN;
42
43 if (!CONFIG_IS_ENABLED(SYS_DCACHE_OFF))
44 mcache_ctl_val |= (MCACHE_CTL_DC_EN | MCACHE_CTL_DC_COHEN);
Yu Chien Peter Lin82f0f532023-02-06 16:10:47 +080045
Leo Yu-Chi Liang2795bf22021-09-23 10:34:29 +080046 csr_write(CSR_MCACHE_CTL, mcache_ctl_val);
47
Leo Yu-Chi Liang1eb9f912023-12-26 14:17:33 +080048 if (!CONFIG_IS_ENABLED(SYS_DCACHE_OFF)) {
49 /*
50 * Check mcache_ctl.DC_COHEN, we assume this platform does
51 * not support CM if the bit is hard-wired to 0.
52 */
53 if (csr_read(CSR_MCACHE_CTL) & MCACHE_CTL_DC_COHEN) {
54 /* Wait for DC_COHSTA bit to be set */
55 while (!(csr_read(CSR_MCACHE_CTL) & MCACHE_CTL_DC_COHSTA));
56 }
Leo Yu-Chi Liang2795bf22021-09-23 10:34:29 +080057 }
Leo Yu-Chi Liang96e75a82023-12-26 14:17:34 +080058
59 mmisc_ctl_val |= MMISC_CTL_NON_BLOCKING_EN;
60
61 csr_write(CSR_MMISC_CTL, mmisc_ctl_val);
Leo Yu-Chi Liang2795bf22021-09-23 10:34:29 +080062 }
63}