Commit | Line | Data |
---|---|---|
b7cdc182 | 1 | /* SPDX-License-Identifier: (GPL-2.0-only OR LGPL-2.1-only) |
9f36eaed | 2 | * |
886d51a3 | 3 | * wrapper/irqdesc.c |
c337ddc2 MD |
4 | * |
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 | |
4a7d870a | 7 | * modules. This export was added to the 3.4 kernels and removed in 5.11. |
c337ddc2 | 8 | * |
886d51a3 | 9 | * Copyright (C) 2011-2012 Mathieu Desnoyers <mathieu.desnoyers@efficios.com> |
c337ddc2 MD |
10 | */ |
11 | ||
2df37e95 | 12 | #include <lttng/kernel-version.h> |
0193412d | 13 | #include <linux/module.h> |
0bbde272 | 14 | |
4a7d870a | 15 | #if (defined(CONFIG_KALLSYMS) && \ |
c58ee879 | 16 | (LTTNG_LINUX_VERSION_CODE >= LTTNG_KERNEL_VERSION(5,11,0))) |
c337ddc2 MD |
17 | |
18 | #include <linux/kallsyms.h> | |
19 | #include <linux/interrupt.h> | |
20 | #include <linux/irqnr.h> | |
5a2f5e92 MD |
21 | #include <wrapper/kallsyms.h> |
22 | #include <wrapper/irqdesc.h> | |
c337ddc2 MD |
23 | |
24 | static | |
25 | struct irq_desc *(*irq_to_desc_sym)(unsigned int irq); | |
26 | ||
27 | struct irq_desc *wrapper_irq_to_desc(unsigned int irq) | |
28 | { | |
29 | if (!irq_to_desc_sym) | |
1e543e7c | 30 | irq_to_desc_sym = (void *) kallsyms_lookup_funcptr("irq_to_desc"); |
c337ddc2 | 31 | if (irq_to_desc_sym) { |
92e2c5fe MD |
32 | struct irq_ibt_state irq_ibt_state; |
33 | struct irq_desc *ret; | |
34 | ||
35 | irq_ibt_state = wrapper_irq_ibt_save(); | |
36 | ret = irq_to_desc_sym(irq); | |
37 | wrapper_irq_ibt_restore(irq_ibt_state); | |
38 | return ret; | |
c337ddc2 | 39 | } else { |
e36de50d | 40 | printk_once(KERN_WARNING "LTTng: irq_to_desc symbol lookup failed.\n"); |
c337ddc2 MD |
41 | return NULL; |
42 | } | |
43 | } | |
1c999280 | 44 | EXPORT_SYMBOL_GPL(wrapper_irq_to_desc); |
c337ddc2 MD |
45 | |
46 | #else | |
47 | ||
48 | #include <linux/interrupt.h> | |
49 | #include <linux/irqnr.h> | |
50 | ||
51 | struct irq_desc *wrapper_irq_to_desc(unsigned int irq) | |
52 | { | |
53 | return irq_to_desc(irq); | |
54 | } | |
1c999280 | 55 | EXPORT_SYMBOL_GPL(wrapper_irq_to_desc); |
c337ddc2 MD |
56 | |
57 | #endif |