mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 01:49:46 +00:00
The only purpose of klp_check_compiler_support() is to make sure that we are not using ftrace on x86 via mcount (because that's executed only after prologue has already happened, and that's too late for livepatching purposes). Now that mcount is not supported by ftrace any more, there is no need for klp_check_compiler_support() either. Link: http://lkml.kernel.org/r/nycvar.YFH.7.76.1905102346100.17054@cbobk.fhfr.pm Reported-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Jiri Kosina <jkosina@suse.cz> Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
52 lines
1.6 KiB
C
52 lines
1.6 KiB
C
/*
|
|
* livepatch.h - powerpc-specific Kernel Live Patching Core
|
|
*
|
|
* Copyright (C) 2015-2016, SUSE, IBM Corp.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#ifndef _ASM_POWERPC_LIVEPATCH_H
|
|
#define _ASM_POWERPC_LIVEPATCH_H
|
|
|
|
#include <linux/module.h>
|
|
#include <linux/ftrace.h>
|
|
#include <linux/sched/task_stack.h>
|
|
|
|
#ifdef CONFIG_LIVEPATCH
|
|
static inline void klp_arch_set_pc(struct pt_regs *regs, unsigned long ip)
|
|
{
|
|
regs->nip = ip;
|
|
}
|
|
|
|
#define klp_get_ftrace_location klp_get_ftrace_location
|
|
static inline unsigned long klp_get_ftrace_location(unsigned long faddr)
|
|
{
|
|
/*
|
|
* Live patch works only with -mprofile-kernel on PPC. In this case,
|
|
* the ftrace location is always within the first 16 bytes.
|
|
*/
|
|
return ftrace_location_range(faddr, faddr + 16);
|
|
}
|
|
|
|
static inline void klp_init_thread_info(struct task_struct *p)
|
|
{
|
|
/* + 1 to account for STACK_END_MAGIC */
|
|
task_thread_info(p)->livepatch_sp = end_of_stack(p) + 1;
|
|
}
|
|
#else
|
|
static inline void klp_init_thread_info(struct task_struct *p) { }
|
|
#endif /* CONFIG_LIVEPATCH */
|
|
|
|
#endif /* _ASM_POWERPC_LIVEPATCH_H */
|