mmzone.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /*
  2. * Written by Pat Gaughen (gone@us.ibm.com) Mar 2002
  3. *
  4. */
  5. #ifndef _ASM_MMZONE_H_
  6. #define _ASM_MMZONE_H_
  7. #include <asm/smp.h>
  8. #ifdef CONFIG_DISCONTIGMEM
  9. extern struct pglist_data *node_data[];
  10. #define NODE_DATA(nid) (node_data[nid])
  11. #define node_localnr(pfn, nid) ((pfn) - NODE_DATA(nid)->node_start_pfn)
  12. #define node_mem_map(nid) (NODE_DATA(nid)->node_mem_map)
  13. #define node_start_pfn(nid) (NODE_DATA(nid)->node_start_pfn)
  14. #define node_end_pfn(nid) \
  15. ({ \
  16. pg_data_t *__pgdat = NODE_DATA(nid); \
  17. __pgdat->node_start_pfn + __pgdat->node_spanned_pages - 1; \
  18. })
  19. #define local_mapnr(kvaddr) \
  20. ({ \
  21. unsigned long __pfn = __pa(kvaddr) >> PAGE_SHIFT; \
  22. (__pfn - node_start_pfn(pfn_to_nid(__pfn))); \
  23. })
  24. #define pfn_to_page(pfn) \
  25. ({ \
  26. unsigned long __pfn = pfn; \
  27. int __node = pfn_to_nid(__pfn); \
  28. &node_mem_map(__node)[node_localnr(__pfn,__node)]; \
  29. })
  30. #define page_to_pfn(pg) \
  31. ({ \
  32. struct page *__page = pg; \
  33. struct zone *__zone = page_zone(__page); \
  34. (unsigned long)(__page - __zone->zone_mem_map) \
  35. + __zone->zone_start_pfn; \
  36. })
  37. #define pmd_page(pmd) (pfn_to_page(pmd_val(pmd) >> PAGE_SHIFT))
  38. /*
  39. * pfn_valid should be made as fast as possible, and the current definition
  40. * is valid for machines that are NUMA, but still contiguous, which is what
  41. * is currently supported. A more generalised, but slower definition would
  42. * be something like this - mbligh:
  43. * ( pfn_to_pgdat(pfn) && ((pfn) < node_end_pfn(pfn_to_nid(pfn))) )
  44. */
  45. #if 1 /* M32R_FIXME */
  46. #define pfn_valid(pfn) (1)
  47. #else
  48. #define pfn_valid(pfn) ((pfn) < num_physpages)
  49. #endif
  50. /*
  51. * generic node memory support, the following assumptions apply:
  52. */
  53. static __inline__ int pfn_to_nid(unsigned long pfn)
  54. {
  55. int node;
  56. for (node = 0 ; node < MAX_NUMNODES ; node++)
  57. if (pfn >= node_start_pfn(node) && pfn <= node_end_pfn(node))
  58. break;
  59. return node;
  60. }
  61. static __inline__ struct pglist_data *pfn_to_pgdat(unsigned long pfn)
  62. {
  63. return(NODE_DATA(pfn_to_nid(pfn)));
  64. }
  65. #endif /* CONFIG_DISCONTIGMEM */
  66. #endif /* _ASM_MMZONE_H_ */