cache.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * U-boot - cache.c
  3. *
  4. * Copyright (c) 2005-2007 Analog Devices Inc.
  5. *
  6. * (C) Copyright 2000-2004
  7. * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
  8. *
  9. * See file CREDITS for list of people who contributed to this
  10. * project.
  11. *
  12. * This program is free software; you can redistribute it and/or
  13. * modify it under the terms of the GNU General Public License as
  14. * published by the Free Software Foundation; either version 2 of
  15. * the License, or (at your option) any later version.
  16. *
  17. * This program is distributed in the hope that it will be useful,
  18. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  19. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  20. * GNU General Public License for more details.
  21. *
  22. * You should have received a copy of the GNU General Public License
  23. * along with this program; if not, write to the Free Software
  24. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
  25. * MA 02110-1301 USA
  26. */
  27. /* for now: just dummy functions to satisfy the linker */
  28. #include <config.h>
  29. #include <common.h>
  30. #include <asm/blackfin.h>
  31. extern void blackfin_icache_flush_range(unsigned long, unsigned long);
  32. extern void blackfin_dcache_flush_range(unsigned long, unsigned long);
  33. void flush_cache(unsigned long dummy1, unsigned long dummy2)
  34. {
  35. if ((dummy1 >= L1_ISRAM) && (dummy1 < L1_ISRAM_END))
  36. return;
  37. if ((dummy1 >= DATA_BANKA_SRAM) && (dummy1 < DATA_BANKA_SRAM_END))
  38. return;
  39. if ((dummy1 >= DATA_BANKB_SRAM) && (dummy1 < DATA_BANKB_SRAM_END))
  40. return;
  41. if (icache_status())
  42. blackfin_icache_flush_range(dummy1, dummy1 + dummy2);
  43. if (dcache_status())
  44. blackfin_dcache_flush_range(dummy1, dummy1 + dummy2);
  45. return;
  46. }