diff options
| author | Daniel Jacobowitz <drow@nevyn.them.org> | 2002-10-29 12:50:51 -0500 |
|---|---|---|
| committer | Daniel Jacobowitz <drow@nevyn.them.org> | 2002-10-29 12:50:51 -0500 |
| commit | e3e8889df67f4d6ce595329ed4afa81c9a0938ca (patch) | |
| tree | 8e806d3d39583fa61d99ab12e60e53ed05a31388 /kernel | |
| parent | 159ecf449ccc0382a3c3cd1102b2da590eb44ba2 (diff) | |
| parent | c7c1b99ba5db53032a4ff4feac8c6eae8ecba25a (diff) | |
Merge nevyn.them.org:/nevyn/big/kernel/linux-2.5
into nevyn.them.org:/nevyn/big/kernel/test/linux-2.5-trace1
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/ptrace.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/kernel/ptrace.c b/kernel/ptrace.c index cc7a76bb65b7..ab3aa39a38cf 100644 --- a/kernel/ptrace.c +++ b/kernel/ptrace.c @@ -248,3 +248,35 @@ int ptrace_writedata(struct task_struct *tsk, char * src, unsigned long dst, int } return copied; } + +int ptrace_setoptions(struct task_struct *child, long data) +{ + if (data & PTRACE_O_TRACESYSGOOD) + child->ptrace |= PT_TRACESYSGOOD; + else + child->ptrace &= ~PT_TRACESYSGOOD; + + if ((data & PTRACE_O_TRACESYSGOOD) != data) + return -EINVAL; + + return 0; +} + +int ptrace_request(struct task_struct *child, long request, + long addr, long data) +{ + int ret = -EIO; + + switch (request) { +#ifdef PTRACE_OLDSETOPTIONS + case PTRACE_OLDSETOPTIONS: +#endif + case PTRACE_SETOPTIONS: + ret = ptrace_setoptions(child, data); + break; + default: + break; + } + + return ret; +} |
