1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef __ASM_SH_IO_TRAPPED_H
3 #define __ASM_SH_IO_TRAPPED_H
4 
5 #include <linux/list.h>
6 #include <linux/ioport.h>
7 #include <asm/page.h>
8 
9 #define IO_TRAPPED_MAGIC 0xfeedbeef
10 
11 struct trapped_io {
12 	unsigned int magic;
13 	struct resource *resource;
14 	unsigned int num_resources;
15 	unsigned int minimum_bus_width;
16 	struct list_head list;
17 	void __iomem *virt_base;
18 } __aligned(PAGE_SIZE);
19 
20 #ifdef CONFIG_IO_TRAPPED
21 int register_trapped_io(struct trapped_io *tiop);
22 int handle_trapped_io(struct pt_regs *regs, unsigned long address);
23 
24 void __iomem *match_trapped_io_handler(struct list_head *list,
25 				       unsigned long offset,
26 				       unsigned long size);
27 
28 #ifdef CONFIG_HAS_IOMEM
29 extern struct list_head trapped_mem;
30 
31 static inline void __iomem *
__ioremap_trapped(unsigned long offset,unsigned long size)32 __ioremap_trapped(unsigned long offset, unsigned long size)
33 {
34 	return match_trapped_io_handler(&trapped_mem, offset, size);
35 }
36 #else
37 #define __ioremap_trapped(offset, size) NULL
38 #endif
39 
40 #ifdef CONFIG_HAS_IOPORT_MAP
41 extern struct list_head trapped_io;
42 
43 static inline void __iomem *
__ioport_map_trapped(unsigned long offset,unsigned long size)44 __ioport_map_trapped(unsigned long offset, unsigned long size)
45 {
46 	return match_trapped_io_handler(&trapped_io, offset, size);
47 }
48 #else
49 #define __ioport_map_trapped(offset, size) NULL
50 #endif
51 
52 #else
53 #define register_trapped_io(tiop) (-1)
54 #define handle_trapped_io(tiop, address) 0
55 #define __ioremap_trapped(offset, size) NULL
56 #define __ioport_map_trapped(offset, size) NULL
57 #endif
58 
59 #endif /* __ASM_SH_IO_TRAPPED_H */
60