powerpc/xmon: Move breakpoints to text section
The instructions for xmon's breakpoint are stored bpt_table[] which is in the data section. This is problematic as the data section may be marked as no execute. Move bpt_table[] to the text section. Signed-off-by: Jordan Niethe <jniethe5@gmail.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20200506034050.24806-4-jniethe5@gmail.com
This commit is contained in:
parent
51c9ba11f1
commit
4eff2b4f32
@ -70,6 +70,10 @@
|
|||||||
#include <asm/fixmap.h>
|
#include <asm/fixmap.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_XMON
|
||||||
|
#include "../xmon/xmon_bpts.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#define STACK_PT_REGS_OFFSET(sym, val) \
|
#define STACK_PT_REGS_OFFSET(sym, val) \
|
||||||
DEFINE(sym, STACK_FRAME_OVERHEAD + offsetof(struct pt_regs, val))
|
DEFINE(sym, STACK_FRAME_OVERHEAD + offsetof(struct pt_regs, val))
|
||||||
|
|
||||||
@ -795,5 +799,9 @@ int main(void)
|
|||||||
DEFINE(VIRT_IMMR_BASE, (u64)__fix_to_virt(FIX_IMMR_BASE));
|
DEFINE(VIRT_IMMR_BASE, (u64)__fix_to_virt(FIX_IMMR_BASE));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_XMON
|
||||||
|
DEFINE(BPT_SIZE, BPT_SIZE);
|
||||||
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ endif
|
|||||||
|
|
||||||
ccflags-$(CONFIG_PPC64) := $(NO_MINIMAL_TOC)
|
ccflags-$(CONFIG_PPC64) := $(NO_MINIMAL_TOC)
|
||||||
|
|
||||||
obj-y += xmon.o nonstdio.o spr_access.o
|
obj-y += xmon.o nonstdio.o spr_access.o xmon_bpts.o
|
||||||
|
|
||||||
ifdef CONFIG_XMON_DISASSEMBLY
|
ifdef CONFIG_XMON_DISASSEMBLY
|
||||||
obj-y += ppc-dis.o ppc-opc.o
|
obj-y += ppc-dis.o ppc-opc.o
|
||||||
|
@ -62,6 +62,7 @@
|
|||||||
|
|
||||||
#include "nonstdio.h"
|
#include "nonstdio.h"
|
||||||
#include "dis-asm.h"
|
#include "dis-asm.h"
|
||||||
|
#include "xmon_bpts.h"
|
||||||
|
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
static cpumask_t cpus_in_xmon = CPU_MASK_NONE;
|
static cpumask_t cpus_in_xmon = CPU_MASK_NONE;
|
||||||
@ -109,7 +110,6 @@ struct bpt {
|
|||||||
#define BP_TRAP 2
|
#define BP_TRAP 2
|
||||||
#define BP_DABR 4
|
#define BP_DABR 4
|
||||||
|
|
||||||
#define NBPTS 256
|
|
||||||
static struct bpt bpts[NBPTS];
|
static struct bpt bpts[NBPTS];
|
||||||
static struct bpt dabr;
|
static struct bpt dabr;
|
||||||
static struct bpt *iabr;
|
static struct bpt *iabr;
|
||||||
@ -117,10 +117,6 @@ static unsigned bpinstr = 0x7fe00008; /* trap */
|
|||||||
|
|
||||||
#define BP_NUM(bp) ((bp) - bpts + 1)
|
#define BP_NUM(bp) ((bp) - bpts + 1)
|
||||||
|
|
||||||
#define BPT_SIZE (sizeof(unsigned int) * 2)
|
|
||||||
#define BPT_WORDS (BPT_SIZE / sizeof(unsigned int))
|
|
||||||
static unsigned int bpt_table[NBPTS * BPT_WORDS];
|
|
||||||
|
|
||||||
/* Prototypes */
|
/* Prototypes */
|
||||||
static int cmds(struct pt_regs *);
|
static int cmds(struct pt_regs *);
|
||||||
static int mread(unsigned long, void *, int);
|
static int mread(unsigned long, void *, int);
|
||||||
|
9
arch/powerpc/xmon/xmon_bpts.S
Normal file
9
arch/powerpc/xmon/xmon_bpts.S
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||||||
|
#include <asm/ppc_asm.h>
|
||||||
|
#include <asm/asm-compat.h>
|
||||||
|
#include <asm/asm-offsets.h>
|
||||||
|
#include "xmon_bpts.h"
|
||||||
|
|
||||||
|
.global bpt_table
|
||||||
|
bpt_table:
|
||||||
|
.space NBPTS * BPT_SIZE
|
14
arch/powerpc/xmon/xmon_bpts.h
Normal file
14
arch/powerpc/xmon/xmon_bpts.h
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||||||
|
#ifndef XMON_BPTS_H
|
||||||
|
#define XMON_BPTS_H
|
||||||
|
|
||||||
|
#define NBPTS 256
|
||||||
|
#ifndef __ASSEMBLY__
|
||||||
|
#define BPT_SIZE (sizeof(unsigned int) * 2)
|
||||||
|
#define BPT_WORDS (BPT_SIZE / sizeof(unsigned int))
|
||||||
|
|
||||||
|
extern unsigned int bpt_table[NBPTS * BPT_WORDS];
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
|
|
||||||
|
#endif /* XMON_BPTS_H */
|
Loading…
Reference in New Issue
Block a user