Blame view

arch/xtensa/include/asm/io.h 5.73 KB
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
1
  /*
173d66813   Chris Zankel   [PATCH] xtensa: r...
2
   * include/asm-xtensa/io.h
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
3
4
5
6
7
8
9
10
11
12
13
14
   *
   * This file is subject to the terms and conditions of the GNU General Public
   * License.  See the file "COPYING" in the main directory of this archive
   * for more details.
   *
   * Copyright (C) 2001 - 2005 Tensilica Inc.
   */
  
  #ifndef _XTENSA_IO_H
  #define _XTENSA_IO_H
  
  #ifdef __KERNEL__
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
15
  #include <asm/byteorder.h>
c51aea80a   Adrian Bunk   include/asm-xtens...
16
  #include <asm/page.h>
6656920b0   Chris Zankel   [XTENSA] Add supp...
17
  #include <linux/kernel.h>
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
18
19
  
  #include <linux/types.h>
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
20

00c81d23d   Chris Zankel   xtensa: Fix io re...
21
22
  #define XCHAL_KIO_CACHED_VADDR	0xe0000000
  #define XCHAL_KIO_BYPASS_VADDR	0xf0000000
173d66813   Chris Zankel   [PATCH] xtensa: r...
23
  #define XCHAL_KIO_PADDR		0xf0000000
00c81d23d   Chris Zankel   xtensa: Fix io re...
24
25
26
  #define XCHAL_KIO_SIZE		0x10000000
  
  #define IOADDR(x)		(XCHAL_KIO_BYPASS_VADDR + (x))
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
  
  /*
   * swap functions to change byte order from little-endian to big-endian and
   * vice versa.
   */
  
  static inline unsigned short _swapw (unsigned short v)
  {
  	return (v << 8) | (v >> 8);
  }
  
  static inline unsigned int _swapl (unsigned int v)
  {
  	return (v << 24) | ((v & 0xff00) << 8) | ((v >> 8) & 0xff00) | (v >> 24);
  }
  
  /*
   * Change virtual addresses to physical addresses and vv.
   * These are trivial on the 1:1 Linux/Xtensa mapping
   */
d99cf715a   Adrian Bunk   [PATCH] xtensa: r...
47
  static inline unsigned long virt_to_phys(volatile void * address)
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
48
  {
173d66813   Chris Zankel   [PATCH] xtensa: r...
49
  	return __pa(address);
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
50
  }
d99cf715a   Adrian Bunk   [PATCH] xtensa: r...
51
  static inline void * phys_to_virt(unsigned long address)
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
52
  {
173d66813   Chris Zankel   [PATCH] xtensa: r...
53
  	return __va(address);
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
54
55
56
  }
  
  /*
173d66813   Chris Zankel   [PATCH] xtensa: r...
57
   * virt_to_bus and bus_to_virt are deprecated.
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
58
   */
173d66813   Chris Zankel   [PATCH] xtensa: r...
59
60
  #define virt_to_bus(x)	virt_to_phys(x)
  #define bus_to_virt(x)	phys_to_virt(x)
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
61
62
  
  /*
173d66813   Chris Zankel   [PATCH] xtensa: r...
63
64
   * Return the virtual (cached) address for the specified bus memory.
   * Note that we currently don't support any address outside the KIO segment.
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
65
   */
d99cf715a   Adrian Bunk   [PATCH] xtensa: r...
66
  static inline void *ioremap(unsigned long offset, unsigned long size)
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
67
  {
e5083a63b   Johannes Weiner   xtensa: nommu sup...
68
  #ifdef CONFIG_MMU
173d66813   Chris Zankel   [PATCH] xtensa: r...
69
70
71
  	if (offset >= XCHAL_KIO_PADDR
  	    && offset < XCHAL_KIO_PADDR + XCHAL_KIO_SIZE)
  		return (void*)(offset-XCHAL_KIO_PADDR+XCHAL_KIO_BYPASS_VADDR);
173d66813   Chris Zankel   [PATCH] xtensa: r...
72
73
  	else
  		BUG();
e5083a63b   Johannes Weiner   xtensa: nommu sup...
74
75
76
  #else
  	return (void *)offset;
  #endif
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
77
  }
d99cf715a   Adrian Bunk   [PATCH] xtensa: r...
78
  static inline void *ioremap_nocache(unsigned long offset, unsigned long size)
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
79
  {
e5083a63b   Johannes Weiner   xtensa: nommu sup...
80
  #ifdef CONFIG_MMU
173d66813   Chris Zankel   [PATCH] xtensa: r...
81
82
83
84
85
  	if (offset >= XCHAL_KIO_PADDR
  	    && offset < XCHAL_KIO_PADDR + XCHAL_KIO_SIZE)
  		return (void*)(offset-XCHAL_KIO_PADDR+XCHAL_KIO_CACHED_VADDR);
  	else
  		BUG();
e5083a63b   Johannes Weiner   xtensa: nommu sup...
86
87
88
  #else
  	return (void *)offset;
  #endif
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
89
  }
