Skip to content

Commit 6f291a0

Browse files
npigginmpe
authored andcommitted
powerpc: add a define for the switch frame size and regs offset
This is open-coded in process.c, ppc32 uses a different define with the same value, and the C definition is name differently which makes it an extra indirection to grep for. Signed-off-by: Nicholas Piggin <npiggin@gmail.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20221127124942.1665522-12-npiggin@gmail.com
1 parent 1223e5a commit 6f291a0

File tree

4 files changed

+16
-10
lines changed

4 files changed

+16
-10
lines changed

arch/powerpc/include/asm/ptrace.h

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -97,8 +97,6 @@ struct pt_regs
9797
#endif
9898

9999

100-
#define STACK_FRAME_WITH_PT_REGS (STACK_FRAME_OVERHEAD + sizeof(struct pt_regs))
101-
102100
// Always displays as "REGS" in memory dumps
103101
#ifdef CONFIG_CPU_BIG_ENDIAN
104102
#define STACK_FRAME_REGS_MARKER ASM_CONST(0x52454753)
@@ -125,6 +123,8 @@ struct pt_regs
125123
#define STACK_USER_INT_FRAME_SIZE (sizeof(struct pt_regs) + STACK_FRAME_OVERHEAD)
126124
#define STACK_INT_FRAME_REGS STACK_FRAME_OVERHEAD
127125
#define STACK_INT_FRAME_MARKER (STACK_FRAME_OVERHEAD - 16)
126+
#define STACK_SWITCH_FRAME_SIZE (sizeof(struct pt_regs) + STACK_FRAME_OVERHEAD)
127+
#define STACK_SWITCH_FRAME_REGS STACK_FRAME_OVERHEAD
128128

129129
#ifdef CONFIG_PPC64_ELF_ABI_V2
130130
#define STACK_FRAME_MIN_SIZE 32
@@ -146,6 +146,8 @@ struct pt_regs
146146
#define STACK_INT_FRAME_REGS STACK_FRAME_OVERHEAD
147147
#define STACK_INT_FRAME_MARKER (STACK_FRAME_OVERHEAD - 8)
148148
#define STACK_FRAME_MIN_SIZE STACK_FRAME_OVERHEAD
149+
#define STACK_SWITCH_FRAME_SIZE (sizeof(struct pt_regs) + STACK_FRAME_OVERHEAD)
150+
#define STACK_SWITCH_FRAME_REGS STACK_FRAME_OVERHEAD
149151

150152
/* Size of stack frame allocated when calling signal handler. */
151153
#define __SIGNAL_FRAMESIZE 64

arch/powerpc/kernel/asm-offsets.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -260,7 +260,7 @@ int main(void)
260260

261261
/* Interrupt register frame */
262262
DEFINE(INT_FRAME_SIZE, STACK_INT_FRAME_SIZE);
263-
DEFINE(SWITCH_FRAME_SIZE, STACK_FRAME_WITH_PT_REGS);
263+
DEFINE(SWITCH_FRAME_SIZE, STACK_SWITCH_FRAME_SIZE);
264264
STACK_PT_REGS_OFFSET(GPR0, gpr[0]);
265265
STACK_PT_REGS_OFFSET(GPR1, gpr[1]);
266266
STACK_PT_REGS_OFFSET(GPR2, gpr[2]);

arch/powerpc/kernel/entry_32.S

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -215,9 +215,9 @@ ret_from_kernel_thread:
215215
* in arch/ppc/kernel/process.c
216216
*/
217217
_GLOBAL(_switch)
218-
stwu r1,-INT_FRAME_SIZE(r1)
218+
stwu r1,-SWITCH_FRAME_SIZE(r1)
219219
mflr r0
220-
stw r0,INT_FRAME_SIZE+4(r1)
220+
stw r0,SWITCH_FRAME_SIZE+4(r1)
221221
/* r3-r12 are caller saved -- Cort */
222222
SAVE_NVGPRS(r1)
223223
stw r0,_NIP(r1) /* Return to switch caller */
@@ -248,7 +248,7 @@ _GLOBAL(_switch)
248248

249249
lwz r4,_NIP(r1) /* Return to _switch caller in new task */
250250
mtlr r4
251-
addi r1,r1,INT_FRAME_SIZE
251+
addi r1,r1,SWITCH_FRAME_SIZE
252252
blr
253253

254254
.globl fast_exception_return

arch/powerpc/kernel/process.c

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1808,10 +1808,10 @@ int copy_thread(struct task_struct *p, const struct kernel_clone_args *args)
18081808
* do some house keeping and then return from the fork or clone
18091809
* system call, using the stack frame created above.
18101810
*/
1811-
sp -= sizeof(struct pt_regs);
1812-
kregs = (struct pt_regs *) sp;
1813-
sp -= STACK_FRAME_OVERHEAD;
1811+
sp -= STACK_SWITCH_FRAME_SIZE;
1812+
kregs = (struct pt_regs *)(sp + STACK_SWITCH_FRAME_REGS);
18141813
p->thread.ksp = sp;
1814+
18151815
#ifdef CONFIG_HAVE_HW_BREAKPOINT
18161816
for (i = 0; i < nr_wp_slots(); i++)
18171817
p->thread.ptrace_bps[i] = NULL;
@@ -2261,8 +2261,12 @@ void __no_sanitize_address show_stack(struct task_struct *tsk,
22612261
/*
22622262
* See if this is an exception frame.
22632263
* We look for the "regs" marker in the current frame.
2264+
*
2265+
* STACK_SWITCH_FRAME_SIZE being the smallest frame that
2266+
* could hold a pt_regs, if that does not fit then it can't
2267+
* have regs.
22642268
*/
2265-
if (validate_sp(sp, tsk, STACK_FRAME_WITH_PT_REGS)
2269+
if (validate_sp(sp, tsk, STACK_SWITCH_FRAME_SIZE)
22662270
&& stack[STACK_INT_FRAME_MARKER_LONGS] == STACK_FRAME_REGS_MARKER) {
22672271
struct pt_regs *regs = (struct pt_regs *)
22682272
(sp + STACK_INT_FRAME_REGS);

0 commit comments

Comments
 (0)