mirror of
https://github.com/torvalds/linux.git
synced 2024-12-23 11:21:33 +00:00
d9a89a26e0
Impact: cleanup On x86_32, %gs is handled lazily. It's not saved and restored on kernel entry/exit but only when necessary which usually is during task switch but there are few other places. Currently, it's done by calling savesegment() and loadsegment() explicitly. Define get_user_gs(), set_user_gs() and task_user_gs() and use them instead. While at it, clean up register access macros in signal.c. This cleans up code a bit and will help future changes. Signed-off-by: Tejun Heo <tj@kernel.org> Signed-off-by: Ingo Molnar <mingo@elte.hu>
72 lines
2.1 KiB
C
72 lines
2.1 KiB
C
/* a.out coredump register dumper
|
|
*
|
|
* Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
|
|
* Written by David Howells (dhowells@redhat.com)
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public Licence
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the Licence, or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _ASM_X86_A_OUT_CORE_H
|
|
#define _ASM_X86_A_OUT_CORE_H
|
|
|
|
#ifdef __KERNEL__
|
|
#ifdef CONFIG_X86_32
|
|
|
|
#include <linux/user.h>
|
|
#include <linux/elfcore.h>
|
|
|
|
/*
|
|
* fill in the user structure for an a.out core dump
|
|
*/
|
|
static inline void aout_dump_thread(struct pt_regs *regs, struct user *dump)
|
|
{
|
|
/* changed the size calculations - should hopefully work better. lbt */
|
|
dump->magic = CMAGIC;
|
|
dump->start_code = 0;
|
|
dump->start_stack = regs->sp & ~(PAGE_SIZE - 1);
|
|
dump->u_tsize = ((unsigned long)current->mm->end_code) >> PAGE_SHIFT;
|
|
dump->u_dsize = ((unsigned long)(current->mm->brk + (PAGE_SIZE - 1)))
|
|
>> PAGE_SHIFT;
|
|
dump->u_dsize -= dump->u_tsize;
|
|
dump->u_ssize = 0;
|
|
dump->u_debugreg[0] = current->thread.debugreg0;
|
|
dump->u_debugreg[1] = current->thread.debugreg1;
|
|
dump->u_debugreg[2] = current->thread.debugreg2;
|
|
dump->u_debugreg[3] = current->thread.debugreg3;
|
|
dump->u_debugreg[4] = 0;
|
|
dump->u_debugreg[5] = 0;
|
|
dump->u_debugreg[6] = current->thread.debugreg6;
|
|
dump->u_debugreg[7] = current->thread.debugreg7;
|
|
|
|
if (dump->start_stack < TASK_SIZE)
|
|
dump->u_ssize = ((unsigned long)(TASK_SIZE - dump->start_stack))
|
|
>> PAGE_SHIFT;
|
|
|
|
dump->regs.bx = regs->bx;
|
|
dump->regs.cx = regs->cx;
|
|
dump->regs.dx = regs->dx;
|
|
dump->regs.si = regs->si;
|
|
dump->regs.di = regs->di;
|
|
dump->regs.bp = regs->bp;
|
|
dump->regs.ax = regs->ax;
|
|
dump->regs.ds = (u16)regs->ds;
|
|
dump->regs.es = (u16)regs->es;
|
|
dump->regs.fs = (u16)regs->fs;
|
|
dump->regs.gs = get_user_gs(regs);
|
|
dump->regs.orig_ax = regs->orig_ax;
|
|
dump->regs.ip = regs->ip;
|
|
dump->regs.cs = (u16)regs->cs;
|
|
dump->regs.flags = regs->flags;
|
|
dump->regs.sp = regs->sp;
|
|
dump->regs.ss = (u16)regs->ss;
|
|
|
|
dump->u_fpvalid = dump_fpu(regs, &dump->i387);
|
|
}
|
|
|
|
#endif /* CONFIG_X86_32 */
|
|
#endif /* __KERNEL__ */
|
|
#endif /* _ASM_X86_A_OUT_CORE_H */
|