init_64.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. #ifndef _SPARC64_MM_INIT_H
  2. #define _SPARC64_MM_INIT_H
  3. #include <asm/page.h>
  4. /* Most of the symbols in this file are defined in init.c and
  5. * marked non-static so that assembler code can get at them.
  6. */
  7. #define MAX_PHYS_ADDRESS (1UL << MAX_PHYS_ADDRESS_BITS)
  8. #define KPTE_BITMAP_CHUNK_SZ (256UL * 1024UL * 1024UL)
  9. #define KPTE_BITMAP_BYTES \
  10. ((MAX_PHYS_ADDRESS / KPTE_BITMAP_CHUNK_SZ) / 4)
  11. #define VALID_ADDR_BITMAP_CHUNK_SZ (4UL * 1024UL * 1024UL)
  12. #define VALID_ADDR_BITMAP_BYTES \
  13. ((MAX_PHYS_ADDRESS / VALID_ADDR_BITMAP_CHUNK_SZ) / 8)
  14. extern unsigned long kern_linear_pte_xor[4];
  15. extern unsigned long kpte_linear_bitmap[KPTE_BITMAP_BYTES / sizeof(unsigned long)];
  16. extern unsigned int sparc64_highest_unlocked_tlb_ent;
  17. extern unsigned long sparc64_kern_pri_context;
  18. extern unsigned long sparc64_kern_pri_nuc_bits;
  19. extern unsigned long sparc64_kern_sec_context;
  20. extern void mmu_info(struct seq_file *m);
  21. struct linux_prom_translation {
  22. unsigned long virt;
  23. unsigned long size;
  24. unsigned long data;
  25. };
  26. /* Exported for kernel TLB miss handling in ktlb.S */
  27. extern struct linux_prom_translation prom_trans[512];
  28. extern unsigned int prom_trans_ents;
  29. /* Exported for SMP bootup purposes. */
  30. extern unsigned long kern_locked_tte_data;
  31. extern void prom_world(int enter);
  32. #ifdef CONFIG_SPARSEMEM_VMEMMAP
  33. #define VMEMMAP_CHUNK_SHIFT 22
  34. #define VMEMMAP_CHUNK (1UL << VMEMMAP_CHUNK_SHIFT)
  35. #define VMEMMAP_CHUNK_MASK ~(VMEMMAP_CHUNK - 1UL)
  36. #define VMEMMAP_ALIGN(x) (((x)+VMEMMAP_CHUNK-1UL)&VMEMMAP_CHUNK_MASK)
  37. #define VMEMMAP_SIZE ((((1UL << MAX_PHYSADDR_BITS) >> PAGE_SHIFT) * \
  38. sizeof(struct page)) >> VMEMMAP_CHUNK_SHIFT)
  39. extern unsigned long vmemmap_table[VMEMMAP_SIZE];
  40. #endif
  41. #endif /* _SPARC64_MM_INIT_H */