d99cf715a   Adrian Bunk   [PATCH] xtensa: r...
90
  static inline void iounmap(void *addr)
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
  {
  }
  
  /*
   * Generic I/O
   */
  
  #define readb(addr) \
  	({ unsigned char __v = (*(volatile unsigned char *)(addr)); __v; })
  #define readw(addr) \
  	({ unsigned short __v = (*(volatile unsigned short *)(addr)); __v; })
  #define readl(addr) \
  	({ unsigned int __v = (*(volatile unsigned int *)(addr)); __v; })
  #define writeb(b, addr) (void)((*(volatile unsigned char *)(addr)) = (b))
  #define writew(b, addr) (void)((*(volatile unsigned short *)(addr)) = (b))
  #define writel(b, addr) (void)((*(volatile unsigned int *)(addr)) = (b))
  
  static inline __u8 __raw_readb(const volatile void __iomem *addr)
  {
            return *(__force volatile __u8 *)(addr);
  }
  static inline __u16 __raw_readw(const volatile void __iomem *addr)
  {
            return *(__force volatile __u16 *)(addr);
  }
  static inline __u32 __raw_readl(const volatile void __iomem *addr)
  {
            return *(__force volatile __u32 *)(addr);
  }
  static inline void __raw_writeb(__u8 b, volatile void __iomem *addr)
  {
            *(__force volatile __u8 *)(addr) = b;
  }
  static inline void __raw_writew(__u16 b, volatile void __iomem *addr)
  {
            *(__force volatile __u16 *)(addr) = b;
  }
  static inline void __raw_writel(__u32 b, volatile void __iomem *addr)
  {
            *(__force volatile __u32 *)(addr) = b;
  }
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
132
133
134
135
136
137
  /* These are the definitions for the x86 IO instructions
   * inb/inw/inl/outb/outw/outl, the "string" versions
   * insb/insw/insl/outsb/outsw/outsl, and the "pausing" versions
   * inb_p/inw_p/...
   * The macros don't do byte-swapping.
   */
173d66813   Chris Zankel   [PATCH] xtensa: r...
138
139
140
141
142
  #define inb(port)		readb((u8 *)((port)))
  #define outb(val, port)		writeb((val),(u8 *)((unsigned long)(port)))
  #define inw(port)		readw((u16 *)((port)))
  #define outw(val, port)		writew((val),(u16 *)((unsigned long)(port)))
  #define inl(port)		readl((u32 *)((port)))
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
  #define outl(val, port)		writel((val),(u32 *)((unsigned long)(port)))
  
  #define inb_p(port)		inb((port))
  #define outb_p(val, port)	outb((val), (port))
  #define inw_p(port)		inw((port))
  #define outw_p(val, port)	outw((val), (port))
  #define inl_p(port)		inl((port))
  #define outl_p(val, port)	outl((val), (port))
  
  extern void insb (unsigned long port, void *dst, unsigned long count);
  extern void insw (unsigned long port, void *dst, unsigned long count);
  extern void insl (unsigned long port, void *dst, unsigned long count);
  extern void outsb (unsigned long port, const void *src, unsigned long count);
  extern void outsw (unsigned long port, const void *src, unsigned long count);
  extern void outsl (unsigned long port, const void *src, unsigned long count);
  
  #define IO_SPACE_LIMIT ~0
  
  #define memset_io(a,b,c)       memset((void *)(a),(b),(c))
  #define memcpy_fromio(a,b,c)   memcpy((a),(void *)(b),(c))
  #define memcpy_toio(a,b,c)      memcpy((void *)(a),(b),(c))
  
  /* At this point the Xtensa doesn't provide byte swap instructions */
  
  #ifdef __XTENSA_EB__
  # define in_8(addr) (*(u8*)(addr))
  # define in_le16(addr) _swapw(*(u16*)(addr))
  # define in_le32(addr) _swapl(*(u32*)(addr))
  # define out_8(b, addr) *(u8*)(addr) = (b)
  # define out_le16(b, addr) *(u16*)(addr) = _swapw(b)
  # define out_le32(b, addr) *(u32*)(addr) = _swapl(b)
  #elif defined(__XTENSA_EL__)
  # define in_8(addr)  (*(u8*)(addr))
  # define in_le16(addr) (*(u16*)(addr))
  # define in_le32(addr) (*(u32*)(addr))
  # define out_8(b, addr) *(u8*)(addr) = (b)
  # define out_le16(b, addr) *(u16*)(addr) = (b)
  # define out_le32(b, addr) *(u32*)(addr) = (b)
  #else
  # error processor byte order undefined!
  #endif
  
  
  /*
173d66813   Chris Zankel   [PATCH] xtensa: r...
187
188
   * Convert a physical pointer to a virtual kernel pointer for /dev/mem access
   */
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
189
190
191
  #define xlate_dev_mem_ptr(p)    __va(p)
  
  /*
173d66813   Chris Zankel   [PATCH] xtensa: r...
192
193
   * Convert a virtual cached pointer to an uncached pointer
   */
9a8fd5589   Chris Zankel   [PATCH] xtensa: A...
194
195
196
197
198
199
  #define xlate_dev_kmem_ptr(p)   p
  
  
  #endif	/* __KERNEL__ */
  
  #endif	/* _XTENSA_IO_H */