diff options
| author | David Howells <dhowells@redhat.com> | 2006-01-08 04:01:20 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-01-08 23:13:36 -0500 |
| commit | a90a72c85fb202d0b172da27d8df2579b6591783 (patch) | |
| tree | 6876226fe257b0f191031492d83714f000a78d25 /include/asm-frv | |
| parent | 018b8d12bc85f8fb332239b11d919ea0724c49a4 (diff) | |
[PATCH] frv: supply various missing I/O access primitives
Supply various I/O access primitives that are missing for the FRV arch:
(*) mmiowb()
(*) read*_relaxed()
(*) ioport_*map()
(*) ioread*(), iowrite*(), ioread*_rep() and iowrite*_rep()
(*) pci_io*map()
(*) check_signature()
The patch also makes __is_PCI_addr() more efficient.
Signed-off-by: David Howells <dhowells@redhat.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'include/asm-frv')
| -rw-r--r-- | include/asm-frv/io.h | 123 | ||||
| -rw-r--r-- | include/asm-frv/mb-regs.h | 4 |
2 files changed, 127 insertions, 0 deletions
diff --git a/include/asm-frv/io.h b/include/asm-frv/io.h index 48829f727242..075369b1a34b 100644 --- a/include/asm-frv/io.h +++ b/include/asm-frv/io.h | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | #ifdef __KERNEL__ | 18 | #ifdef __KERNEL__ |
| 19 | 19 | ||
| 20 | #include <linux/config.h> | 20 | #include <linux/config.h> |
| 21 | #include <linux/types.h> | ||
| 21 | #include <asm/virtconvert.h> | 22 | #include <asm/virtconvert.h> |
| 22 | #include <asm/string.h> | 23 | #include <asm/string.h> |
| 23 | #include <asm/mb-regs.h> | 24 | #include <asm/mb-regs.h> |
| @@ -104,6 +105,8 @@ static inline void __insl(unsigned long addr, void *buf, int len, int swap) | |||
| 104 | __insl_sw(addr, buf, len); | 105 | __insl_sw(addr, buf, len); |
| 105 | } | 106 | } |
| 106 | 107 | ||
| 108 | #define mmiowb() mb() | ||
| 109 | |||
| 107 | /* | 110 | /* |
| 108 | * make the short names macros so specific devices | 111 | * make the short names macros so specific devices |
| 109 | * can override them as required | 112 | * can override them as required |
| @@ -209,6 +212,10 @@ static inline uint32_t readl(const volatile void __iomem *addr) | |||
| 209 | return ret; | 212 | return ret; |
| 210 | } | 213 | } |
| 211 | 214 | ||
| 215 | #define readb_relaxed readb | ||
| 216 | #define readw_relaxed readw | ||
| 217 | #define readl_relaxed readl | ||
| 218 | |||
| 212 | static inline void writeb(uint8_t datum, volatile void __iomem *addr) | 219 | static inline void writeb(uint8_t datum, volatile void __iomem *addr) |
| 213 | { | 220 | { |
| 214 | __builtin_write8((volatile uint8_t __force *) addr, datum); | 221 | __builtin_write8((volatile uint8_t __force *) addr, datum); |
| @@ -268,11 +275,106 @@ static inline void __iomem *ioremap_fullcache(unsigned long physaddr, unsigned l | |||
| 268 | 275 | ||
| 269 | extern void iounmap(void __iomem *addr); | 276 | extern void iounmap(void __iomem *addr); |
| 270 | 277 | ||
| 278 | static inline void __iomem *ioport_map(unsigned long port, unsigned int nr) | ||
| 279 | { | ||
| 280 | return (void __iomem *) port; | ||
| 281 | } | ||
| 282 | |||
| 283 | static inline void ioport_unmap(void __iomem *p) | ||
| 284 | { | ||
| 285 | } | ||
| 286 | |||
| 271 | static inline void flush_write_buffers(void) | 287 | static inline void flush_write_buffers(void) |
| 272 | { | 288 | { |
| 273 | __asm__ __volatile__ ("membar" : : :"memory"); | 289 | __asm__ __volatile__ ("membar" : : :"memory"); |
| 274 | } | 290 | } |
| 275 | 291 | ||
| 292 | /* | ||
| 293 | * do appropriate I/O accesses for token type | ||
| 294 | */ | ||
| 295 | static inline unsigned int ioread8(void __iomem *p) | ||
| 296 | { | ||
| 297 | return __builtin_read8(p); | ||
| 298 | } | ||
| 299 | |||
| 300 | static inline unsigned int ioread16(void __iomem *p) | ||
| 301 | { | ||
| 302 | uint16_t ret = __builtin_read16(p); | ||
| 303 | if (__is_PCI_addr(p)) | ||
| 304 | ret = _swapw(ret); | ||
| 305 | return ret; | ||
| 306 | } | ||
| 307 | |||
| 308 | static inline unsigned int ioread32(void __iomem *p) | ||
| 309 | { | ||
| 310 | uint32_t ret = __builtin_read32(p); | ||
| 311 | if (__is_PCI_addr(p)) | ||
| 312 | ret = _swapl(ret); | ||
| 313 | return ret; | ||
| 314 | } | ||
| 315 | |||
| 316 | static inline void iowrite8(u8 val, void __iomem *p) | ||
| 317 | { | ||
| 318 | __builtin_write8(p, val); | ||
| 319 | if (__is_PCI_MEM(p)) | ||
| 320 | __flush_PCI_writes(); | ||
| 321 | } | ||
| 322 | |||
| 323 | static inline void iowrite16(u16 val, void __iomem *p) | ||
| 324 | { | ||
| 325 | if (__is_PCI_addr(p)) | ||
| 326 | val = _swapw(val); | ||
| 327 | __builtin_write16(p, val); | ||
| 328 | if (__is_PCI_MEM(p)) | ||
| 329 | __flush_PCI_writes(); | ||
| 330 | } | ||
| 331 | |||
| 332 | static inline void iowrite32(u32 val, void __iomem *p) | ||
| 333 | { | ||
| 334 | if (__is_PCI_addr(p)) | ||
| 335 | val = _swapl(val); | ||
| 336 | __builtin_write32(p, val); | ||
| 337 | if (__is_PCI_MEM(p)) | ||
| 338 | __flush_PCI_writes(); | ||
| 339 | } | ||
| 340 | |||
| 341 | static inline void ioread8_rep(void __iomem *p, void *dst, unsigned long count) | ||
| 342 | { | ||
| 343 | io_insb((unsigned long) p, dst, count); | ||
| 344 | } | ||
| 345 | |||
| 346 | static inline void ioread16_rep(void __iomem *p, void *dst, unsigned long count) | ||
| 347 | { | ||
| 348 | io_insw((unsigned long) p, dst, count); | ||
| 349 | } | ||
| 350 | |||
| 351 | static inline void ioread32_rep(void __iomem *p, void *dst, unsigned long count) | ||
| 352 | { | ||
| 353 | __insl_ns((unsigned long) p, dst, count); | ||
| 354 | } | ||
| 355 | |||
| 356 | static inline void iowrite8_rep(void __iomem *p, const void *src, unsigned long count) | ||
| 357 | { | ||
| 358 | io_outsb((unsigned long) p, src, count); | ||
| 359 | } | ||
| 360 | |||
| 361 | static inline void iowrite16_rep(void __iomem *p, const void *src, unsigned long count) | ||
| 362 | { | ||
| 363 | io_outsw((unsigned long) p, src, count); | ||
| 364 | } | ||
| 365 | |||
| 366 | static inline void iowrite32_rep(void __iomem *p, const void *src, unsigned long count) | ||
| 367 | { | ||
| 368 | __outsl_ns((unsigned long) p, src, count); | ||
| 369 | } | ||
| 370 | |||
| 371 | /* Create a virtual mapping cookie for a PCI BAR (memory or IO) */ | ||
| 372 | struct pci_dev; | ||
| 373 | extern void __iomem *pci_iomap(struct pci_dev *dev, int bar, unsigned long max); | ||
| 374 | static inline void pci_iounmap(struct pci_dev *dev, void __iomem *p) | ||
| 375 | { | ||
| 376 | } | ||
| 377 | |||
| 276 | 378 | ||
| 277 | /* | 379 | /* |
| 278 | * Convert a physical pointer to a virtual kernel pointer for /dev/mem | 380 | * Convert a physical pointer to a virtual kernel pointer for /dev/mem |
| @@ -285,6 +387,27 @@ static inline void flush_write_buffers(void) | |||
| 285 | */ | 387 | */ |
| 286 | #define xlate_dev_kmem_ptr(p) p | 388 | #define xlate_dev_kmem_ptr(p) p |
| 287 | 389 | ||
| 390 | /* | ||
| 391 | * Check BIOS signature | ||
| 392 | */ | ||
| 393 | static inline int check_signature(volatile void __iomem *io_addr, | ||
| 394 | const unsigned char *signature, int length) | ||
| 395 | { | ||
| 396 | int retval = 0; | ||
| 397 | |||
| 398 | do { | ||
| 399 | if (readb(io_addr) != *signature) | ||
| 400 | goto out; | ||
| 401 | io_addr++; | ||
| 402 | signature++; | ||
| 403 | length--; | ||
| 404 | } while (length); | ||
| 405 | |||
| 406 | retval = 1; | ||
| 407 | out: | ||
| 408 | return retval; | ||
| 409 | } | ||
| 410 | |||
| 288 | #endif /* __KERNEL__ */ | 411 | #endif /* __KERNEL__ */ |
| 289 | 412 | ||
| 290 | #endif /* _ASM_IO_H */ | 413 | #endif /* _ASM_IO_H */ |
diff --git a/include/asm-frv/mb-regs.h b/include/asm-frv/mb-regs.h index c8f575fc42fa..93fa732fb0cd 100644 --- a/include/asm-frv/mb-regs.h +++ b/include/asm-frv/mb-regs.h | |||
| @@ -68,6 +68,9 @@ do { \ | |||
| 68 | #define __is_PCI_MEM(addr) \ | 68 | #define __is_PCI_MEM(addr) \ |
| 69 | ((unsigned long)(addr) - __region_PCI_MEM < 0x08000000UL) | 69 | ((unsigned long)(addr) - __region_PCI_MEM < 0x08000000UL) |
| 70 | 70 | ||
| 71 | #define __is_PCI_addr(addr) \ | ||
| 72 | ((unsigned long)(addr) - __region_PCI_IO < 0x0c000000UL) | ||
| 73 | |||
| 71 | #define __get_CLKSW() ({ *(volatile unsigned long *)(__region_CS2 + 0x0130000cUL) & 0xffUL; }) | 74 | #define __get_CLKSW() ({ *(volatile unsigned long *)(__region_CS2 + 0x0130000cUL) & 0xffUL; }) |
| 72 | #define __get_CLKIN() (__get_CLKSW() * 125U * 100000U / 24U) | 75 | #define __get_CLKIN() (__get_CLKSW() * 125U * 100000U / 24U) |
| 73 | 76 | ||
| @@ -149,6 +152,7 @@ do { \ | |||
| 149 | 152 | ||
| 150 | #define __is_PCI_IO(addr) 0 /* no PCI */ | 153 | #define __is_PCI_IO(addr) 0 /* no PCI */ |
| 151 | #define __is_PCI_MEM(addr) 0 | 154 | #define __is_PCI_MEM(addr) 0 |
| 155 | #define __is_PCI_addr(addr) 0 | ||
| 152 | #define __region_PCI_IO 0 | 156 | #define __region_PCI_IO 0 |
| 153 | #define __region_PCI_MEM 0 | 157 | #define __region_PCI_MEM 0 |
| 154 | #define __flush_PCI_writes() do { } while(0) | 158 | #define __flush_PCI_writes() do { } while(0) |
