memory.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * arch/arm/mach-pxa/include/mach/memory.h
  3. *
  4. * Author: Nicolas Pitre
  5. * Copyright: (C) 2001 MontaVista Software Inc.
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License version 2 as
  9. * published by the Free Software Foundation.
  10. */
  11. #ifndef __ASM_ARCH_MEMORY_H
  12. #define __ASM_ARCH_MEMORY_H
  13. /*
  14. * Physical DRAM offset.
  15. */
  16. #define PHYS_OFFSET UL(0xa0000000)
  17. /*
  18. * Virtual view <-> DMA view memory address translations
  19. * virt_to_bus: Used to translate the virtual address to an
  20. * address suitable to be passed to set_dma_addr
  21. * bus_to_virt: Used to convert an address for DMA operations
  22. * to an address that the kernel can use.
  23. */
  24. #define __virt_to_bus(x) __virt_to_phys(x)
  25. #define __bus_to_virt(x) __phys_to_virt(x)
  26. /*
  27. * The nodes are matched with the physical SDRAM banks as follows:
  28. *
  29. * node 0: 0xa0000000-0xa3ffffff --> 0xc0000000-0xc3ffffff
  30. * node 1: 0xa4000000-0xa7ffffff --> 0xc4000000-0xc7ffffff
  31. * node 2: 0xa8000000-0xabffffff --> 0xc8000000-0xcbffffff
  32. * node 3: 0xac000000-0xafffffff --> 0xcc000000-0xcfffffff
  33. *
  34. * This needs a node mem size of 26 bits.
  35. */
  36. #define NODE_MEM_SIZE_BITS 26
  37. #if !defined(__ASSEMBLY__) && defined(CONFIG_MACH_ARMCORE) && defined(CONFIG_PCI)
  38. void cmx2xx_pci_adjust_zones(int node, unsigned long *size,
  39. unsigned long *holes);
  40. #define arch_adjust_zones(node, size, holes) \
  41. cmx2xx_pci_adjust_zones(node, size, holes)
  42. #define ISA_DMA_THRESHOLD (PHYS_OFFSET + SZ_64M - 1)
  43. #endif
  44. #endif