mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-15 08:14:15 +08:00
e8012b584f
Handle floating point state better in ptrace. The code now correctly distinguishes between PTRACE_[GS]ETFPREGS and PTRACE_[GS]ETFPXREGS. The FPX requests get handed off to arch-specific code because that's not generic. get_fpregs, set_fpregs, set_fpregs, and set_fpxregs needed real implementations. Something here exposed a missing include in asm/page.h, which needed linux/types.h in order to get gfp_t, so that's fixed here. Signed-off-by: Jeff Dike <jdike@linux.intel.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
59 lines
1.6 KiB
C
59 lines
1.6 KiB
C
/*
|
|
* Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
|
|
* Licensed under the GPL
|
|
*/
|
|
|
|
#ifndef __UM_PTRACE_GENERIC_H
|
|
#define __UM_PTRACE_GENERIC_H
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
#include "asm/arch/ptrace-abi.h"
|
|
#include <asm/user.h>
|
|
#include "sysdep/ptrace.h"
|
|
|
|
struct pt_regs {
|
|
struct uml_pt_regs regs;
|
|
};
|
|
|
|
#define EMPTY_REGS { .regs = EMPTY_UML_PT_REGS }
|
|
|
|
#define PT_REGS_IP(r) UPT_IP(&(r)->regs)
|
|
#define PT_REGS_SP(r) UPT_SP(&(r)->regs)
|
|
|
|
#define PT_REG(r, reg) UPT_REG(&(r)->regs, reg)
|
|
#define PT_REGS_SET(r, reg, val) UPT_SET(&(r)->regs, reg, val)
|
|
|
|
#define PT_REGS_SET_SYSCALL_RETURN(r, res) \
|
|
UPT_SET_SYSCALL_RETURN(&(r)->regs, res)
|
|
#define PT_REGS_RESTART_SYSCALL(r) UPT_RESTART_SYSCALL(&(r)->regs)
|
|
|
|
#define PT_REGS_SYSCALL_NR(r) UPT_SYSCALL_NR(&(r)->regs)
|
|
|
|
#define PT_REGS_SC(r) UPT_SC(&(r)->regs)
|
|
|
|
#define instruction_pointer(regs) PT_REGS_IP(regs)
|
|
|
|
struct task_struct;
|
|
|
|
extern long subarch_ptrace(struct task_struct *child, long request, long addr,
|
|
long data);
|
|
extern unsigned long getreg(struct task_struct *child, int regno);
|
|
extern int putreg(struct task_struct *child, int regno, unsigned long value);
|
|
extern int get_fpregs(struct user_i387_struct __user *buf,
|
|
struct task_struct *child);
|
|
extern int set_fpregs(struct user_i387_struct __user *buf,
|
|
struct task_struct *child);
|
|
|
|
extern void show_regs(struct pt_regs *regs);
|
|
|
|
extern void send_sigtrap(struct task_struct *tsk, struct uml_pt_regs *regs,
|
|
int error_code);
|
|
|
|
extern int arch_copy_tls(struct task_struct *new);
|
|
extern void clear_flushed_tls(struct task_struct *task);
|
|
|
|
#endif
|
|
|
|
#endif
|