mmzone_64.h 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /* K8 NUMA support */
  2. /* Copyright 2002,2003 by Andi Kleen, SuSE Labs */
  3. /* 2.5 Version loosely based on the NUMAQ Code by Pat Gaughen. */
  4. #ifndef ASM_X86__MMZONE_64_H
  5. #define ASM_X86__MMZONE_64_H
  6. #ifdef CONFIG_NUMA
  7. #define VIRTUAL_BUG_ON(x)
  8. #include <asm/smp.h>
  9. /* Simple perfect hash to map physical addresses to node numbers */
  10. struct memnode {
  11. int shift;
  12. unsigned int mapsize;
  13. s16 *map;
  14. s16 embedded_map[64 - 8];
  15. } ____cacheline_aligned; /* total size = 128 bytes */
  16. extern struct memnode memnode;
  17. #define memnode_shift memnode.shift
  18. #define memnodemap memnode.map
  19. #define memnodemapsize memnode.mapsize
  20. extern struct pglist_data *node_data[];
  21. static inline __attribute__((pure)) int phys_to_nid(unsigned long addr)
  22. {
  23. unsigned nid;
  24. VIRTUAL_BUG_ON(!memnodemap);
  25. VIRTUAL_BUG_ON((addr >> memnode_shift) >= memnodemapsize);
  26. nid = memnodemap[addr >> memnode_shift];
  27. VIRTUAL_BUG_ON(nid >= MAX_NUMNODES || !node_data[nid]);
  28. return nid;
  29. }
  30. #define NODE_DATA(nid) (node_data[nid])
  31. #define node_start_pfn(nid) (NODE_DATA(nid)->node_start_pfn)
  32. #define node_end_pfn(nid) (NODE_DATA(nid)->node_start_pfn + \
  33. NODE_DATA(nid)->node_spanned_pages)
  34. extern int early_pfn_to_nid(unsigned long pfn);
  35. #ifdef CONFIG_NUMA_EMU
  36. #define FAKE_NODE_MIN_SIZE (64 * 1024 * 1024)
  37. #define FAKE_NODE_MIN_HASH_MASK (~(FAKE_NODE_MIN_SIZE - 1UL))
  38. #endif
  39. #endif
  40. #endif /* ASM_X86__MMZONE_64_H */