mirror of https://github.com/rust-lang/rust.git
Rollup merge of #115946 - the8472:panic-on-sched_getaffinity-bug, r=Mark-Simulacrum
panic when encountering an illegal cpumask in thread::available_parallelism Fixes #115868 by panicking instead of returning an invalid `NonZeroUsize`
This commit is contained in:
commit
57f1f91a9c
|
@ -324,8 +324,10 @@ pub fn available_parallelism() -> io::Result<NonZeroUsize> {
|
|||
if libc::sched_getaffinity(0, mem::size_of::<libc::cpu_set_t>(), &mut set) == 0 {
|
||||
let count = libc::CPU_COUNT(&set) as usize;
|
||||
let count = count.min(quota);
|
||||
// SAFETY: affinity mask can't be empty and the quota gets clamped to a minimum of 1
|
||||
return Ok(NonZeroUsize::new_unchecked(count));
|
||||
// reported to occur on MIPS kernels older than our minimum supported kernel version for those targets
|
||||
let count = NonZeroUsize::new(count)
|
||||
.expect("CPU count must be > 0. This may be a bug in sched_getaffinity(); try upgrading the kernel.");
|
||||
return Ok(count);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue