Skip to content

Commit

Permalink
Added ptrace::kill
Browse files Browse the repository at this point in the history
Just to check it's not actually different
  • Loading branch information
xd009642 committed Oct 10, 2018
1 parent 1918a7d commit 1bca5fc
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 2 deletions.
8 changes: 8 additions & 0 deletions src/sys/ptrace/bsd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,14 @@ pub fn cont<T: Into<Option<Signal>>>(pid: Pid, sig: T) -> Result<()> {
}
}

/// Issues a kill request as with ptrace(PT_KILL, ..-)
/// This request is equivalent to ptrace(PT_CONTINUE, ..., SIGKILL);
pub fn kill(pid: Pid) -> Result<()> {
unsafe {
ptrace_other(Request::PT_KILL, pid, 0 as AddressType, 0).map(|_| ())
}
}

/// Move the stopped tracee process forward by a single step as with
/// `ptrace(PT_STEP, ...)`
///
Expand Down
9 changes: 9 additions & 0 deletions src/sys/ptrace/linux.rs
Original file line number Diff line number Diff line change
Expand Up @@ -320,6 +320,15 @@ pub fn cont<T: Into<Option<Signal>>>(pid: Pid, sig: T) -> Result<()> {
}
}


/// Issues a kill request as with ptrace(PTRACE_KILL, ..-)
/// This request is equivalent to ptrace(PTRACE_CONT, ..., SIGKILL);
pub fn kill(pid: Pid) -> Result<()> {
unsafe {
ptrace_other(Request::PTRACE_KILL, pid, ptr::null_mut(), ptr::null_mut()).map(|_| ())
}
}

/// Move the stopped tracee process forward by a single step as with
/// `ptrace(PTRACE_SINGLESTEP, ...)`
///
Expand Down
4 changes: 2 additions & 2 deletions test/sys/test_ptrace.rs
Original file line number Diff line number Diff line change
Expand Up @@ -87,14 +87,14 @@ fn test_ptrace_cont() {
assert_eq!(waitpid(child, None), Ok(WaitStatus::Stopped(child, Signal::SIGTRAP)));
ptrace::cont(child, None).unwrap();
assert_eq!(waitpid(child, None), Ok(WaitStatus::Stopped(child, Signal::SIGTRAP)));
ptrace::cont(child, Signal::SIGKILL).unwrap();
ptrace::kill(pid).unwrap();
match waitpid(child, None) {
Ok(WaitStatus::Signaled(pid, Signal::SIGKILL, _)) if pid == child => {
// Some systems require the tracee is in
// signal-delivery-stop otherwise the signal is discarded
// and the tracee doesn't actually get killed despite
// receiving the signal
let _ = kill(child, None);
//let _ = kill(child, None);
}
_ => panic!("The process should have been killed"),
}
Expand Down

0 comments on commit 1bca5fc

Please sign in to comment.