tlb_64.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * include/asm-sh/tlb_64.h
  3. *
  4. * Copyright (C) 2003 Paul Mundt
  5. *
  6. * This file is subject to the terms and conditions of the GNU General Public
  7. * License. See the file "COPYING" in the main directory of this archive
  8. * for more details.
  9. */
  10. #ifndef __ASM_SH_TLB_64_H
  11. #define __ASM_SH_TLB_64_H
  12. /* ITLB defines */
  13. #define ITLB_FIXED 0x00000000 /* First fixed ITLB, see head.S */
  14. #define ITLB_LAST_VAR_UNRESTRICTED 0x000003F0 /* Last ITLB */
  15. /* DTLB defines */
  16. #define DTLB_FIXED 0x00800000 /* First fixed DTLB, see head.S */
  17. #define DTLB_LAST_VAR_UNRESTRICTED 0x008003F0 /* Last DTLB */
  18. #ifndef __ASSEMBLY__
  19. /**
  20. * for_each_dtlb_entry
  21. *
  22. * @tlb: TLB entry
  23. *
  24. * Iterate over free (non-wired) DTLB entries
  25. */
  26. #define for_each_dtlb_entry(tlb) \
  27. for (tlb = cpu_data->dtlb.first; \
  28. tlb <= cpu_data->dtlb.last; \
  29. tlb += cpu_data->dtlb.step)
  30. /**
  31. * for_each_itlb_entry
  32. *
  33. * @tlb: TLB entry
  34. *
  35. * Iterate over free (non-wired) ITLB entries
  36. */
  37. #define for_each_itlb_entry(tlb) \
  38. for (tlb = cpu_data->itlb.first; \
  39. tlb <= cpu_data->itlb.last; \
  40. tlb += cpu_data->itlb.step)
  41. /**
  42. * __flush_tlb_slot
  43. *
  44. * @slot: Address of TLB slot.
  45. *
  46. * Flushes TLB slot @slot.
  47. */
  48. static inline void __flush_tlb_slot(unsigned long long slot)
  49. {
  50. __asm__ __volatile__ ("putcfg %0, 0, r63\n" : : "r" (slot));
  51. }
  52. #ifdef CONFIG_MMU
  53. /* arch/sh64/mm/tlb.c */
  54. int sh64_tlb_init(void);
  55. unsigned long long sh64_next_free_dtlb_entry(void);
  56. unsigned long long sh64_get_wired_dtlb_entry(void);
  57. int sh64_put_wired_dtlb_entry(unsigned long long entry);
  58. void sh64_setup_tlb_slot(unsigned long long config_addr, unsigned long eaddr,
  59. unsigned long asid, unsigned long paddr);
  60. void sh64_teardown_tlb_slot(unsigned long long config_addr);
  61. #else
  62. #define sh64_tlb_init() do { } while (0)
  63. #define sh64_next_free_dtlb_entry() (0)
  64. #define sh64_get_wired_dtlb_entry() (0)
  65. #define sh64_put_wired_dtlb_entry(entry) do { } while (0)
  66. #define sh64_setup_tlb_slot(conf, virt, asid, phys) do { } while (0)
  67. #define sh64_teardown_tlb_slot(addr) do { } while (0)
  68. #endif /* CONFIG_MMU */
  69. #endif /* __ASSEMBLY__ */
  70. #endif /* __ASM_SH_TLB_64_H */