blob: 9f532902627c4412b08968645eda5667975b104e [file] [log] [blame]
Sam Ravnborgf5e706a2008-07-17 21:55:51 -07001#ifndef __SPARC_IO_H
2#define __SPARC_IO_H
3
4#include <linux/kernel.h>
Sam Ravnborgf5e706a2008-07-17 21:55:51 -07005#include <linux/ioport.h> /* struct resource */
6
Sam Ravnborgf5e706a2008-07-17 21:55:51 -07007#define readb_relaxed(__addr) readb(__addr)
8#define readw_relaxed(__addr) readw(__addr)
9#define readl_relaxed(__addr) readl(__addr)
10
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070011#define IO_SPACE_LIMIT 0xffffffff
12
Sam Ravnborge1039fb2014-04-26 09:57:36 +020013#define memset_io(d,c,sz) _memset_io(d,c,sz)
14#define memcpy_fromio(d,s,sz) _memcpy_fromio(d,s,sz)
15#define memcpy_toio(d,s,sz) _memcpy_toio(d,s,sz)
16
17#include <asm-generic/io.h>
18
19static inline void _memset_io(volatile void __iomem *dst,
20 int c, __kernel_size_t n)
21{
22 volatile void __iomem *d = dst;
23
24 while (n--) {
25 writeb(c, d);
26 d++;
27 }
28}
29
30static inline void _memcpy_fromio(void *dst, const volatile void __iomem *src,
31 __kernel_size_t n)
32{
33 char *d = dst;
34
35 while (n--) {
36 char tmp = readb(src);
37 *d++ = tmp;
38 src++;
39 }
40}
41
42static inline void _memcpy_toio(volatile void __iomem *dst, const void *src,
43 __kernel_size_t n)
44{
45 const char *s = src;
46 volatile void __iomem *d = dst;
47
48 while (n--) {
49 char tmp = *s++;
50 writeb(tmp, d);
51 d++;
52 }
53}
54
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070055/*
56 * SBus accessors.
57 *
58 * SBus has only one, memory mapped, I/O space.
59 * We do not need to flip bytes for SBus of course.
60 */
Sam Ravnborgc3373da2014-04-26 09:57:37 +020061static inline u8 sbus_readb(const volatile void __iomem *addr)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070062{
63 return *(__force volatile u8 *)addr;
64}
65
Sam Ravnborgc3373da2014-04-26 09:57:37 +020066static inline u16 sbus_readw(const volatile void __iomem *addr)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070067{
68 return *(__force volatile u16 *)addr;
69}
70
Sam Ravnborgc3373da2014-04-26 09:57:37 +020071static inline u32 sbus_readl(const volatile void __iomem *addr)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070072{
73 return *(__force volatile u32 *)addr;
74}
75
Sam Ravnborgc3373da2014-04-26 09:57:37 +020076static inline void sbus_writeb(u8 b, volatile void __iomem *addr)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070077{
78 *(__force volatile u8 *)addr = b;
79}
80
Sam Ravnborgc3373da2014-04-26 09:57:37 +020081static inline void sbus_writew(u16 w, volatile void __iomem *addr)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070082{
83 *(__force volatile u16 *)addr = w;
84}
85
Sam Ravnborgc3373da2014-04-26 09:57:37 +020086static inline void sbus_writel(u32 l, volatile void __iomem *addr)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070087{
88 *(__force volatile u32 *)addr = l;
89}
90
Sam Ravnborgc3373da2014-04-26 09:57:37 +020091static inline void sbus_memset_io(volatile void __iomem *__dst, int c,
92 __kernel_size_t n)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070093{
94 while(n--) {
95 sbus_writeb(c, __dst);
96 __dst++;
97 }
98}
99
Sam Ravnborgc3373da2014-04-26 09:57:37 +0200100static inline void sbus_memcpy_fromio(void *dst,
101 const volatile void __iomem *src,
102 __kernel_size_t n)
James Hoganf11b478d2010-10-27 15:33:28 -0700103{
104 char *d = dst;
105
106 while (n--) {
107 char tmp = sbus_readb(src);
108 *d++ = tmp;
109 src++;
110 }
111}
112
Sam Ravnborgc3373da2014-04-26 09:57:37 +0200113static inline void sbus_memcpy_toio(volatile void __iomem *dst,
114 const void *src,
115 __kernel_size_t n)
James Hoganf11b478d2010-10-27 15:33:28 -0700116{
117 const char *s = src;
118 volatile void __iomem *d = dst;
119
120 while (n--) {
121 char tmp = *s++;
122 sbus_writeb(tmp, d);
123 d++;
124 }
125}
126
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700127#ifdef __KERNEL__
128
129/*
130 * Bus number may be embedded in the higher bits of the physical address.
131 * This is why we have no bus number argument to ioremap().
132 */
Sam Ravnborgf05a6862014-05-16 23:25:50 +0200133void __iomem *ioremap(unsigned long offset, unsigned long size);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700134#define ioremap_nocache(X,Y) ioremap((X),(Y))
David S. Miller428695b2008-07-22 14:30:55 -0700135#define ioremap_wc(X,Y) ioremap((X),(Y))
Sam Ravnborgf05a6862014-05-16 23:25:50 +0200136void iounmap(volatile void __iomem *addr);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700137
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700138/* Create a virtual mapping cookie for an IO port range */
Sam Ravnborgf05a6862014-05-16 23:25:50 +0200139void __iomem *ioport_map(unsigned long port, unsigned int nr);
140void ioport_unmap(void __iomem *);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700141
142/* Create a virtual mapping cookie for a PCI BAR (memory or IO) */
143struct pci_dev;
Sam Ravnborgf05a6862014-05-16 23:25:50 +0200144void pci_iounmap(struct pci_dev *dev, void __iomem *);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700145
Sam Ravnborge1039fb2014-04-26 09:57:36 +0200146
147
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700148/*
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700149 * At the moment, we do not use CMOS_READ anywhere outside of rtc.c,
150 * so rtc_port is static in it. This should not change unless a new
151 * hardware pops up.
152 */
153#define RTC_PORT(x) (rtc_port + (x))
154#define RTC_ALWAYS_BCD 0
155
David S. Miller63237ee2008-08-26 23:33:42 -0700156static inline int sbus_can_dma_64bit(void)
157{
158 return 0; /* actually, sparc_cpu_model==sun4d */
159}
160static inline int sbus_can_burst64(void)
161{
162 return 0; /* actually, sparc_cpu_model==sun4d */
163}
164struct device;
Sam Ravnborgf05a6862014-05-16 23:25:50 +0200165void sbus_set_sbus64(struct device *, int);
David S. Miller63237ee2008-08-26 23:33:42 -0700166
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700167#endif
168
169#define __ARCH_HAS_NO_PAGE_ZERO_MAPPED 1
170
Sam Ravnborgf5e706a2008-07-17 21:55:51 -0700171
172#endif /* !(__SPARC_IO_H) */