blob: 1557864f9c4470492f779bac012c9c5560cd0401 [file] [log] [blame]
Wolfgang Denk6cb142f2006-03-12 02:12:27 +01001/*
2 * U-boot - cache.c
3 *
Mike Frysingerb86b3412008-02-19 00:50:58 -05004 * Copyright (c) 2005-2008 Analog Devices Inc.
Wolfgang Denk6cb142f2006-03-12 02:12:27 +01005 *
6 * (C) Copyright 2000-2004
7 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
8 *
Mike Frysingerb86b3412008-02-19 00:50:58 -05009 * Licensed under the GPL-2 or later.
Wolfgang Denk6cb142f2006-03-12 02:12:27 +010010 */
11
Aubrey.Li3f0606a2007-03-09 13:38:44 +080012#include <common.h>
13#include <asm/blackfin.h>
Mike Frysinger50f0d212008-08-07 15:21:47 -040014#include <asm/mach-common/bits/mpu.h>
Aubrey.Li3f0606a2007-03-09 13:38:44 +080015
Mike Frysingerb86b3412008-02-19 00:50:58 -050016void flush_cache(unsigned long addr, unsigned long size)
Wolfgang Denk6cb142f2006-03-12 02:12:27 +010017{
Mike Frysingerfdce83c2008-11-04 00:04:03 -050018 void *start_addr, *end_addr;
19 int istatus, dstatus;
20
Mike Frysingerb86b3412008-02-19 00:50:58 -050021 /* no need to flush stuff in on chip memory (L1/L2/etc...) */
22 if (addr >= 0xE0000000)
Aubrey.Li3f0606a2007-03-09 13:38:44 +080023 return;
24
Mike Frysingerfdce83c2008-11-04 00:04:03 -050025 start_addr = (void *)addr;
26 end_addr = (void *)(addr + size);
27 istatus = icache_status();
28 dstatus = dcache_status();
Aubrey.Li3f0606a2007-03-09 13:38:44 +080029
Mike Frysingerfdce83c2008-11-04 00:04:03 -050030 if (istatus) {
31 if (dstatus)
32 blackfin_icache_dcache_flush_range(start_addr, end_addr);
33 else
34 blackfin_icache_flush_range(start_addr, end_addr);
35 } else if (dstatus)
36 blackfin_dcache_flush_range(start_addr, end_addr);
Wolfgang Denk6cb142f2006-03-12 02:12:27 +010037}
Mike Frysinger50f0d212008-08-07 15:21:47 -040038
39void icache_enable(void)
40{
41 bfin_write_IMEM_CONTROL(IMC | ENICPLB);
42 SSYNC();
43}
44
45void icache_disable(void)
46{
47 bfin_write_IMEM_CONTROL(0);
48 SSYNC();
49}
50
51int icache_status(void)
52{
Mike Frysinger0f9a8812008-08-07 18:40:13 -040053 return bfin_read_IMEM_CONTROL() & IMC;
Mike Frysinger50f0d212008-08-07 15:21:47 -040054}
55
56void dcache_enable(void)
57{
58 bfin_write_DMEM_CONTROL(ACACHE_BCACHE | ENDCPLB | PORT_PREF0);
59 SSYNC();
60}
61
62void dcache_disable(void)
63{
64 bfin_write_DMEM_CONTROL(0);
65 SSYNC();
66}
67
68int dcache_status(void)
69{
Mike Frysinger0f9a8812008-08-07 18:40:13 -040070 return bfin_read_DMEM_CONTROL() & ACACHE_BCACHE;
Mike Frysinger50f0d212008-08-07 15:21:47 -040071}