1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Generic I/O and MEMIO string operations.  */
3 
4 #define __ide_insw	insw
5 #define __ide_insl	insl
6 #define __ide_outsw	outsw
7 #define __ide_outsl	outsl
8 
__ide_mm_insw(void __iomem * port,void * addr,u32 count)9 static __inline__ void __ide_mm_insw(void __iomem *port, void *addr, u32 count)
10 {
11 	while (count--) {
12 		*(u16 *)addr = readw(port);
13 		addr += 2;
14 	}
15 }
16 
__ide_mm_insl(void __iomem * port,void * addr,u32 count)17 static __inline__ void __ide_mm_insl(void __iomem *port, void *addr, u32 count)
18 {
19 	while (count--) {
20 		*(u32 *)addr = readl(port);
21 		addr += 4;
22 	}
23 }
24 
__ide_mm_outsw(void __iomem * port,void * addr,u32 count)25 static __inline__ void __ide_mm_outsw(void __iomem *port, void *addr, u32 count)
26 {
27 	while (count--) {
28 		writew(*(u16 *)addr, port);
29 		addr += 2;
30 	}
31 }
32 
__ide_mm_outsl(void __iomem * port,void * addr,u32 count)33 static __inline__ void __ide_mm_outsl(void __iomem * port, void *addr, u32 count)
34 {
35 	while (count--) {
36 		writel(*(u32 *)addr, port);
37 		addr += 4;
38 	}
39 }
40