cache.c 798 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2017
  4. * Christophe Leroy, CS Systemes d'Information, christophe.leroy@c-s.fr
  5. */
  6. #include <common.h>
  7. #include <asm/processor.h>
  8. #include <asm/ppc.h>
  9. #include <asm/io.h>
  10. #include <asm/mmu.h>
  11. int icache_status(void)
  12. {
  13. return !!(mfspr(IC_CST) & IDC_ENABLED);
  14. }
  15. void icache_enable(void)
  16. {
  17. sync();
  18. mtspr(IC_CST, IDC_INVALL);
  19. mtspr(IC_CST, IDC_ENABLE);
  20. }
  21. void icache_disable(void)
  22. {
  23. sync();
  24. mtspr(IC_CST, IDC_DISABLE);
  25. }
  26. int dcache_status(void)
  27. {
  28. return !!(mfspr(IC_CST) & IDC_ENABLED);
  29. }
  30. void dcache_enable(void)
  31. {
  32. mtspr(MD_CTR, MD_RESETVAL); /* Set cache mode with MMU off */
  33. mtspr(DC_CST, IDC_INVALL);
  34. mtspr(DC_CST, IDC_ENABLE);
  35. }
  36. void dcache_disable(void)
  37. {
  38. sync();
  39. mtspr(DC_CST, IDC_DISABLE);
  40. mtspr(DC_CST, IDC_INVALL);
  41. }