1 #ifndef __ASM_AVR32_IO_H
 
   2 #define __ASM_AVR32_IO_H
 
   4 #include <linux/kernel.h>
 
   5 #include <linux/string.h>
 
   6 #include <linux/types.h>
 
   8 #include <asm/addrspace.h>
 
   9 #include <asm/byteorder.h>
 
  11 #include <asm/arch/io.h>
 
  13 /* virt_to_phys will only work when address is in P1 or P2 */
 
  14 static __inline__ unsigned long virt_to_phys(volatile void *address)
 
  16         return PHYSADDR(address);
 
  19 static __inline__ void * phys_to_virt(unsigned long address)
 
  21         return (void *)P1SEGADDR(address);
 
  24 #define cached_to_phys(addr)    ((unsigned long)PHYSADDR(addr))
 
  25 #define uncached_to_phys(addr)  ((unsigned long)PHYSADDR(addr))
 
  26 #define phys_to_cached(addr)    ((void *)P1SEGADDR(addr))
 
  27 #define phys_to_uncached(addr)  ((void *)P2SEGADDR(addr))
 
  30  * Generic IO read/write.  These perform native-endian accesses.  Note
 
  31  * that some architectures will want to re-define __raw_{read,write}w.
 
  33 extern void __raw_writesb(void __iomem *addr, const void *data, int bytelen);
 
  34 extern void __raw_writesw(void __iomem *addr, const void *data, int wordlen);
 
  35 extern void __raw_writesl(void __iomem *addr, const void *data, int longlen);
 
  37 extern void __raw_readsb(const void __iomem *addr, void *data, int bytelen);
 
  38 extern void __raw_readsw(const void __iomem *addr, void *data, int wordlen);
 
  39 extern void __raw_readsl(const void __iomem *addr, void *data, int longlen);
 
  41 static inline void __raw_writeb(u8 v, volatile void __iomem *addr)
 
  43         *(volatile u8 __force *)addr = v;
 
  45 static inline void __raw_writew(u16 v, volatile void __iomem *addr)
 
  47         *(volatile u16 __force *)addr = v;
 
  49 static inline void __raw_writel(u32 v, volatile void __iomem *addr)
 
  51         *(volatile u32 __force *)addr = v;
 
  54 static inline u8 __raw_readb(const volatile void __iomem *addr)
 
  56         return *(const volatile u8 __force *)addr;
 
  58 static inline u16 __raw_readw(const volatile void __iomem *addr)
 
  60         return *(const volatile u16 __force *)addr;
 
  62 static inline u32 __raw_readl(const volatile void __iomem *addr)
 
  64         return *(const volatile u32 __force *)addr;
 
  67 /* Convert I/O port address to virtual address */
 
  69 # define __io(p)        ((void *)phys_to_uncached(p))
 
  73  * Not really sure about the best way to slow down I/O on
 
  74  * AVR32. Defining it as a no-op until we have an actual test case.
 
  76 #define SLOW_DOWN_IO    do { } while (0)
 
  78 #define __BUILD_MEMORY_SINGLE(pfx, bwl, type)                           \
 
  80 pfx##write##bwl(type val, volatile void __iomem *addr)                  \
 
  82         volatile type *__addr;                                          \
 
  85         __addr = (void *)__swizzle_addr_##bwl((unsigned long)(addr));   \
 
  86         __val = pfx##ioswab##bwl(__addr, val);                          \
 
  88         BUILD_BUG_ON(sizeof(type) > sizeof(unsigned long));             \
 
  93 static inline type pfx##read##bwl(const volatile void __iomem *addr)    \
 
  95         volatile type *__addr;                                          \
 
  98         __addr = (void *)__swizzle_addr_##bwl((unsigned long)(addr));   \
 
 100         BUILD_BUG_ON(sizeof(type) > sizeof(unsigned long));             \
 
 103         return pfx##ioswab##bwl(__addr, __val);                         \
 
 106 #define __BUILD_IOPORT_SINGLE(pfx, bwl, type, p, slow)                  \
 
 107 static inline void pfx##out##bwl##p(type val, unsigned long port)       \
 
 109         volatile type *__addr;                                          \
 
 112         __addr = __io(__swizzle_addr_##bwl(port));                      \
 
 113         __val = pfx##ioswab##bwl(__addr, val);                          \
 
 115         BUILD_BUG_ON(sizeof(type) > sizeof(unsigned long));             \
 
 121 static inline type pfx##in##bwl##p(unsigned long port)                  \
 
 123         volatile type *__addr;                                          \
 
 126         __addr = __io(__swizzle_addr_##bwl(port));                      \
 
 128         BUILD_BUG_ON(sizeof(type) > sizeof(unsigned long));             \
 
 133         return pfx##ioswab##bwl(__addr, __val);                         \
 
 136 #define __BUILD_MEMORY_PFX(bus, bwl, type)                              \
 
 137         __BUILD_MEMORY_SINGLE(bus, bwl, type)
 
 139 #define BUILDIO_MEM(bwl, type)                                          \
 
 140         __BUILD_MEMORY_PFX(, bwl, type)                                 \
 
 141         __BUILD_MEMORY_PFX(__mem_, bwl, type)
 
 143 #define __BUILD_IOPORT_PFX(bus, bwl, type)                              \
 
 144         __BUILD_IOPORT_SINGLE(bus, bwl, type, ,)                        \
 
 145         __BUILD_IOPORT_SINGLE(bus, bwl, type, _p, SLOW_DOWN_IO)
 
 147 #define BUILDIO_IOPORT(bwl, type)                                       \
 
 148         __BUILD_IOPORT_PFX(, bwl, type)                                 \
 
 149         __BUILD_IOPORT_PFX(__mem_, bwl, type)
 
 155 BUILDIO_IOPORT(b, u8)
 
 156 BUILDIO_IOPORT(w, u16)
 
 157 BUILDIO_IOPORT(l, u32)
 
 159 #define readb_relaxed                   readb
 
 160 #define readw_relaxed                   readw
 
 161 #define readl_relaxed                   readl
 
 163 #define __BUILD_MEMORY_STRING(bwl, type)                                \
 
 164 static inline void writes##bwl(volatile void __iomem *addr,             \
 
 165                                const void *data, unsigned int count)    \
 
 167         const type *__data = data;                                      \
 
 170                 __mem_write##bwl(*__data++, addr);                      \
 
 173 static inline void reads##bwl(const volatile void __iomem *addr,        \
 
 174                               void *data, unsigned int count)           \
 
 176         type *__data = data;                                            \
 
 179                 *__data++ = __mem_read##bwl(addr);                      \
 
 182 #define __BUILD_IOPORT_STRING(bwl, type)                                \
 
 183 static inline void outs##bwl(unsigned long port, const void *data,      \
 
 184                              unsigned int count)                        \
 
 186         const type *__data = data;                                      \
 
 189                 __mem_out##bwl(*__data++, port);                        \
 
 192 static inline void ins##bwl(unsigned long port, void *data,             \
 
 193                            unsigned int count)                          \
 
 195         type *__data = data;                                            \
 
 198                 *__data++ = __mem_in##bwl(port);                        \
 
 201 #define BUILDSTRING(bwl, type)                                          \
 
 202         __BUILD_MEMORY_STRING(bwl, type)                                \
 
 203         __BUILD_IOPORT_STRING(bwl, type)
 
 210  * io{read,write}{8,16,32} macros in both le (for PCI style consumers) and native be
 
 214 #define ioread8(p)              ((unsigned int)readb(p))
 
 216 #define ioread16(p)             ((unsigned int)readw(p))
 
 217 #define ioread16be(p)           ((unsigned int)__raw_readw(p))
 
 219 #define ioread32(p)             ((unsigned int)readl(p))
 
 220 #define ioread32be(p)           ((unsigned int)__raw_readl(p))
 
 222 #define iowrite8(v,p)           writeb(v, p)
 
 224 #define iowrite16(v,p)          writew(v, p)
 
 225 #define iowrite16be(v,p)        __raw_writew(v, p)
 
 227 #define iowrite32(v,p)          writel(v, p)
 
 228 #define iowrite32be(v,p)        __raw_writel(v, p)
 
 230 #define ioread8_rep(p,d,c)      readsb(p,d,c)
 
 231 #define ioread16_rep(p,d,c)     readsw(p,d,c)
 
 232 #define ioread32_rep(p,d,c)     readsl(p,d,c)
 
 234 #define iowrite8_rep(p,s,c)     writesb(p,s,c)
 
 235 #define iowrite16_rep(p,s,c)    writesw(p,s,c)
 
 236 #define iowrite32_rep(p,s,c)    writesl(p,s,c)
 
 240 static inline void memcpy_fromio(void * to, const volatile void __iomem *from,
 
 243         memcpy(to, (const void __force *)from, count);
 
 246 static inline void  memcpy_toio(volatile void __iomem *to, const void * from,
 
 249         memcpy((void __force *)to, from, count);
 
 252 static inline void memset_io(volatile void __iomem *addr, unsigned char val,
 
 255         memset((void __force *)addr, val, count);
 
 258 #define IO_SPACE_LIMIT  0xffffffff
 
 260 extern void __iomem *__ioremap(unsigned long offset, size_t size,
 
 261                                unsigned long flags);
 
 262 extern void __iounmap(void __iomem *addr);
 
 265  * ioremap      -   map bus memory into CPU space
 
 266  * @offset      bus address of the memory
 
 267  * @size        size of the resource to map
 
 269  * ioremap performs a platform specific sequence of operations to make
 
 270  * bus memory CPU accessible via the readb/.../writel functions and
 
 271  * the other mmio helpers. The returned address is not guaranteed to
 
 272  * be usable directly as a virtual address.
 
 274 #define ioremap(offset, size)                   \
 
 275         __ioremap((offset), (size), 0)
 
 277 #define ioremap_nocache(offset, size)           \
 
 278         __ioremap((offset), (size), 0)
 
 280 #define iounmap(addr)                           \
 
 283 #define cached(addr) P1SEGADDR(addr)
 
 284 #define uncached(addr) P2SEGADDR(addr)
 
 286 #define virt_to_bus virt_to_phys
 
 287 #define bus_to_virt phys_to_virt
 
 288 #define page_to_bus page_to_phys
 
 289 #define bus_to_page phys_to_page
 
 292  * Create a virtual mapping cookie for an IO port range.  There exists
 
 293  * no such thing as port-based I/O on AVR32, so a regular ioremap()
 
 294  * should do what we need.
 
 296 #define ioport_map(port, nr)    ioremap(port, nr)
 
 297 #define ioport_unmap(port)      iounmap(port)
 
 299 #define dma_cache_wback_inv(_start, _size)      \
 
 300         flush_dcache_region(_start, _size)
 
 301 #define dma_cache_inv(_start, _size)            \
 
 302         invalidate_dcache_region(_start, _size)
 
 303 #define dma_cache_wback(_start, _size)          \
 
 304         clean_dcache_region(_start, _size)
 
 307  * Convert a physical pointer to a virtual kernel pointer for /dev/mem
 
 310 #define xlate_dev_mem_ptr(p)    __va(p)
 
 313  * Convert a virtual cached pointer to an uncached pointer
 
 315 #define xlate_dev_kmem_ptr(p)   p
 
 317 #endif /* __ASM_AVR32_IO_H */