cache.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2016 Vladimir Zapolskiy <vz@mleia.com>
  4. * (C) Copyright 2007 Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
  5. */
  6. #include <common.h>
  7. #include <command.h>
  8. #include <asm/io.h>
  9. #include <asm/processor.h>
  10. #include <asm/system.h>
  11. #define CACHE_VALID 1
  12. #define CACHE_UPDATED 2
  13. static inline void cache_wback_all(void)
  14. {
  15. unsigned long addr, data, i, j;
  16. for (i = 0; i < CACHE_OC_NUM_ENTRIES; i++) {
  17. for (j = 0; j < CACHE_OC_NUM_WAYS; j++) {
  18. addr = CACHE_OC_ADDRESS_ARRAY
  19. | (j << CACHE_OC_WAY_SHIFT)
  20. | (i << CACHE_OC_ENTRY_SHIFT);
  21. data = inl(addr);
  22. if (data & CACHE_UPDATED) {
  23. data &= ~CACHE_UPDATED;
  24. outl(data, addr);
  25. }
  26. }
  27. }
  28. }
  29. #define CACHE_ENABLE 0
  30. #define CACHE_DISABLE 1
  31. static int cache_control(unsigned int cmd)
  32. {
  33. unsigned long ccr;
  34. jump_to_P2();
  35. ccr = inl(CCR);
  36. if (ccr & CCR_CACHE_ENABLE)
  37. cache_wback_all();
  38. if (cmd == CACHE_DISABLE)
  39. outl(CCR_CACHE_STOP, CCR);
  40. else
  41. outl(CCR_CACHE_INIT, CCR);
  42. back_to_P1();
  43. return 0;
  44. }
  45. void flush_dcache_range(unsigned long start, unsigned long end)
  46. {
  47. u32 v;
  48. start &= ~(L1_CACHE_BYTES - 1);
  49. for (v = start; v < end; v += L1_CACHE_BYTES) {
  50. asm volatile ("ocbp %0" : /* no output */
  51. : "m" (__m(v)));
  52. }
  53. }
  54. void invalidate_dcache_range(unsigned long start, unsigned long end)
  55. {
  56. u32 v;
  57. start &= ~(L1_CACHE_BYTES - 1);
  58. for (v = start; v < end; v += L1_CACHE_BYTES) {
  59. asm volatile ("ocbi %0" : /* no output */
  60. : "m" (__m(v)));
  61. }
  62. }
  63. void flush_cache(unsigned long addr, unsigned long size)
  64. {
  65. flush_dcache_range(addr , addr + size);
  66. }
  67. void icache_enable(void)
  68. {
  69. cache_control(CACHE_ENABLE);
  70. }
  71. void icache_disable(void)
  72. {
  73. cache_control(CACHE_DISABLE);
  74. }
  75. int icache_status(void)
  76. {
  77. return 0;
  78. }
  79. void dcache_enable(void)
  80. {
  81. }
  82. void dcache_disable(void)
  83. {
  84. }
  85. int dcache_status(void)
  86. {
  87. return 0;
  88. }