xref: /linux-6.15/include/linux/of_irq.h (revision 2bb129eb)
1 #ifndef __OF_IRQ_H
2 #define __OF_IRQ_H
3 
4 #include <linux/types.h>
5 #include <linux/errno.h>
6 #include <linux/irq.h>
7 #include <linux/irqdomain.h>
8 #include <linux/ioport.h>
9 #include <linux/of.h>
10 
11 typedef int (*of_irq_init_cb_t)(struct device_node *, struct device_node *);
12 
13 /*
14  * Workarounds only applied to 32bit powermac machines
15  */
16 #define OF_IMAP_OLDWORLD_MAC	0x00000001
17 #define OF_IMAP_NO_PHANDLE	0x00000002
18 
19 #if defined(CONFIG_PPC32) && defined(CONFIG_PPC_PMAC)
20 extern unsigned int of_irq_workarounds;
21 extern struct device_node *of_irq_dflt_pic;
22 extern int of_irq_parse_oldworld(struct device_node *device, int index,
23 			       struct of_phandle_args *out_irq);
24 #else /* CONFIG_PPC32 && CONFIG_PPC_PMAC */
25 #define of_irq_workarounds (0)
26 #define of_irq_dflt_pic (NULL)
27 static inline int of_irq_parse_oldworld(struct device_node *device, int index,
28 				      struct of_phandle_args *out_irq)
29 {
30 	return -EINVAL;
31 }
32 #endif /* CONFIG_PPC32 && CONFIG_PPC_PMAC */
33 
34 extern int of_irq_parse_raw(const __be32 *addr, struct of_phandle_args *out_irq);
35 extern int of_irq_parse_one(struct device_node *device, int index,
36 			  struct of_phandle_args *out_irq);
37 extern unsigned int irq_create_of_mapping(struct of_phandle_args *irq_data);
38 extern int of_irq_to_resource(struct device_node *dev, int index,
39 			      struct resource *r);
40 
41 extern void of_irq_init(const struct of_device_id *matches);
42 
43 #ifdef CONFIG_OF_IRQ
44 extern int of_irq_count(struct device_node *dev);
45 extern int of_irq_get(struct device_node *dev, int index);
46 extern int of_irq_get_byname(struct device_node *dev, const char *name);
47 extern int of_irq_to_resource_table(struct device_node *dev,
48 		struct resource *res, int nr_irqs);
49 extern struct irq_domain *of_msi_get_domain(struct device *dev,
50 					    struct device_node *np,
51 					    enum irq_domain_bus_token token);
52 extern struct irq_domain *of_msi_map_get_device_domain(struct device *dev,
53 						       u32 rid);
54 extern void of_msi_configure(struct device *dev, struct device_node *np);
55 #else
56 static inline int of_irq_count(struct device_node *dev)
57 {
58 	return 0;
59 }
60 static inline int of_irq_get(struct device_node *dev, int index)
61 {
62 	return 0;
63 }
64 static inline int of_irq_get_byname(struct device_node *dev, const char *name)
65 {
66 	return 0;
67 }
68 static inline int of_irq_to_resource_table(struct device_node *dev,
69 					   struct resource *res, int nr_irqs)
70 {
71 	return 0;
72 }
73 static inline struct irq_domain *of_msi_get_domain(struct device *dev,
74 						   struct device_node *np,
75 						   enum irq_domain_bus_token token)
76 {
77 	return NULL;
78 }
79 static inline struct irq_domain *of_msi_map_get_device_domain(struct device *dev,
80 							      u32 rid)
81 {
82 	return NULL;
83 }
84 static inline void of_msi_configure(struct device *dev, struct device_node *np)
85 {
86 }
87 #endif
88 
89 #if defined(CONFIG_OF_IRQ) || defined(CONFIG_SPARC)
90 /*
91  * irq_of_parse_and_map() is used by all OF enabled platforms; but SPARC
92  * implements it differently.  However, the prototype is the same for all,
93  * so declare it here regardless of the CONFIG_OF_IRQ setting.
94  */
95 extern unsigned int irq_of_parse_and_map(struct device_node *node, int index);
96 u32 of_msi_map_rid(struct device *dev, struct device_node *msi_np, u32 rid_in);
97 
98 #else /* !CONFIG_OF && !CONFIG_SPARC */
99 static inline unsigned int irq_of_parse_and_map(struct device_node *dev,
100 						int index)
101 {
102 	return 0;
103 }
104 
105 static inline u32 of_msi_map_rid(struct device *dev,
106 				 struct device_node *msi_np, u32 rid_in)
107 {
108 	return rid_in;
109 }
110 #endif /* !CONFIG_OF */
111 
112 #endif /* __OF_IRQ_H */
113