blob: 525c87f37cd4ca79d2428c3c3a109121c1448f76 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Christophe Leroy0ae15b92017-07-13 15:10:00 +02002/*
3 * (C) Copyright 2017
4 * Christophe Leroy, CS Systemes d'Information, christophe.leroy@c-s.fr
Christophe Leroy0ae15b92017-07-13 15:10:00 +02005 */
6
Simon Glass1d91ba72019-11-14 12:57:37 -07007#include <cpu_func.h>
Christophe Leroy0ae15b92017-07-13 15:10:00 +02008#include <asm/processor.h>
9#include <asm/ppc.h>
10#include <asm/io.h>
11#include <asm/mmu.h>
12
13int icache_status(void)
14{
15 return !!(mfspr(IC_CST) & IDC_ENABLED);
16}
17
18void icache_enable(void)
19{
20 sync();
21 mtspr(IC_CST, IDC_INVALL);
22 mtspr(IC_CST, IDC_ENABLE);
23}
24
25void icache_disable(void)
26{
27 sync();
28 mtspr(IC_CST, IDC_DISABLE);
29}
30
31int dcache_status(void)
32{
33 return !!(mfspr(IC_CST) & IDC_ENABLED);
34}
35
36void dcache_enable(void)
37{
38 mtspr(MD_CTR, MD_RESETVAL); /* Set cache mode with MMU off */
39 mtspr(DC_CST, IDC_INVALL);
40 mtspr(DC_CST, IDC_ENABLE);
41}
42
43void dcache_disable(void)
44{
45 sync();
46 mtspr(DC_CST, IDC_DISABLE);
47 mtspr(DC_CST, IDC_INVALL);
48}