From 4f5355a61e167b282150aeefb2ca63042868987e Mon Sep 17 00:00:00 2001 From: oksbsb Date: Mon, 4 Dec 2023 15:09:59 +0800 Subject: [PATCH] fix jobserver GLOBAL_CLIENT_CHECKED uninitialized before use --- compiler/rustc_data_structures/src/jobserver.rs | 2 +- compiler/rustc_interface/src/interface.rs | 4 ++++ compiler/rustc_interface/src/tests.rs | 3 +++ compiler/rustc_session/src/session.rs | 12 +++++++----- 4 files changed, 15 insertions(+), 6 deletions(-) diff --git a/compiler/rustc_data_structures/src/jobserver.rs b/compiler/rustc_data_structures/src/jobserver.rs index b777bfd4d3c9..412e33aaa655 100644 --- a/compiler/rustc_data_structures/src/jobserver.rs +++ b/compiler/rustc_data_structures/src/jobserver.rs @@ -52,7 +52,7 @@ fn default_client() -> Client { static GLOBAL_CLIENT_CHECKED: OnceLock = OnceLock::new(); -pub fn check(report_warning: impl FnOnce(&'static str)) { +pub fn initialize_checked(report_warning: impl FnOnce(&'static str)) { let client_checked = match &*GLOBAL_CLIENT { Ok(client) => client.clone(), Err(e) => { diff --git a/compiler/rustc_interface/src/interface.rs b/compiler/rustc_interface/src/interface.rs index 8a6d8d3d42e2..0acc901d38f1 100644 --- a/compiler/rustc_interface/src/interface.rs +++ b/compiler/rustc_interface/src/interface.rs @@ -382,6 +382,10 @@ pub fn run_compiler(config: Config, f: impl FnOnce(&Compiler) -> R + Se // Set parallel mode before thread pool creation, which will create `Lock`s. rustc_data_structures::sync::set_dyn_thread_safe_mode(config.opts.unstable_opts.threads > 1); + // Check jobserver before run_in_thread_pool_with_globals, which call jobserver::acquire_thread + let handler = EarlyErrorHandler::new(config.opts.error_format); + handler.initialize_checked_jobserver(); + util::run_in_thread_pool_with_globals( config.opts.edition, config.opts.unstable_opts.threads, diff --git a/compiler/rustc_interface/src/tests.rs b/compiler/rustc_interface/src/tests.rs index 714af977fb5d..26db399ce9ae 100644 --- a/compiler/rustc_interface/src/tests.rs +++ b/compiler/rustc_interface/src/tests.rs @@ -36,6 +36,9 @@ fn mk_session(handler: &mut EarlyErrorHandler, matches: getopts::Matches) -> (Se output_file: None, temps_dir, }; + + handler.initialize_checked_jobserver(); + let sess = build_session( handler, sessopts, diff --git a/compiler/rustc_session/src/session.rs b/compiler/rustc_session/src/session.rs index 57a535d8c105..74de77c31100 100644 --- a/compiler/rustc_session/src/session.rs +++ b/compiler/rustc_session/src/session.rs @@ -1469,11 +1469,6 @@ pub fn build_session( let asm_arch = if target_cfg.allow_asm { InlineAsmArch::from_str(&target_cfg.arch).ok() } else { None }; - // Check jobserver before getting `jobserver::client`. - jobserver::check(|err| { - handler.early_warn_with_note(err, "the build environment is likely misconfigured") - }); - let sess = Session { target: target_cfg, host, @@ -1791,6 +1786,13 @@ impl EarlyErrorHandler { ) { self.handler.struct_warn(msg).note(note).emit() } + + pub fn initialize_checked_jobserver(&self) { + // initialize jobserver before getting `jobserver::client` and `build_session`. + jobserver::initialize_checked(|err| { + self.early_warn_with_note(err, "the build environment is likely misconfigured") + }); + } } fn mk_emitter(output: ErrorOutputType) -> Box {