Merge to Fedora kernel-2.6.18-1.2224_FC5 patched with stable patch-2.6.18.1-vs2.0...
[linux-2.6.git] / include / asm-arm / arch-l7200 / io.h
1 /*
2  * linux/include/asm-arm/arch-l7200/io.h
3  *
4  * Copyright (C) 2000 Steve Hill (sjhill@cotw.com)
5  *
6  * Changelog:
7  *  03-21-2000  SJH     Created from linux/include/asm-arm/arch-nexuspci/io.h
8  *  08-31-2000  SJH     Added in IO functions necessary for new drivers
9  */
10 #ifndef __ASM_ARM_ARCH_IO_H
11 #define __ASM_ARM_ARCH_IO_H
12
13 #include <asm/hardware.h>
14
15 #define IO_SPACE_LIMIT 0xffffffff
16
17 /*
18  * There are not real ISA nor PCI buses, so we fake it.
19  */
20 #define __io_pci(a)             ((void __iomem *)(PCIO_BASE + (a)))
21 #define __mem_pci(a)            (a)
22
23 #define __ioaddr(p)             __io_pci(p)
24
25 /*
26  * Generic virtual read/write
27  */
28 #define __arch_getb(a)          (*(volatile unsigned char *)(a))
29 #define __arch_getl(a)          (*(volatile unsigned int  *)(a))
30
31 static inline unsigned int __arch_getw(unsigned long a)
32 {
33         unsigned int value;
34         __asm__ __volatile__("ldr%?h    %0, [%1, #0]    @ getw"
35                 : "=&r" (value)
36                 : "r" (a));
37         return value;
38 }
39
40 #define __arch_putb(v,a)        (*(volatile unsigned char *)(a) = (v))
41 #define __arch_putl(v,a)        (*(volatile unsigned int  *)(a) = (v))
42
43 static inline void __arch_putw(unsigned int value, unsigned long a)
44 {
45         __asm__ __volatile__("str%?h    %0, [%1, #0]    @ putw"
46                 : : "r" (value), "r" (a));
47 }
48
49 /*
50  * Translated address IO functions
51  *
52  * IO address has already been translated to a virtual address
53  */
54 #define outb_t(v,p)             (*(volatile unsigned char *)(p) = (v))
55 #define inb_t(p)                (*(volatile unsigned char *)(p))
56 #define outw_t(v,p)             (*(volatile unsigned int *)(p) = (v))
57 #define inw_t(p)                (*(volatile unsigned int *)(p))
58 #define outl_t(v,p)             (*(volatile unsigned long *)(p) = (v))
59 #define inl_t(p)                (*(volatile unsigned long *)(p))
60
61 /*
62  * FIXME - These are to allow for linking. On all the other
63  *         ARM platforms, the entire IO space is contiguous.
64  *         The 7200 has three separate IO spaces. The below
65  *         macros will eventually become more involved. Use
66  *         with caution and don't be surprised by kernel oopses!!!
67  */
68 #define inb(p)                  inb_t(p)
69 #define inw(p)                  inw_t(p)
70 #define inl(p)                  inl_t(p)
71 #define outb(v,p)               outb_t(v,p)
72 #define outw(v,p)               outw_t(v,p)
73 #define outl(v,p)               outl_t(v,p)
74
75 #endif