7135c5447421a1f47554abb80ba7ad0340e0bfeb
1 /* SPDX-License-Identifier: (GPL-2.0-only OR LGPL-2.1-only)
5 * wrapper around irq_to_desc. Using KALLSYMS to get its address when
6 * available, else we need to have a kernel that exports this function to GPL
7 * modules. This export was added to the 3.4 kernels.
9 * Copyright (C) 2011-2012 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
12 #include <lttng/kernel-version.h>
13 #include <linux/module.h>
15 #if (defined(CONFIG_KALLSYMS) \
16 && (LINUX_VERSION_CODE < KERNEL_VERSION(3,4,0)))
18 #include <linux/kallsyms.h>
19 #include <linux/interrupt.h>
20 #include <linux/irqnr.h>
21 #include <wrapper/kallsyms.h>
22 #include <wrapper/irqdesc.h>
25 struct irq_desc
*(*irq_to_desc_sym
)(unsigned int irq
);
27 struct irq_desc
*wrapper_irq_to_desc(unsigned int irq
)
30 irq_to_desc_sym
= (void *) kallsyms_lookup_funcptr("irq_to_desc");
31 if (irq_to_desc_sym
) {
32 return irq_to_desc_sym(irq
);
34 printk_once(KERN_WARNING
"LTTng: irq_to_desc symbol lookup failed.\n");
38 EXPORT_SYMBOL_GPL(wrapper_irq_to_desc
);
42 #include <linux/interrupt.h>
43 #include <linux/irqnr.h>
45 struct irq_desc
*wrapper_irq_to_desc(unsigned int irq
)
47 return irq_to_desc(irq
);
49 EXPORT_SYMBOL_GPL(wrapper_irq_to_desc
);
This page took 0.030141 seconds and 4 git commands to generate.