diff options
Diffstat (limited to 'arch/x86/kernel/ptrace.c')
| -rw-r--r-- | arch/x86/kernel/ptrace.c | 14 | 
1 files changed, 7 insertions, 7 deletions
| diff --git a/arch/x86/kernel/ptrace.c b/arch/x86/kernel/ptrace.c index f79576a541ff..0e63c0267f99 100644 --- a/arch/x86/kernel/ptrace.c +++ b/arch/x86/kernel/ptrace.c @@ -173,8 +173,8 @@ unsigned long kernel_stack_pointer(struct pt_regs *regs)  		return sp;  	prev_esp = (u32 *)(context); -	if (prev_esp) -		return (unsigned long)prev_esp; +	if (*prev_esp) +		return (unsigned long)*prev_esp;  	return (unsigned long)regs;  } @@ -934,7 +934,7 @@ static int putreg32(struct task_struct *child, unsigned regno, u32 value)  		 */  		regs->orig_ax = value;  		if (syscall_get_nr(child, regs) >= 0) -			task_thread_info(child)->status |= TS_I386_REGS_POKED; +			child->thread.status |= TS_I386_REGS_POKED;  		break;  	case offsetof(struct user32, regs.eflags): @@ -1250,7 +1250,7 @@ long compat_arch_ptrace(struct task_struct *child, compat_long_t request,  #ifdef CONFIG_X86_64 -static struct user_regset x86_64_regsets[] __read_mostly = { +static struct user_regset x86_64_regsets[] __ro_after_init = {  	[REGSET_GENERAL] = {  		.core_note_type = NT_PRSTATUS,  		.n = sizeof(struct user_regs_struct) / sizeof(long), @@ -1291,7 +1291,7 @@ static const struct user_regset_view user_x86_64_view = {  #endif	/* CONFIG_X86_64 */  #if defined CONFIG_X86_32 || defined CONFIG_IA32_EMULATION -static struct user_regset x86_32_regsets[] __read_mostly = { +static struct user_regset x86_32_regsets[] __ro_after_init = {  	[REGSET_GENERAL] = {  		.core_note_type = NT_PRSTATUS,  		.n = sizeof(struct user_regs_struct32) / sizeof(u32), @@ -1344,7 +1344,7 @@ static const struct user_regset_view user_x86_32_view = {   */  u64 xstate_fx_sw_bytes[USER_XSTATE_FX_SW_WORDS]; -void update_regset_xstate_info(unsigned int size, u64 xstate_mask) +void __init update_regset_xstate_info(unsigned int size, u64 xstate_mask)  {  #ifdef CONFIG_X86_64  	x86_64_regsets[REGSET_XSTATE].n = size / sizeof(u64); @@ -1358,7 +1358,7 @@ void update_regset_xstate_info(unsigned int size, u64 xstate_mask)  const struct user_regset_view *task_user_regset_view(struct task_struct *task)  {  #ifdef CONFIG_IA32_EMULATION -	if (test_tsk_thread_flag(task, TIF_IA32)) +	if (!user_64bit_mode(task_pt_regs(task)))  #endif  #if defined CONFIG_X86_32 || defined CONFIG_IA32_EMULATION  		return &user_x86_32_view; |