1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _ASM_M68K_ZORRO_H
3 #define _ASM_M68K_ZORRO_H
4 
5 #include <asm/raw_io.h>
6 #include <asm/kmap.h>
7 
8 #define z_readb raw_inb
9 #define z_readw raw_inw
10 #define z_readl raw_inl
11 
12 #define z_writeb raw_outb
13 #define z_writew raw_outw
14 #define z_writel raw_outl
15 
16 #define z_memset_io(a,b,c)	memset((void *)(a),(b),(c))
17 #define z_memcpy_fromio(a,b,c)	memcpy((a),(void *)(b),(c))
18 #define z_memcpy_toio(a,b,c)	memcpy((void *)(a),(b),(c))
19 
z_remap_nocache_ser(unsigned long physaddr,unsigned long size)20 static inline void __iomem *z_remap_nocache_ser(unsigned long physaddr,
21 					unsigned long size)
22 {
23 	return __ioremap(physaddr, size, IOMAP_NOCACHE_SER);
24 }
25 
z_remap_nocache_nonser(unsigned long physaddr,unsigned long size)26 static inline void __iomem *z_remap_nocache_nonser(unsigned long physaddr,
27 					   unsigned long size)
28 {
29 	return __ioremap(physaddr, size, IOMAP_NOCACHE_NONSER);
30 }
31 
z_remap_writethrough(unsigned long physaddr,unsigned long size)32 static inline void __iomem *z_remap_writethrough(unsigned long physaddr,
33 					 unsigned long size)
34 {
35 	return __ioremap(physaddr, size, IOMAP_WRITETHROUGH);
36 }
z_remap_fullcache(unsigned long physaddr,unsigned long size)37 static inline void __iomem *z_remap_fullcache(unsigned long physaddr,
38 				      unsigned long size)
39 {
40 	return __ioremap(physaddr, size, IOMAP_FULL_CACHING);
41 }
42 
43 #define z_unmap iounmap
44 #define z_iounmap iounmap
45 #define z_ioremap z_remap_nocache_ser
46 
47 #endif /* _ASM_M68K_ZORRO_H */
48