[lttng-dev] https://lists.lttng.org/pipermail/lttng-dev/2020-May/029631.html
Mathieu Desnoyers
mathieu.desnoyers at efficios.com
Mon Mar 27 08:27:01 EDT 2023
On 2023-03-26 11:00, yashvardhan kukreti wrote:
>
> Hi Mathew,
>
> I have a question about this patch for lttng-modules and the use of
> register_kprobe() to fetch the function ptr.
> The question in this regard is especially from PPC64 ELF_ABI_v1
> perspective.
>
> The functions on PPC64 are accessed via the Function descriptor
> while what register_kprobes returns is the entry point of the function.
> Hence using the return pointer tends to interpret the addr as the
> address of the function descriptor and dereferences the ppc_inst as
> the function entry point and crashes
>
> [ 4145.483594] kernel tried to execute exec-protected page
> (7c0802a6fb81ffe0) - exploit attempt? (uid: 0)
> here 7c0802a6 is the mfspr instruction from the code text section of
> the kallsyms_lookup_name()
>
> note for PPC_ELF_ABI_v1 the register_kprobes() searches for the dot
> variant of the symbol and only in case if cannot find the dot
> variant looks for the normal symbol.
> register_kprobe() -> kprobe_addr() -> kprobe_lookup_name() [arch
> variant replaces weak symbol]
> https://elixir.bootlin.com/linux/v5.10.174/C/ident/kprobe_lookup_name <https://elixir.bootlin.com/linux/v5.10.174/C/ident/kprobe_lookup_name>
>
> Please let me know if i make sense or that i may have missed something.
>
> I have looked at the code of 2.12.8 as well and 2.12.3 verstion of
> lttng-modules.
Please have a look at commits (from stable-2.12 branch of lttng-modules):
commit 53772db24facd84f1f3ddcf21a1ef5f162608721
Author: He Zhe <zhe.he at windriver.com>
Date: Tue Sep 27 15:59:42 2022 +0800
wrapper: powerpc64: fix kernel crash caused by do_get_kallsyms
commit 8fe888d86ccad4226b05a536efb73d71bb091062
Author: Michael Jeanson <mjeanson at efficios.com>
Date: Thu Nov 24 14:25:33 2022 -0500
fix: kallsyms wrapper on ppc64el
I suspect you'll also need this change currently in review:
https://review.lttng.org/c/lttng-modules/+/9113
Please let us know if especially this last change fixes things on your side.
Thanks,
Mathieu
>
> Regards,
> Shashank
>
--
Mathieu Desnoyers
EfficiOS Inc.
https://www.efficios.com
More information about the lttng-dev
mailing list