[PATCH][v3] Enable livepatching on powerpc
Petr Mladek
pmladek at suse.com
Fri Mar 4 02:49:21 AEDT 2016
On Fri 2016-03-04 00:11:55, Balbir Singh wrote:
>
> Changelog v3:
> 1. Moved -ENOSYS to -EINVAL in klp_write_module_reloc
> 2. Moved klp_matchaddr to use ftrace_location_range
Ah, I have been working on it in parallel. It took me longer
because I was busy with some other stuff previous days.
I am going to send slightly updated version in a bit. I will
address there some comments, see below.
> diff --git a/arch/powerpc/include/asm/livepatch.h b/arch/powerpc/include/asm/livepatch.h
> new file mode 100644
> index 0000000..9ecd879
> --- /dev/null
> +++ b/arch/powerpc/include/asm/livepatch.h
> @@ -0,0 +1,41 @@
> +
> +extern int klp_write_module_reloc(struct module *mod, unsigned long type,
> + unsigned long loc, unsigned long value);
Nit, we do not use "extern" in the livepatch-related headers.
> +
> +static inline void klp_arch_set_pc(struct pt_regs *regs, unsigned long ip)
> +{
> + regs->nip = ip;
> +}
> +
> +#endif /* CONFIG_LIVEPATCH */
As Mirek already pointed out. We would like to have here:
#else /* CONFIG_LIVEPATCH */
#error Include linux/livepatch.h, not asm/livepatch.h
#endif /* CONFIG_LIVEPATCH */
> +#endif /* _ASM_POWERPC64_LIVEPATCH_H */
> diff --git a/arch/powerpc/kernel/livepatch.c b/arch/powerpc/kernel/livepatch.c
> new file mode 100644
> index 0000000..8c99e2d
> --- /dev/null
> +++ b/arch/powerpc/kernel/livepatch.c
> @@ -0,0 +1,54 @@
> +/**
> + * klp_write_module_reloc() - write a relocation in a module
> + * @mod: module in which the section to be modified is found
> + * @type: ELF relocation type (see asm/elf.h)
> + * @loc: address that the relocation should be written to
> + * @value: relocation value (sym address + addend)
> + *
> + * This function writes a relocation to the specified location for
> + * a particular module.
> + */
> +int klp_write_module_reloc(struct module *mod, unsigned long type,
> + unsigned long loc, unsigned long value)
> +{
> + /* This requires infrastructure changes; we need the loadinfos. */
> + pr_err("klp_write_module_reloc not yet supported\n");
> + return -EINVAL;
I agree that -ENOSYS is a bit misleading. But -EINVAL is not ideal
either. Anyway, we should stay compatible with the other architectures
in this patch.
> +}
> +
> +int klp_matchaddr(struct ftrace_ops *ops, unsigned long ip,
> + int remove, int reset)
> +{
> + int ret = 1;
> + unsigned long correct_ip;
> +
> + correct_ip = ftrace_location_range(ip, ip + 16);
I really like that it is so easy in the end.
> + if (!correct_ip)
> + goto done;
> +
> + ret = ftrace_set_filter_ip(ops, correct_ip, remove, reset);
I do not like that we hide this important operation under a function
called klp_matchaddr(). I am going to rename this function to
klp_get_ftrace_location() and just return the address found
by ftrace_location_range(). Another advantage is that it will
make one-liner from this arch-specific function.
> +done:
> + return ret;
> +}
> +
Thanks a lot for pushing this forward,
Petr
More information about the Linuxppc-dev
mailing list