diff options
Diffstat (limited to 'arch/ia64/kernel/ptrace.c')
-rw-r--r-- | arch/ia64/kernel/ptrace.c | 42 |
1 files changed, 3 insertions, 39 deletions
diff --git a/arch/ia64/kernel/ptrace.c b/arch/ia64/kernel/ptrace.c index e82fe296c2c0..1dfff5a8f365 100644 --- a/arch/ia64/kernel/ptrace.c +++ b/arch/ia64/kernel/ptrace.c | |||
@@ -1470,46 +1470,13 @@ ptrace_disable (struct task_struct *child) | |||
1470 | child_psr->tb = 0; | 1470 | child_psr->tb = 0; |
1471 | } | 1471 | } |
1472 | 1472 | ||
1473 | asmlinkage long | 1473 | long |
1474 | sys_ptrace (long request, pid_t pid, unsigned long addr, unsigned long data) | 1474 | arch_ptrace (struct task_struct *child, long request, long addr, long data) |
1475 | { | 1475 | { |
1476 | struct pt_regs *pt; | 1476 | struct pt_regs *pt; |
1477 | struct task_struct *child; | ||
1478 | struct switch_stack *sw; | 1477 | struct switch_stack *sw; |
1479 | long ret; | 1478 | long ret; |
1480 | 1479 | ||
1481 | lock_kernel(); | ||
1482 | ret = -EPERM; | ||
1483 | if (request == PTRACE_TRACEME) { | ||
1484 | ret = ptrace_traceme(); | ||
1485 | goto out; | ||
1486 | } | ||
1487 | |||
1488 | ret = -ESRCH; | ||
1489 | read_lock(&tasklist_lock); | ||
1490 | { | ||
1491 | child = find_task_by_pid(pid); | ||
1492 | if (child) | ||
1493 | get_task_struct(child); | ||
1494 | } | ||
1495 | read_unlock(&tasklist_lock); | ||
1496 | if (!child) | ||
1497 | goto out; | ||
1498 | ret = -EPERM; | ||
1499 | if (pid == 1) /* no messing around with init! */ | ||
1500 | goto out_tsk; | ||
1501 | |||
1502 | if (request == PTRACE_ATTACH) { | ||
1503 | ret = ptrace_attach(child); | ||
1504 | if (!ret) | ||
1505 | arch_ptrace_attach(child); | ||
1506 | goto out_tsk; | ||
1507 | } | ||
1508 | |||
1509 | ret = ptrace_check_attach(child, request == PTRACE_KILL); | ||
1510 | if (ret < 0) | ||
1511 | goto out_tsk; | ||
1512 | |||
1513 | pt = task_pt_regs(child); | 1480 | pt = task_pt_regs(child); |
1514 | sw = (struct switch_stack *) (child->thread.ksp + 16); | 1481 | sw = (struct switch_stack *) (child->thread.ksp + 16); |
1515 | 1482 | ||
@@ -1594,7 +1561,7 @@ sys_ptrace (long request, pid_t pid, unsigned long addr, unsigned long data) | |||
1594 | */ | 1561 | */ |
1595 | if (child->exit_state == EXIT_ZOMBIE) | 1562 | if (child->exit_state == EXIT_ZOMBIE) |
1596 | /* already dead */ | 1563 | /* already dead */ |
1597 | goto out_tsk; | 1564 | return 0; |
1598 | child->exit_code = SIGKILL; | 1565 | child->exit_code = SIGKILL; |
1599 | 1566 | ||
1600 | ptrace_disable(child); | 1567 | ptrace_disable(child); |
@@ -1643,9 +1610,6 @@ sys_ptrace (long request, pid_t pid, unsigned long addr, unsigned long data) | |||
1643 | goto out_tsk; | 1610 | goto out_tsk; |
1644 | } | 1611 | } |
1645 | out_tsk: | 1612 | out_tsk: |
1646 | put_task_struct(child); | ||
1647 | out: | ||
1648 | unlock_kernel(); | ||
1649 | return ret; | 1613 | return ret; |
1650 | } | 1614 | } |
1651 | 1615 | ||