X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;ds=inline;f=lib_blackfin%2Fcache.c;h=c2f6e2848ef1db7750ba03edfb41de2ae55f9adf;hb=d977a57356657ba241256231efca32828a5822f9;hp=847278d226ed3114bfd709d28878b2786c27c26e;hpb=7b230f61db319d87d51449d4620d520822813fbb;p=u-boot diff --git a/lib_blackfin/cache.c b/lib_blackfin/cache.c index 847278d226..c2f6e2848e 100644 --- a/lib_blackfin/cache.c +++ b/lib_blackfin/cache.c @@ -1,40 +1,26 @@ /* * U-boot - cache.c * - * Copyright (c) 2005 blackfin.uclinux.org + * Copyright (c) 2005-2008 Analog Devices Inc. * * (C) Copyright 2000-2004 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * - * See file CREDITS for list of people who contributed to this - * project. - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of - * the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, - * MA 02111-1307 USA + * Licensed under the GPL-2 or later. */ -/* for now: just dummy functions to satisfy the linker */ -extern void blackfin_icache_range (unsigned long *, unsigned long *); -extern void blackfin_dcache_range (unsigned long *, unsigned long *); -void flush_cache (unsigned long dummy1, unsigned long dummy2) +#include +#include + +void flush_cache(unsigned long addr, unsigned long size) { - if (icache_status ()) { - blackfin_icache_flush_range (dummy1, dummy1 + dummy2); - } - if (dcache_status ()) { - blackfin_dcache_flush_range (dummy1, dummy1 + dummy2); - } - return; + /* no need to flush stuff in on chip memory (L1/L2/etc...) */ + if (addr >= 0xE0000000) + return; + + if (icache_status()) + blackfin_icache_flush_range((void *)addr, (void *)(addr + size)); + + if (dcache_status()) + blackfin_dcache_flush_range((void *)addr, (void *)(addr + size)); }