diff options
author | Alexey Dobriyan <adobriyan@gmail.com> | 2007-07-17 07:03:44 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-07-17 13:23:03 -0400 |
commit | f284ce7269031947326bac6bb19a977705276222 (patch) | |
tree | 8b145d42d4da182fb185dacc53b24ca7a2546114 /arch/s390 | |
parent | 7664732315c97f48dba9d1e7339ad16fc5a320ac (diff) |
PTRACE_POKEDATA consolidation
Identical implementations of PTRACE_POKEDATA go into generic_ptrace_pokedata()
function.
AFAICS, fix bug on xtensa where successful PTRACE_POKEDATA will nevertheless
return EPERM.
Signed-off-by: Alexey Dobriyan <adobriyan@gmail.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: <linux-arch@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/s390')
-rw-r--r-- | arch/s390/kernel/ptrace.c | 5 |
1 files changed, 1 insertions, 4 deletions
diff --git a/arch/s390/kernel/ptrace.c b/arch/s390/kernel/ptrace.c index 28afff4e5d1b..f4503ca27630 100644 --- a/arch/s390/kernel/ptrace.c +++ b/arch/s390/kernel/ptrace.c | |||
@@ -314,10 +314,7 @@ do_ptrace_normal(struct task_struct *child, long request, long addr, long data) | |||
314 | /* Remove high order bit from address (only for 31 bit). */ | 314 | /* Remove high order bit from address (only for 31 bit). */ |
315 | addr &= PSW_ADDR_INSN; | 315 | addr &= PSW_ADDR_INSN; |
316 | /* write the word at location addr. */ | 316 | /* write the word at location addr. */ |
317 | copied = access_process_vm(child, addr, &data, sizeof(data),1); | 317 | return generic_ptrace_pokedata(child, addr, data); |
318 | if (copied != sizeof(data)) | ||
319 | return -EIO; | ||
320 | return 0; | ||
321 | 318 | ||
322 | case PTRACE_POKEUSR: | 319 | case PTRACE_POKEUSR: |
323 | /* write the word at location addr in the USER area */ | 320 | /* write the word at location addr in the USER area */ |