blob: f7e1b9bce345688419167f5ff6d6e0e3c00cc2f9 [file] [log] [blame]
Russell Kinga09e64f2008-08-05 16:14:15 +01001/*
2 * arch/arm/mach-ks8695/include/mach/memory.h
3 *
4 * Copyright (C) 2006 Andrew Victor
5 *
6 * KS8695 Memory definitions
7 *
8 * This file is licensed under the terms of the GNU General Public
9 * License version 2. This program is licensed "as is" without any
10 * warranty of any kind, whether express or implied.
11 */
12
13#ifndef __ASM_ARCH_MEMORY_H
14#define __ASM_ARCH_MEMORY_H
15
16#include <mach/hardware.h>
17
18/*
19 * Physical SRAM offset.
20 */
Russell Kingf4117ac2011-01-04 18:07:14 +000021#define PLAT_PHYS_OFFSET KS8695_SDRAM_PA
Russell Kinga09e64f2008-08-05 16:14:15 +010022
23#ifndef __ASSEMBLY__
24
25#ifdef CONFIG_PCI
26
27/* PCI mappings */
28#define __virt_to_bus(x) ((x) - PAGE_OFFSET + KS8695_PCIMEM_PA)
29#define __bus_to_virt(x) ((x) - KS8695_PCIMEM_PA + PAGE_OFFSET)
30
31/* Platform-bus mapping */
32extern struct bus_type platform_bus_type;
33#define is_lbus_device(dev) (dev && dev->bus == &platform_bus_type)
Andrew Victor8e6c81f2008-10-07 20:44:07 +010034#define __arch_dma_to_virt(dev, x) ({ (void *) (is_lbus_device(dev) ? \
35 __phys_to_virt(x) : __bus_to_virt(x)); })
Russell Kinga09e64f2008-08-05 16:14:15 +010036#define __arch_virt_to_dma(dev, x) ({ is_lbus_device(dev) ? \
37 (dma_addr_t)__virt_to_phys(x) : (dma_addr_t)__virt_to_bus(x); })
Russell King9eedd962011-01-03 00:00:17 +000038#define __arch_pfn_to_dma(dev, pfn) \
39 ({ dma_addr_t __dma = __pfn_to_phys(pfn); \
Nicolas Pitre58edb512008-09-09 15:54:13 -040040 if (!is_lbus_device(dev)) \
41 __dma = __dma - PHYS_OFFSET + KS8695_PCIMEM_PA; \
42 __dma; })
Russell Kinga09e64f2008-08-05 16:14:15 +010043
Russell King9eedd962011-01-03 00:00:17 +000044#define __arch_dma_to_pfn(dev, x) \
Russell Kingef1baed2009-10-31 16:07:16 +000045 ({ dma_addr_t __dma = x; \
46 if (!is_lbus_device(dev)) \
47 __dma += PHYS_OFFSET - KS8695_PCIMEM_PA; \
Russell King9eedd962011-01-03 00:00:17 +000048 __phys_to_pfn(__dma); \
Russell Kingef1baed2009-10-31 16:07:16 +000049 })
50
Russell Kinga09e64f2008-08-05 16:14:15 +010051#endif
52
53#endif
54
55#endif