diff options
Diffstat (limited to 'include/asm-ppc/io.h')
-rw-r--r-- | include/asm-ppc/io.h | 60 |
1 files changed, 35 insertions, 25 deletions
diff --git a/include/asm-ppc/io.h b/include/asm-ppc/io.h index 7eb7cf6360bd..84ac6e258eef 100644 --- a/include/asm-ppc/io.h +++ b/include/asm-ppc/io.h | |||
@@ -8,6 +8,7 @@ | |||
8 | 8 | ||
9 | #include <asm/page.h> | 9 | #include <asm/page.h> |
10 | #include <asm/byteorder.h> | 10 | #include <asm/byteorder.h> |
11 | #include <asm/synch.h> | ||
11 | #include <asm/mmu.h> | 12 | #include <asm/mmu.h> |
12 | 13 | ||
13 | #define SIO_CONFIG_RA 0x398 | 14 | #define SIO_CONFIG_RA 0x398 |
@@ -56,7 +57,7 @@ extern unsigned long pci_dram_offset; | |||
56 | * is actually performed (i.e. the data has come back) before we start | 57 | * is actually performed (i.e. the data has come back) before we start |
57 | * executing any following instructions. | 58 | * executing any following instructions. |
58 | */ | 59 | */ |
59 | extern inline int in_8(volatile unsigned char __iomem *addr) | 60 | extern inline int in_8(const volatile unsigned char __iomem *addr) |
60 | { | 61 | { |
61 | int ret; | 62 | int ret; |
62 | 63 | ||
@@ -72,7 +73,7 @@ extern inline void out_8(volatile unsigned char __iomem *addr, int val) | |||
72 | __asm__ __volatile__("stb%U0%X0 %1,%0; eieio" : "=m" (*addr) : "r" (val)); | 73 | __asm__ __volatile__("stb%U0%X0 %1,%0; eieio" : "=m" (*addr) : "r" (val)); |
73 | } | 74 | } |
74 | 75 | ||
75 | extern inline int in_le16(volatile unsigned short __iomem *addr) | 76 | extern inline int in_le16(const volatile unsigned short __iomem *addr) |
76 | { | 77 | { |
77 | int ret; | 78 | int ret; |
78 | 79 | ||
@@ -83,7 +84,7 @@ extern inline int in_le16(volatile unsigned short __iomem *addr) | |||
83 | return ret; | 84 | return ret; |
84 | } | 85 | } |
85 | 86 | ||
86 | extern inline int in_be16(volatile unsigned short __iomem *addr) | 87 | extern inline int in_be16(const volatile unsigned short __iomem *addr) |
87 | { | 88 | { |
88 | int ret; | 89 | int ret; |
89 | 90 | ||
@@ -104,7 +105,7 @@ extern inline void out_be16(volatile unsigned short __iomem *addr, int val) | |||
104 | __asm__ __volatile__("sth%U0%X0 %1,%0; eieio" : "=m" (*addr) : "r" (val)); | 105 | __asm__ __volatile__("sth%U0%X0 %1,%0; eieio" : "=m" (*addr) : "r" (val)); |
105 | } | 106 | } |
106 | 107 | ||
107 | extern inline unsigned in_le32(volatile unsigned __iomem *addr) | 108 | extern inline unsigned in_le32(const volatile unsigned __iomem *addr) |
108 | { | 109 | { |
109 | unsigned ret; | 110 | unsigned ret; |
110 | 111 | ||
@@ -115,7 +116,7 @@ extern inline unsigned in_le32(volatile unsigned __iomem *addr) | |||
115 | return ret; | 116 | return ret; |
116 | } | 117 | } |
117 | 118 | ||
118 | extern inline unsigned in_be32(volatile unsigned __iomem *addr) | 119 | extern inline unsigned in_be32(const volatile unsigned __iomem *addr) |
119 | { | 120 | { |
120 | unsigned ret; | 121 | unsigned ret; |
121 | 122 | ||
@@ -139,7 +140,7 @@ extern inline void out_be32(volatile unsigned __iomem *addr, int val) | |||
139 | #define readb(addr) in_8((volatile u8 *)(addr)) | 140 | #define readb(addr) in_8((volatile u8 *)(addr)) |
140 | #define writeb(b,addr) out_8((volatile u8 *)(addr), (b)) | 141 | #define writeb(b,addr) out_8((volatile u8 *)(addr), (b)) |
141 | #else | 142 | #else |
142 | static inline __u8 readb(volatile void __iomem *addr) | 143 | static inline __u8 readb(const volatile void __iomem *addr) |
143 | { | 144 | { |
144 | return in_8(addr); | 145 | return in_8(addr); |
145 | } | 146 | } |
@@ -150,11 +151,11 @@ static inline void writeb(__u8 b, volatile void __iomem *addr) | |||
150 | #endif | 151 | #endif |
151 | 152 | ||
152 | #if defined(CONFIG_APUS) | 153 | #if defined(CONFIG_APUS) |
153 | static inline __u16 readw(volatile void __iomem *addr) | 154 | static inline __u16 readw(const volatile void __iomem *addr) |
154 | { | 155 | { |
155 | return *(__force volatile __u16 *)(addr); | 156 | return *(__force volatile __u16 *)(addr); |
156 | } | 157 | } |
157 | static inline __u32 readl(volatile void __iomem *addr) | 158 | static inline __u32 readl(const volatile void __iomem *addr) |
158 | { | 159 | { |
159 | return *(__force volatile __u32 *)(addr); | 160 | return *(__force volatile __u32 *)(addr); |
160 | } | 161 | } |
@@ -173,11 +174,11 @@ static inline void writel(__u32 b, volatile void __iomem *addr) | |||
173 | #define writew(b,addr) out_le16((volatile u16 *)(addr),(b)) | 174 | #define writew(b,addr) out_le16((volatile u16 *)(addr),(b)) |
174 | #define writel(b,addr) out_le32((volatile u32 *)(addr),(b)) | 175 | #define writel(b,addr) out_le32((volatile u32 *)(addr),(b)) |
175 | #else | 176 | #else |
176 | static inline __u16 readw(volatile void __iomem *addr) | 177 | static inline __u16 readw(const volatile void __iomem *addr) |
177 | { | 178 | { |
178 | return in_le16(addr); | 179 | return in_le16(addr); |
179 | } | 180 | } |
180 | static inline __u32 readl(volatile void __iomem *addr) | 181 | static inline __u32 readl(const volatile void __iomem *addr) |
181 | { | 182 | { |
182 | return in_le32(addr); | 183 | return in_le32(addr); |
183 | } | 184 | } |
@@ -236,9 +237,9 @@ static inline void __raw_writel(__u32 b, volatile void __iomem *addr) | |||
236 | #define outsl(port, buf, nl) _outsl_ns((port)+___IO_BASE, (buf), (nl)) | 237 | #define outsl(port, buf, nl) _outsl_ns((port)+___IO_BASE, (buf), (nl)) |
237 | 238 | ||
238 | /* | 239 | /* |
239 | * On powermacs, we will get a machine check exception if we | 240 | * On powermacs and 8xx we will get a machine check exception |
240 | * try to read data from a non-existent I/O port. Because the | 241 | * if we try to read data from a non-existent I/O port. Because |
241 | * machine check is an asynchronous exception, it isn't | 242 | * the machine check is an asynchronous exception, it isn't |
242 | * well-defined which instruction SRR0 will point to when the | 243 | * well-defined which instruction SRR0 will point to when the |
243 | * exception occurs. | 244 | * exception occurs. |
244 | * With the sequence below (twi; isync; nop), we have found that | 245 | * With the sequence below (twi; isync; nop), we have found that |
@@ -257,7 +258,7 @@ extern __inline__ unsigned int name(unsigned int port) \ | |||
257 | { \ | 258 | { \ |
258 | unsigned int x; \ | 259 | unsigned int x; \ |
259 | __asm__ __volatile__( \ | 260 | __asm__ __volatile__( \ |
260 | op " %0,0,%1\n" \ | 261 | "0:" op " %0,0,%1\n" \ |
261 | "1: twi 0,%0,0\n" \ | 262 | "1: twi 0,%0,0\n" \ |
262 | "2: isync\n" \ | 263 | "2: isync\n" \ |
263 | "3: nop\n" \ | 264 | "3: nop\n" \ |
@@ -268,6 +269,7 @@ extern __inline__ unsigned int name(unsigned int port) \ | |||
268 | ".previous\n" \ | 269 | ".previous\n" \ |
269 | ".section __ex_table,\"a\"\n" \ | 270 | ".section __ex_table,\"a\"\n" \ |
270 | " .align 2\n" \ | 271 | " .align 2\n" \ |
272 | " .long 0b,5b\n" \ | ||
271 | " .long 1b,5b\n" \ | 273 | " .long 1b,5b\n" \ |
272 | " .long 2b,5b\n" \ | 274 | " .long 2b,5b\n" \ |
273 | " .long 3b,5b\n" \ | 275 | " .long 3b,5b\n" \ |
@@ -281,11 +283,12 @@ extern __inline__ unsigned int name(unsigned int port) \ | |||
281 | extern __inline__ void name(unsigned int val, unsigned int port) \ | 283 | extern __inline__ void name(unsigned int val, unsigned int port) \ |
282 | { \ | 284 | { \ |
283 | __asm__ __volatile__( \ | 285 | __asm__ __volatile__( \ |
284 | op " %0,0,%1\n" \ | 286 | "0:" op " %0,0,%1\n" \ |
285 | "1: sync\n" \ | 287 | "1: sync\n" \ |
286 | "2:\n" \ | 288 | "2:\n" \ |
287 | ".section __ex_table,\"a\"\n" \ | 289 | ".section __ex_table,\"a\"\n" \ |
288 | " .align 2\n" \ | 290 | " .align 2\n" \ |
291 | " .long 0b,2b\n" \ | ||
289 | " .long 1b,2b\n" \ | 292 | " .long 1b,2b\n" \ |
290 | ".previous" \ | 293 | ".previous" \ |
291 | : : "r" (val), "r" (port + ___IO_BASE)); \ | 294 | : : "r" (val), "r" (port + ___IO_BASE)); \ |
@@ -440,16 +443,6 @@ extern inline void * phys_to_virt(unsigned long address) | |||
440 | #define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT) | 443 | #define page_to_phys(page) (page_to_pfn(page) << PAGE_SHIFT) |
441 | #define page_to_bus(page) (page_to_phys(page) + PCI_DRAM_OFFSET) | 444 | #define page_to_bus(page) (page_to_phys(page) + PCI_DRAM_OFFSET) |
442 | 445 | ||
443 | /* | ||
444 | * Enforce In-order Execution of I/O: | ||
445 | * Acts as a barrier to ensure all previous I/O accesses have | ||
446 | * completed before any further ones are issued. | ||
447 | */ | ||
448 | extern inline void eieio(void) | ||
449 | { | ||
450 | __asm__ __volatile__ ("eieio" : : : "memory"); | ||
451 | } | ||
452 | |||
453 | /* Enforce in-order execution of data I/O. | 446 | /* Enforce in-order execution of data I/O. |
454 | * No distinction between read/write on PPC; use eieio for all three. | 447 | * No distinction between read/write on PPC; use eieio for all three. |
455 | */ | 448 | */ |
@@ -552,6 +545,23 @@ extern void pci_iounmap(struct pci_dev *dev, void __iomem *); | |||
552 | #include <asm/mpc8260_pci9.h> | 545 | #include <asm/mpc8260_pci9.h> |
553 | #endif | 546 | #endif |
554 | 547 | ||
548 | #ifdef CONFIG_NOT_COHERENT_CACHE | ||
549 | |||
550 | #define dma_cache_inv(_start,_size) \ | ||
551 | invalidate_dcache_range(_start, (_start + _size)) | ||
552 | #define dma_cache_wback(_start,_size) \ | ||
553 | clean_dcache_range(_start, (_start + _size)) | ||
554 | #define dma_cache_wback_inv(_start,_size) \ | ||
555 | flush_dcache_range(_start, (_start + _size)) | ||
556 | |||
557 | #else | ||
558 | |||
559 | #define dma_cache_inv(_start,_size) do { } while (0) | ||
560 | #define dma_cache_wback(_start,_size) do { } while (0) | ||
561 | #define dma_cache_wback_inv(_start,_size) do { } while (0) | ||
562 | |||
563 | #endif | ||
564 | |||
555 | /* | 565 | /* |
556 | * Convert a physical pointer to a virtual kernel pointer for /dev/mem | 566 | * Convert a physical pointer to a virtual kernel pointer for /dev/mem |
557 | * access | 567 | * access |