Check whether clone3 syscall exists in pidfd test
This commit is contained in:
parent
2a4d012103
commit
4a832d32f2
1 changed files with 19 additions and 1 deletions
|
@ -2,10 +2,28 @@
|
||||||
// only-linux - pidfds are a linux-specific concept
|
// only-linux - pidfds are a linux-specific concept
|
||||||
|
|
||||||
#![feature(linux_pidfd)]
|
#![feature(linux_pidfd)]
|
||||||
use std::os::linux::process::{CommandExt, ChildExt};
|
#![feature(rustc_private)]
|
||||||
|
|
||||||
|
extern crate libc;
|
||||||
|
|
||||||
|
use std::io::Error;
|
||||||
|
use std::os::linux::process::{ChildExt, CommandExt};
|
||||||
use std::process::Command;
|
use std::process::Command;
|
||||||
|
|
||||||
|
fn has_clone3() -> bool {
|
||||||
|
let res = unsafe { libc::syscall(libc::SYS_clone3, 0, 0) };
|
||||||
|
let err = (res == -1)
|
||||||
|
.then(|| Error::last_os_error())
|
||||||
|
.expect("probe syscall should not succeed");
|
||||||
|
err.raw_os_error() != Some(libc::ENOSYS)
|
||||||
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
// pidfds require the clone3 syscall
|
||||||
|
if !has_clone3() {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// We don't assert the precise value, since the standard library
|
// We don't assert the precise value, since the standard library
|
||||||
// might have opened other file descriptors before our code runs.
|
// might have opened other file descriptors before our code runs.
|
||||||
let _ = Command::new("echo")
|
let _ = Command::new("echo")
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue