mmzone.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /*
  2. * linux/include/asm-sh/mmzone.h
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. */
  8. #ifndef __ASM_SH_MMZONE_H
  9. #define __ASM_SH_MMZONE_H
  10. #include <linux/config.h>
  11. #ifdef CONFIG_DISCONTIGMEM
  12. /* Currently, just for HP690 */
  13. #define PHYSADDR_TO_NID(phys) ((((phys) - __MEMORY_START) >= 0x01000000)?1:0)
  14. extern pg_data_t discontig_page_data[MAX_NUMNODES];
  15. extern bootmem_data_t discontig_node_bdata[MAX_NUMNODES];
  16. /*
  17. * Following are macros that each numa implmentation must define.
  18. */
  19. /*
  20. * Given a kernel address, find the home node of the underlying memory.
  21. */
  22. #define KVADDR_TO_NID(kaddr) PHYSADDR_TO_NID(__pa(kaddr))
  23. /*
  24. * Return a pointer to the node data for node n.
  25. */
  26. #define NODE_DATA(nid) (&discontig_page_data[nid])
  27. /*
  28. * NODE_MEM_MAP gives the kaddr for the mem_map of the node.
  29. */
  30. #define NODE_MEM_MAP(nid) (NODE_DATA(nid)->node_mem_map)
  31. #define phys_to_page(phys) \
  32. ({ unsigned int node = PHYSADDR_TO_NID(phys); \
  33. NODE_MEM_MAP(node) \
  34. + (((phys) - NODE_DATA(node)->node_start_paddr) >> PAGE_SHIFT); })
  35. static inline int is_valid_page(struct page *page)
  36. {
  37. unsigned int i;
  38. for (i = 0; i < MAX_NUMNODES; i++) {
  39. if (page >= NODE_MEM_MAP(i) &&
  40. page < NODE_MEM_MAP(i) + NODE_DATA(i)->node_size)
  41. return 1;
  42. }
  43. return 0;
  44. }
  45. #define VALID_PAGE(page) is_valid_page(page)
  46. #define page_to_phys(page) PHYSADDR(page_address(page))
  47. #endif /* CONFIG_DISCONTIGMEM */
  48. #endif