tlb_64.h 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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. /* arch/sh64/mm/tlb.c */
  53. int sh64_tlb_init(void);
  54. unsigned long long sh64_next_free_dtlb_entry(void);
  55. unsigned long long sh64_get_wired_dtlb_entry(void);
  56. int sh64_put_wired_dtlb_entry(unsigned long long entry);
  57. void sh64_setup_tlb_slot(unsigned long long config_addr, unsigned long eaddr,
  58. unsigned long asid, unsigned long paddr);
  59. void sh64_teardown_tlb_slot(unsigned long long config_addr);
  60. #endif /* __ASSEMBLY__ */
  61. #endif /* __ASM_SH_TLB_64_H */