Rollup merge of #132355 - practicalrs:fix_117638, r=SparrowLii
Fix compiler panic with a large number of threads Hi, This PR is an attempt to fix the problem described here https://github.com/rust-lang/rust/issues/117638 using the solution suggested in this comment https://github.com/rust-lang/rust/issues/117638#issuecomment-1800925067 Best regards, Michal
This commit is contained in:
commit
31ad4e4a54
2 changed files with 12 additions and 3 deletions
|
@ -2466,6 +2466,10 @@ pub fn build_session_options(early_dcx: &mut EarlyDiagCtxt, matches: &getopts::M
|
||||||
early_dcx.early_fatal("value for threads must be a positive non-zero integer");
|
early_dcx.early_fatal("value for threads must be a positive non-zero integer");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if unstable_opts.threads == parse::MAX_THREADS_CAP {
|
||||||
|
early_dcx.early_warn(format!("number of threads was capped at {}", parse::MAX_THREADS_CAP));
|
||||||
|
}
|
||||||
|
|
||||||
let fuel = unstable_opts.fuel.is_some() || unstable_opts.print_fuel.is_some();
|
let fuel = unstable_opts.fuel.is_some() || unstable_opts.print_fuel.is_some();
|
||||||
if fuel && unstable_opts.threads > 1 {
|
if fuel && unstable_opts.threads > 1 {
|
||||||
early_dcx.early_fatal("optimization fuel is incompatible with multiple threads");
|
early_dcx.early_fatal("optimization fuel is incompatible with multiple threads");
|
||||||
|
|
|
@ -457,10 +457,11 @@ mod desc {
|
||||||
"either a boolean (`yes`, `no`, `on`, `off`, etc), or `nll` (default: `nll`)";
|
"either a boolean (`yes`, `no`, `on`, `off`, etc), or `nll` (default: `nll`)";
|
||||||
}
|
}
|
||||||
|
|
||||||
mod parse {
|
pub mod parse {
|
||||||
use std::str::FromStr;
|
use std::str::FromStr;
|
||||||
|
|
||||||
pub(crate) use super::*;
|
pub(crate) use super::*;
|
||||||
|
pub(crate) const MAX_THREADS_CAP: usize = 256;
|
||||||
|
|
||||||
/// This is for boolean options that don't take a value and start with
|
/// This is for boolean options that don't take a value and start with
|
||||||
/// `no-`. This style of option is deprecated.
|
/// `no-`. This style of option is deprecated.
|
||||||
|
@ -657,7 +658,7 @@ mod parse {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn parse_threads(slot: &mut usize, v: Option<&str>) -> bool {
|
pub(crate) fn parse_threads(slot: &mut usize, v: Option<&str>) -> bool {
|
||||||
match v.and_then(|s| s.parse().ok()) {
|
let ret = match v.and_then(|s| s.parse().ok()) {
|
||||||
Some(0) => {
|
Some(0) => {
|
||||||
*slot = std::thread::available_parallelism().map_or(1, NonZero::<usize>::get);
|
*slot = std::thread::available_parallelism().map_or(1, NonZero::<usize>::get);
|
||||||
true
|
true
|
||||||
|
@ -667,7 +668,11 @@ mod parse {
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
None => false,
|
None => false,
|
||||||
}
|
};
|
||||||
|
// We want to cap the number of threads here to avoid large numbers like 999999 and compiler panics.
|
||||||
|
// This solution was suggested here https://github.com/rust-lang/rust/issues/117638#issuecomment-1800925067
|
||||||
|
*slot = slot.clone().min(MAX_THREADS_CAP);
|
||||||
|
ret
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Use this for any numeric option that has a static default.
|
/// Use this for any numeric option that has a static default.
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue