Auto merge of #121909 - Zoxc:drop-ast-task, r=petrochenkov
Drop AST on a separate thread and prefetch `hir_crate` This drop AST on a separate thread and prefetches `hir_crate`. A `spawn` function is added to the `parallel` module which spawn some work on the Rayon thread pool.
This commit is contained in:
@@ -49,6 +49,7 @@ use rustc_attr_parsing::{AttributeParser, OmitDoc};
|
|||||||
use rustc_data_structures::fingerprint::Fingerprint;
|
use rustc_data_structures::fingerprint::Fingerprint;
|
||||||
use rustc_data_structures::sorted_map::SortedMap;
|
use rustc_data_structures::sorted_map::SortedMap;
|
||||||
use rustc_data_structures::stable_hasher::{HashStable, StableHasher};
|
use rustc_data_structures::stable_hasher::{HashStable, StableHasher};
|
||||||
|
use rustc_data_structures::sync::spawn;
|
||||||
use rustc_data_structures::tagged_ptr::TaggedRef;
|
use rustc_data_structures::tagged_ptr::TaggedRef;
|
||||||
use rustc_errors::{DiagArgFromDisplay, DiagCtxtHandle, StashKey};
|
use rustc_errors::{DiagArgFromDisplay, DiagCtxtHandle, StashKey};
|
||||||
use rustc_hir::def::{DefKind, LifetimeRes, Namespace, PartialRes, PerNS, Res};
|
use rustc_hir::def::{DefKind, LifetimeRes, Namespace, PartialRes, PerNS, Res};
|
||||||
@@ -454,9 +455,14 @@ pub fn lower_to_hir(tcx: TyCtxt<'_>, (): ()) -> hir::Crate<'_> {
|
|||||||
.lower_node(def_id);
|
.lower_node(def_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Drop AST to free memory
|
|
||||||
drop(ast_index);
|
drop(ast_index);
|
||||||
sess.time("drop_ast", || drop(krate));
|
|
||||||
|
// Drop AST to free memory. It can be expensive so try to drop it on a separate thread.
|
||||||
|
let prof = sess.prof.clone();
|
||||||
|
spawn(move || {
|
||||||
|
let _timer = prof.verbose_generic_activity("drop_ast");
|
||||||
|
drop(krate);
|
||||||
|
});
|
||||||
|
|
||||||
// Don't hash unless necessary, because it's expensive.
|
// Don't hash unless necessary, because it's expensive.
|
||||||
let opt_hir_hash =
|
let opt_hir_hash =
|
||||||
|
|||||||
@@ -43,7 +43,7 @@ pub use self::freeze::{FreezeLock, FreezeReadGuard, FreezeWriteGuard};
|
|||||||
pub use self::lock::{Lock, LockGuard, Mode};
|
pub use self::lock::{Lock, LockGuard, Mode};
|
||||||
pub use self::mode::{is_dyn_thread_safe, set_dyn_thread_safe_mode};
|
pub use self::mode::{is_dyn_thread_safe, set_dyn_thread_safe_mode};
|
||||||
pub use self::parallel::{
|
pub use self::parallel::{
|
||||||
join, par_for_each_in, par_map, parallel_guard, scope, try_par_for_each_in,
|
join, par_for_each_in, par_map, parallel_guard, scope, spawn, try_par_for_each_in,
|
||||||
};
|
};
|
||||||
pub use self::vec::{AppendOnlyIndexVec, AppendOnlyVec};
|
pub use self::vec::{AppendOnlyIndexVec, AppendOnlyVec};
|
||||||
pub use self::worker_local::{Registry, WorkerLocal};
|
pub use self::worker_local::{Registry, WorkerLocal};
|
||||||
|
|||||||
@@ -93,6 +93,17 @@ macro_rules! parallel {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn spawn(func: impl FnOnce() + DynSend + 'static) {
|
||||||
|
if mode::is_dyn_thread_safe() {
|
||||||
|
let func = FromDyn::from(func);
|
||||||
|
rayon_core::spawn(|| {
|
||||||
|
(func.into_inner())();
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
func()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// This function only works when `mode::is_dyn_thread_safe()`.
|
// This function only works when `mode::is_dyn_thread_safe()`.
|
||||||
pub fn scope<'scope, OP, R>(op: OP) -> R
|
pub fn scope<'scope, OP, R>(op: OP) -> R
|
||||||
where
|
where
|
||||||
|
|||||||
@@ -900,6 +900,12 @@ fn run_required_analyses(tcx: TyCtxt<'_>) {
|
|||||||
// is not defined. So we need to cfg it out.
|
// is not defined. So we need to cfg it out.
|
||||||
#[cfg(all(not(doc), debug_assertions))]
|
#[cfg(all(not(doc), debug_assertions))]
|
||||||
rustc_passes::hir_id_validator::check_crate(tcx);
|
rustc_passes::hir_id_validator::check_crate(tcx);
|
||||||
|
|
||||||
|
// Prefetch this to prevent multiple threads from blocking on it later.
|
||||||
|
// This is needed since the `hir_id_validator::check_crate` call above is not guaranteed
|
||||||
|
// to use `hir_crate`.
|
||||||
|
tcx.ensure_done().hir_crate(());
|
||||||
|
|
||||||
let sess = tcx.sess;
|
let sess = tcx.sess;
|
||||||
sess.time("misc_checking_1", || {
|
sess.time("misc_checking_1", || {
|
||||||
parallel!(
|
parallel!(
|
||||||
|
|||||||
Reference in New Issue
Block a user