mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-12 08:00:09 +00:00
arm64 2nd round of updates for 4.20:
- Fix W+X page (mark RO) allocated by the arm64 kprobes code - Makefile fix for .i files in out of tree modules -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEE5RElWfyWxS+3PLO2a9axLQDIXvEFAlvdeMUACgkQa9axLQDI XvGVAQ/8Dd6M1NwDsPqdemdWVOGJJi+c+Ou39c29dCvPkZV63ZgPBaQiOX5DJ18T TUjC+Q2zW4Oag86q4N0REOQiafDfScNU/ZsDgnfHvagKNc6+V1lqzb8DsteeeCW9 YOPnbL/VV+dBKKXphjW23VQfsz5ryDU6HKoDHRgOOtHisnTOKJGj/HCXzn1LY6x4 us/Gl6U/kJyRs0/7F8lmfSatDK2o+bKo0/0X6OV7dNE3bo++rpWxCX8D/dcBiEwV BZDkWu5noglnzYz/LwobYwIjshd6cNjSjJKgoudp3+6WtcFGiK347HDQyo6WqBSd 5hmo/R0My5SUWrwb3GVmxFQmDDxIwywneSkKdx00PNygoNBhu7VYOrf7C/8NOl2h a0lMCl1Q9x+/2ZDWHhgcwZ6Nfkj/3hJ/3jQVtfqt7ldXgPmZQPrBcx0+CzjGAAiK gmIpr7VH701KkQGMljV4W0AurWx4v/+YpewkSODBOcbEQTd6trl8I5+A0SA+o6eC F479l8meU9H0vf9fMB1bkRxBipyaFRKNaTuabO3wHN45C4fzQCXQi5pjfvyAfC+f zZbnTKeWVzAafnYGcS6Fml+hUD3QQdARnd3WDOyzwBC7EvZM3gGmFWnlkMxbgSuV 9c9+t7fMLChQiKUZ+bjNQpaXZ0YmA9+1fRqb9xCOP1/Ll7933A0= =hH50 -----END PGP SIGNATURE----- Merge tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux Pull more arm64 updates from Catalin Marinas: - fix W+X page (mark RO) allocated by the arm64 kprobes code - Makefile fix for .i files in out of tree modules * tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: arm64: kprobe: make page to RO mode when allocate it arm64: kdump: fix small typo arm64: makefile fix build of .i file in external module case
This commit is contained in:
commit
83650fd58a
@ -134,6 +134,7 @@ vdso_install:
|
|||||||
archclean:
|
archclean:
|
||||||
$(Q)$(MAKE) $(clean)=$(boot)
|
$(Q)$(MAKE) $(clean)=$(boot)
|
||||||
|
|
||||||
|
ifeq ($(KBUILD_EXTMOD),)
|
||||||
# We need to generate vdso-offsets.h before compiling certain files in kernel/.
|
# We need to generate vdso-offsets.h before compiling certain files in kernel/.
|
||||||
# In order to do that, we should use the archprepare target, but we can't since
|
# In order to do that, we should use the archprepare target, but we can't since
|
||||||
# asm-offsets.h is included in some files used to generate vdso-offsets.h, and
|
# asm-offsets.h is included in some files used to generate vdso-offsets.h, and
|
||||||
@ -143,6 +144,7 @@ archclean:
|
|||||||
prepare: vdso_prepare
|
prepare: vdso_prepare
|
||||||
vdso_prepare: prepare0
|
vdso_prepare: prepare0
|
||||||
$(Q)$(MAKE) $(build)=arch/arm64/kernel/vdso include/generated/vdso-offsets.h
|
$(Q)$(MAKE) $(build)=arch/arm64/kernel/vdso include/generated/vdso-offsets.h
|
||||||
|
endif
|
||||||
|
|
||||||
define archhelp
|
define archhelp
|
||||||
echo '* Image.gz - Compressed kernel image (arch/$(ARCH)/boot/Image.gz)'
|
echo '* Image.gz - Compressed kernel image (arch/$(ARCH)/boot/Image.gz)'
|
||||||
|
@ -58,7 +58,7 @@ ssize_t copy_oldmem_page(unsigned long pfn, char *buf,
|
|||||||
/**
|
/**
|
||||||
* elfcorehdr_read - read from ELF core header
|
* elfcorehdr_read - read from ELF core header
|
||||||
* @buf: buffer where the data is placed
|
* @buf: buffer where the data is placed
|
||||||
* @csize: number of bytes to read
|
* @count: number of bytes to read
|
||||||
* @ppos: address in the memory
|
* @ppos: address in the memory
|
||||||
*
|
*
|
||||||
* This function reads @count bytes from elf core header which exists
|
* This function reads @count bytes from elf core header which exists
|
||||||
|
@ -23,7 +23,9 @@
|
|||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/stop_machine.h>
|
#include <linux/stop_machine.h>
|
||||||
#include <linux/sched/debug.h>
|
#include <linux/sched/debug.h>
|
||||||
|
#include <linux/set_memory.h>
|
||||||
#include <linux/stringify.h>
|
#include <linux/stringify.h>
|
||||||
|
#include <linux/vmalloc.h>
|
||||||
#include <asm/traps.h>
|
#include <asm/traps.h>
|
||||||
#include <asm/ptrace.h>
|
#include <asm/ptrace.h>
|
||||||
#include <asm/cacheflush.h>
|
#include <asm/cacheflush.h>
|
||||||
@ -42,10 +44,21 @@ DEFINE_PER_CPU(struct kprobe_ctlblk, kprobe_ctlblk);
|
|||||||
static void __kprobes
|
static void __kprobes
|
||||||
post_kprobe_handler(struct kprobe_ctlblk *, struct pt_regs *);
|
post_kprobe_handler(struct kprobe_ctlblk *, struct pt_regs *);
|
||||||
|
|
||||||
|
static int __kprobes patch_text(kprobe_opcode_t *addr, u32 opcode)
|
||||||
|
{
|
||||||
|
void *addrs[1];
|
||||||
|
u32 insns[1];
|
||||||
|
|
||||||
|
addrs[0] = addr;
|
||||||
|
insns[0] = opcode;
|
||||||
|
|
||||||
|
return aarch64_insn_patch_text(addrs, insns, 1);
|
||||||
|
}
|
||||||
|
|
||||||
static void __kprobes arch_prepare_ss_slot(struct kprobe *p)
|
static void __kprobes arch_prepare_ss_slot(struct kprobe *p)
|
||||||
{
|
{
|
||||||
/* prepare insn slot */
|
/* prepare insn slot */
|
||||||
p->ainsn.api.insn[0] = cpu_to_le32(p->opcode);
|
patch_text(p->ainsn.api.insn, p->opcode);
|
||||||
|
|
||||||
flush_icache_range((uintptr_t) (p->ainsn.api.insn),
|
flush_icache_range((uintptr_t) (p->ainsn.api.insn),
|
||||||
(uintptr_t) (p->ainsn.api.insn) +
|
(uintptr_t) (p->ainsn.api.insn) +
|
||||||
@ -118,15 +131,15 @@ int __kprobes arch_prepare_kprobe(struct kprobe *p)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __kprobes patch_text(kprobe_opcode_t *addr, u32 opcode)
|
void *alloc_insn_page(void)
|
||||||
{
|
{
|
||||||
void *addrs[1];
|
void *page;
|
||||||
u32 insns[1];
|
|
||||||
|
|
||||||
addrs[0] = (void *)addr;
|
page = vmalloc_exec(PAGE_SIZE);
|
||||||
insns[0] = (u32)opcode;
|
if (page)
|
||||||
|
set_memory_ro((unsigned long)page, 1);
|
||||||
|
|
||||||
return aarch64_insn_patch_text(addrs, insns, 1);
|
return page;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* arm kprobe: install breakpoint in text */
|
/* arm kprobe: install breakpoint in text */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user