Skip to main content

rustc_query_impl/
execution.rs

1use std::hash::Hash;
2use std::mem::ManuallyDrop;
3
4use rustc_data_structures::hash_table::{Entry, HashTable};
5use rustc_data_structures::stack::ensure_sufficient_stack;
6use rustc_data_structures::sync::{DynSend, DynSync};
7use rustc_data_structures::{defer, outline, sharded, sync};
8use rustc_errors::FatalError;
9use rustc_middle::dep_graph::{DepGraphData, DepNodeKey, SerializedDepNodeIndex};
10use rustc_middle::query::{
11    ActiveKeyStatus, Cycle, EnsureMode, QueryCache, QueryJob, QueryJobId, QueryKey, QueryLatch,
12    QueryMode, QueryState, QueryVTable,
13};
14use rustc_middle::ty::TyCtxt;
15use rustc_middle::verify_ich::incremental_verify_ich;
16use rustc_span::{DUMMY_SP, Span};
17use tracing::debug;
18
19use crate::dep_graph::{DepNode, DepNodeIndex};
20use crate::handle_cycle_error;
21use crate::job::{QueryJobInfo, QueryJobMap, create_cycle_error, find_cycle_in_stack};
22use crate::plumbing::{current_query_job, loadable_from_disk, next_job_id, start_query};
23use crate::query_impl::for_each_query_vtable;
24
25#[inline]
26fn equivalent_key<K: Eq, V>(k: K) -> impl Fn(&(K, V)) -> bool {
27    move |x| x.0 == k
28}
29
30pub(crate) fn all_inactive<'tcx, K>(state: &QueryState<'tcx, K>) -> bool {
31    state.active.lock_shards().all(|shard| shard.is_empty())
32}
33
34#[derive(#[automatically_derived]
impl ::core::clone::Clone for CollectActiveJobsKind {
    #[inline]
    fn clone(&self) -> CollectActiveJobsKind { *self }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for CollectActiveJobsKind { }Copy)]
35pub enum CollectActiveJobsKind {
36    /// We need the full query job map, and we are willing to wait to obtain the query state
37    /// shard lock(s).
38    Full,
39
40    /// We need the full query job map, and we shouldn't need to wait to obtain the shard lock(s),
41    /// because we are in a place where nothing else could hold the shard lock(s).
42    FullNoContention,
43
44    /// We can get by without the full query job map, so we won't bother waiting to obtain the
45    /// shard lock(s) if they're not already unlocked.
46    PartialAllowed,
47}
48
49/// Returns a map of currently active query jobs, collected from all queries.
50pub fn collect_active_query_jobs<'tcx>(
51    tcx: TyCtxt<'tcx>,
52    collect_kind: CollectActiveJobsKind,
53) -> QueryJobMap<'tcx> {
54    let mut job_map = QueryJobMap::default();
55
56    {
    let tcx: rustc_middle::ty::TyCtxt<'_> = tcx;
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.derive_macro_expansion;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.trigger_delayed_bug;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.registered_tools;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.early_lint_checks;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.env_var_os;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.resolutions;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.resolver_for_lowering_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.source_span;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.hir_crate;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lower_delayed_owner;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.hir_owner;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.hir_delayed_owner;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.hir_crate_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.hir_module_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.hir_owner_parent_q;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.hir_attr_map;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.const_param_default;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.const_of_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_of_opaque;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_of_opaque_hir_typeck;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_alias_is_lazy;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.collect_return_position_impl_trait_in_trait_tys;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.opaque_ty_origin;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.unsizing_params_for_adt;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.analysis;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_expectations;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.generics_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.predicates_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.opaque_types_defined_by;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.nested_bodies_within;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.explicit_item_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.explicit_item_self_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.item_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.item_self_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.item_non_self_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.impl_super_outlives;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.native_libraries;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.shallow_lint_levels_on;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lint_expectations;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lints_that_dont_need_to_run;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.expn_that_defined;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_panic_runtime;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_representability;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_representability_adt_ty;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.params_in_repr;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.thir_body;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_keys;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_const_qualif;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_built;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.thir_abstract_const;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_drops_elaborated_and_const_checked;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_for_ctfe;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_promoted;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.closure_typeinfo;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.closure_saved_names_of_captured_variables;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_coroutine_witnesses;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_coroutine_obligations;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_potentially_region_dependent_goals;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.optimized_mir;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coverage_attr_on;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coverage_ids_info;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.promoted_mir;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.erase_and_anonymize_regions_ty;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.wasm_import_module_map;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.trait_explicit_predicates_and_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.explicit_predicates_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.inferred_outlives_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.explicit_super_predicates_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.explicit_implied_predicates_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.explicit_supertraits_containing_assoc_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.const_conditions;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.explicit_implied_const_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_param_predicates;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.trait_def;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_def;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_destructor;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_async_destructor;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_sizedness_constraint;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_dtorck_constraint;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.constness;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.asyncness;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_promotable_const_fn;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coroutine_by_move_body_def_id;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coroutine_kind;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coroutine_for_closure;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coroutine_hidden_types;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_variances;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.variances_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.inferred_outlives_crate;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.associated_item_def_ids;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.associated_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.associated_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.impl_item_implementor_ids;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.associated_types_for_impl_traits_in_trait_or_impl;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.impl_trait_header;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.impl_self_is_guaranteed_unsized;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.inherent_impls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.incoherent_impls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_transmutes;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_unsafety;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_tail_calls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.assumed_wf_types;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.assumed_wf_types_for_rpitit;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.fn_sig;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lint_mod;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_unused_traits;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_mod_attrs;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_mod_unstable_api_usage;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_mod_privacy;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_liveness;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.live_symbols_and_ignored_derived_traits;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_mod_deathness;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_type_wf;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coerce_unsized_info;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.typeck_root;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.used_trait_imports;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.coherent_trait;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_borrowck;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_inherent_impls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_inherent_impls_validity_check;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_inherent_impls_overlap_check;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.orphan_check_impl;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_callgraph_cyclic;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_inliner_callees;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.tag_for_variant;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.eval_to_allocation_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.eval_static_initializer;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.eval_to_const_value_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.eval_to_valtree;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.valtree_to_const_val;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lit_to_const;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_match;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.effective_visibilities;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_private_in_public;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.reachable_set;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.region_scope_tree;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.mir_shims;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.symbol_name;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.def_kind;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.def_span;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.def_ident_span;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.ty_span;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lookup_stability;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lookup_const_stability;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lookup_default_body_stability;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.should_inherit_track_caller;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.inherited_align;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lookup_deprecation_entry;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_doc_hidden;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_doc_notable_trait;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.attrs_for_def;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.codegen_fn_attrs;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.asm_target_features;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.fn_arg_idents;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.rendered_const;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.rendered_precise_capturing_args;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.impl_parent;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_mir_available;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.own_existential_vtable_entries;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.vtable_entries;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.first_method_vtable_slot;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.supertrait_vtable_slot;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.vtable_allocation;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.codegen_select_candidate;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.all_local_trait_impls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.local_trait_impls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.trait_impls_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.specialization_graph_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.dyn_compatibility_violations;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_dyn_compatible;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.param_env;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.param_env_normalized_for_post_analysis;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_copy_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_use_cloned_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_sized_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_freeze_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_unsafe_unpin_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_unpin_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_async_drop_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.needs_drop_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.needs_async_drop_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.has_significant_drop_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.has_structural_eq_impl;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_drop_tys;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_async_drop_tys;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.adt_significant_drop_tys;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.list_significant_drop_tys;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.layout_of;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.fn_abi_of_fn_ptr;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.fn_abi_of_instance_no_deduced_attrs;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.fn_abi_of_instance_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.dylib_dependency_formats;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.dependency_formats;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_compiler_builtins;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.has_global_allocator;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.has_alloc_error_handler;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.has_panic_handler;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_profiler_runtime;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.has_ffi_unwind_calls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.required_panic_strategy;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.panic_in_drop_strategy;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_no_builtins;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.symbol_mangling_version;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.extern_crate;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.specialization_enabled_in;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.specializes;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.defaultness;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.default_field;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_well_formed;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.enforce_impl_non_lifetime_params_are_constrained;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.reachable_non_generics;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_reachable_non_generic;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_unreachable_local_definition;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.upstream_monomorphizations;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.upstream_monomorphizations_for;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.upstream_drop_glue_for;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.upstream_async_drop_glue_for;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.foreign_modules;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.clashing_extern_declarations;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.entry_fn;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.proc_macro_decls_static;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_hash;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_host_hash;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.extra_filename;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_extern_paths;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.implementations_of_trait;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_incoherent_impls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.native_library;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.inherit_sig_for_delegation_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.delegation_user_specified_args;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.delegations_resolutions;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.resolve_bound_vars;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.named_variable_map;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_late_bound_map;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.object_lifetime_default;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.late_bound_vars_map;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.opaque_captured_lifetimes;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.visibility;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.inhabited_predicate_adt;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.inhabited_predicate_type;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_dep_kind;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_name;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.module_children;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.num_extern_def_ids;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.lib_features;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.stability_implications;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.intrinsic_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.get_lang_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.all_diagnostic_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.defined_lang_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.diagnostic_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.missing_lang_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.visible_parent_map;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.trimmed_def_paths;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.missing_extern_crate_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.used_crate_source;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.debugger_visualizers;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.postorder_cnums;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_private_dep;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.allocator_kind;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.alloc_error_handler_kind;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.upvars_mentioned;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crates;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.used_crates;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.duplicate_crate_names;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.traits;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.trait_impls_in_crate;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.stable_order_of_exportable_impls;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.exportable_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.exported_non_generic_symbols;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.exported_generic_symbols;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.collect_and_partition_mono_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_codegened_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.codegen_unit;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.backend_optimization_level;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.output_filenames;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.normalize_canonicalized_projection;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.normalize_canonicalized_free_alias;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.normalize_canonicalized_inherent_projection;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.try_normalize_generic_arg_after_erasing_regions;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.implied_outlives_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.dropck_outlives;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.evaluate_obligation;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_op_ascribe_user_type;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_op_prove_predicate;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_op_normalize_ty;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_op_normalize_clause;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_op_normalize_poly_fn_sig;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.type_op_normalize_fn_sig;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.instantiate_and_check_impossible_predicates;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.is_impossible_associated_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.method_autoderef_steps;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.evaluate_root_goal_for_proof_tree_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.rust_target_features;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.implied_target_features;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.features_query;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.crate_for_resolver;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.resolve_instance_raw;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.reveal_opaque_types_in_bounds;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.limits;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.diagnostic_hir_wf_check;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.global_backend_features;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_validity_requirement;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.compare_impl_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.deduced_param_attrs;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.doc_link_resolutions;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.doc_link_traits_in_scope;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.stripped_cfg_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.generics_require_sized_self;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.cross_crate_inlinable;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_mono_item;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.items_of_instance;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.size_estimate;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.anon_const_kind;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.trivial_const;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.sanitizer_settings_for;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.check_externally_implementable_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
    let query: &rustc_middle::query::QueryVTable<'_, _> =
        &tcx.query_system.query_vtables.externally_implementable_items;
    (|query|
            {
                collect_active_query_jobs_inner(query, collect_kind,
                    &mut job_map);
            })(query);
};for_each_query_vtable!(ALL, tcx, |query| {
57        collect_active_query_jobs_inner(query, collect_kind, &mut job_map);
58    });
59
60    job_map
61}
62
63/// Internal plumbing for collecting the set of active jobs for this query.
64///
65/// Aborts if jobs can't be gathered as specified by `collect_kind`.
66fn collect_active_query_jobs_inner<'tcx, C>(
67    query: &'tcx QueryVTable<'tcx, C>,
68    collect_kind: CollectActiveJobsKind,
69    job_map: &mut QueryJobMap<'tcx>,
70) where
71    C: QueryCache<Key: QueryKey + DynSend + DynSync>,
72    QueryVTable<'tcx, C>: DynSync,
73{
74    let mut collect_shard_jobs = |shard: &HashTable<(C::Key, ActiveKeyStatus<'tcx>)>| {
75        for (key, status) in shard.iter() {
76            if let ActiveKeyStatus::Started(job) = status {
77                // It's fine to call `create_tagged_key` with the shard locked,
78                // because it's just a `TaggedQueryKey` variant constructor.
79                let tagged_key = (query.create_tagged_key)(*key);
80                job_map.insert(job.id, QueryJobInfo { tagged_key, job: job.clone() });
81            }
82        }
83    };
84
85    match collect_kind {
86        CollectActiveJobsKind::Full => {
87            for shard in query.state.active.lock_shards() {
88                collect_shard_jobs(&shard);
89            }
90        }
91        CollectActiveJobsKind::FullNoContention => {
92            for shard in query.state.active.try_lock_shards() {
93                match shard {
94                    Some(shard) => collect_shard_jobs(&shard),
95                    None => {
    ::core::panicking::panic_fmt(format_args!("Failed to collect active jobs for query `{0}`!",
            query.name));
}panic!("Failed to collect active jobs for query `{}`!", query.name),
96                }
97            }
98        }
99        CollectActiveJobsKind::PartialAllowed => {
100            for shard in query.state.active.try_lock_shards() {
101                match shard {
102                    Some(shard) => collect_shard_jobs(&shard),
103                    // This collection is best-effort (it is only used to print the query
104                    // stack on panic), so a contended shard is expected and fine to skip.
105                    // Emitting this at `warn!` would leak nondeterministically into the
106                    // panic output under the parallel front-end, where another thread may
107                    // still hold a shard lock, so keep it at `debug!`.
108                    None => {
    use ::tracing::__macro_support::Callsite as _;
    static __CALLSITE: ::tracing::callsite::DefaultCallsite =
        {
            static META: ::tracing::Metadata<'static> =
                {
                    ::tracing_core::metadata::Metadata::new("event compiler/rustc_query_impl/src/execution.rs:108",
                        "rustc_query_impl::execution", ::tracing::Level::DEBUG,
                        ::tracing_core::__macro_support::Option::Some("compiler/rustc_query_impl/src/execution.rs"),
                        ::tracing_core::__macro_support::Option::Some(108u32),
                        ::tracing_core::__macro_support::Option::Some("rustc_query_impl::execution"),
                        ::tracing_core::field::FieldSet::new(&["message"],
                            ::tracing_core::callsite::Identifier(&__CALLSITE)),
                        ::tracing::metadata::Kind::EVENT)
                };
            ::tracing::callsite::DefaultCallsite::new(&META)
        };
    let enabled =
        ::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
                &&
                ::tracing::Level::DEBUG <=
                    ::tracing::level_filters::LevelFilter::current() &&
            {
                let interest = __CALLSITE.interest();
                !interest.is_never() &&
                    ::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
                        interest)
            };
    if enabled {
        (|value_set: ::tracing::field::ValueSet|
                    {
                        let meta = __CALLSITE.metadata();
                        ::tracing::Event::dispatch(meta, &value_set);
                        ;
                    })({
                #[allow(unused_imports)]
                use ::tracing::field::{debug, display, Value};
                let mut iter = __CALLSITE.metadata().fields().iter();
                __CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
                                    ::tracing::__macro_support::Option::Some(&format_args!("Failed to collect active jobs for query `{0}`!",
                                                    query.name) as &dyn Value))])
            });
    } else { ; }
}debug!("Failed to collect active jobs for query `{}`!", query.name),
109                }
110            }
111        }
112    }
113}
114
115#[cold]
116#[inline(never)]
117fn handle_cycle<'tcx, C: QueryCache>(
118    query: &'tcx QueryVTable<'tcx, C>,
119    tcx: TyCtxt<'tcx>,
120    key: C::Key,
121    cycle: Cycle<'tcx>,
122) -> C::Value {
123    let nested;
124    {
125        let mut nesting = tcx.query_system.cycle_handler_nesting.lock();
126        nested = match *nesting {
127            0 => false,
128            1 => true,
129            _ => {
130                // Don't print further nested errors to avoid cases of infinite recursion
131                tcx.dcx().delayed_bug("doubly nested cycle error").raise_fatal()
132            }
133        };
134        *nesting += 1;
135    }
136    let _guard = defer(|| *tcx.query_system.cycle_handler_nesting.lock() -= 1);
137
138    let error = create_cycle_error(tcx, &cycle, nested);
139
140    if nested {
141        // Avoid custom handlers and only use the robust `create_cycle_error` for nested cycle errors
142        handle_cycle_error::default(error)
143    } else {
144        (query.handle_cycle_error_fn)(tcx, key, cycle, error)
145    }
146}
147
148/// Guard object representing the responsibility to execute a query job and
149/// mark it as completed.
150///
151/// This will poison the relevant query key if it is dropped without calling
152/// [`Self::complete`].
153struct ActiveJobGuard<'tcx, K>
154where
155    K: Eq + Hash + Copy,
156{
157    state: &'tcx QueryState<'tcx, K>,
158    key: K,
159    key_hash: u64,
160}
161
162impl<'tcx, K> ActiveJobGuard<'tcx, K>
163where
164    K: Eq + Hash + Copy,
165{
166    /// Completes the query by updating the query cache with the `result`,
167    /// signals the waiter, and forgets the guard so it won't poison the query.
168    fn complete<C>(self, cache: &C, value: C::Value, dep_node_index: DepNodeIndex)
169    where
170        C: QueryCache<Key = K>,
171    {
172        // Mark as complete before we remove the job from the active state
173        // so no other thread can re-execute this query.
174        cache.complete(self.key, value, dep_node_index);
175
176        let mut this = ManuallyDrop::new(self);
177
178        // Drop everything without poisoning the query.
179        this.drop_and_maybe_poison(/* poison */ false);
180    }
181
182    fn drop_and_maybe_poison(&mut self, poison: bool) {
183        let status = {
184            let mut shard = self.state.active.lock_shard_by_hash(self.key_hash);
185            match shard.find_entry(self.key_hash, equivalent_key(self.key)) {
186                Err(_) => {
187                    // Note: we must not panic while holding the lock, because unwinding also looks
188                    // at this map, which can result in a double panic. So drop it first.
189                    drop(shard);
190                    ::core::panicking::panic("explicit panic");panic!();
191                }
192                Ok(occupied) => {
193                    let ((key, status), vacant) = occupied.remove();
194                    if poison {
195                        vacant.insert((key, ActiveKeyStatus::Poisoned));
196                    }
197                    status
198                }
199            }
200        };
201
202        // Also signal the completion of the job, so waiters will continue execution.
203        match status {
204            ActiveKeyStatus::Started(job) => job.signal_complete(),
205            ActiveKeyStatus::Poisoned => ::core::panicking::panic("explicit panic")panic!(),
206        }
207    }
208}
209
210impl<'tcx, K> Drop for ActiveJobGuard<'tcx, K>
211where
212    K: Eq + Hash + Copy,
213{
214    #[inline(never)]
215    #[cold]
216    fn drop(&mut self) {
217        // Poison the query so jobs waiting on it panic.
218        self.drop_and_maybe_poison(/* poison */ true);
219    }
220}
221
222#[cold]
223#[inline(never)]
224fn find_and_handle_cycle<'tcx, C: QueryCache>(
225    query: &'tcx QueryVTable<'tcx, C>,
226    tcx: TyCtxt<'tcx>,
227    key: C::Key,
228    try_execute: QueryJobId,
229    span: Span,
230) -> (C::Value, Option<DepNodeIndex>) {
231    // Ensure there were no errors collecting all active jobs.
232    // We need the complete map to ensure we find a cycle to break.
233    let job_map = collect_active_query_jobs(tcx, CollectActiveJobsKind::FullNoContention);
234
235    let cycle = find_cycle_in_stack(try_execute, job_map, &current_query_job(), span);
236    (handle_cycle(query, tcx, key, cycle), None)
237}
238
239#[inline(always)]
240fn wait_for_query<'tcx, C: QueryCache>(
241    query: &'tcx QueryVTable<'tcx, C>,
242    tcx: TyCtxt<'tcx>,
243    span: Span,
244    key: C::Key,
245    key_hash: u64,
246    latch: QueryLatch<'tcx>,
247    current: Option<QueryJobId>,
248) -> (C::Value, Option<DepNodeIndex>) {
249    // For parallel queries, we'll block and wait until the query running
250    // in another thread has completed. Record how long we wait in the
251    // self-profiler.
252    let query_blocked_prof_timer = tcx.prof.query_blocked();
253
254    // With parallel queries we might just have to wait on some other thread.
255    let result = latch.wait_on(tcx, current, span);
256
257    match result {
258        Ok(()) => {
259            let Some((v, index)) = query.cache.lookup(&key) else {
260                outline(|| {
261                    // We didn't find the query result in the query cache. Check if it was
262                    // poisoned due to a panic instead.
263                    let shard = query.state.active.lock_shard_by_hash(key_hash);
264                    match shard.find(key_hash, equivalent_key(key)) {
265                        // The query we waited on panicked. Continue unwinding here.
266                        Some((_, ActiveKeyStatus::Poisoned)) => FatalError.raise(),
267                        _ => {
    ::core::panicking::panic_fmt(format_args!("query \'{0}\' result must be in the cache or the query must be poisoned after a wait",
            query.name));
}panic!(
268                            "query '{}' result must be in the cache or the query must be poisoned after a wait",
269                            query.name
270                        ),
271                    }
272                })
273            };
274
275            tcx.prof.query_cache_hit(index.into());
276            query_blocked_prof_timer.finish_with_query_invocation_id(index.into());
277
278            (v, Some(index))
279        }
280        Err(cycle) => (handle_cycle(query, tcx, key, cycle), None),
281    }
282}
283
284/// Shared main part of both [`execute_query_incr_inner`] and [`execute_query_non_incr_inner`].
285#[inline(never)]
286fn try_execute_query<'tcx, C: QueryCache, const INCR: bool>(
287    query: &'tcx QueryVTable<'tcx, C>,
288    tcx: TyCtxt<'tcx>,
289    span: Span,
290    key: C::Key,
291    dep_node: Option<DepNode>, // `None` for non-incremental, `Some` for incremental
292) -> (C::Value, Option<DepNodeIndex>) {
293    let key_hash = sharded::make_hash(&key);
294    let mut state_lock = query.state.active.lock_shard_by_hash(key_hash);
295
296    // For the parallel compiler we need to check both the query cache and query state structures
297    // while holding the state lock to ensure that 1) the query has not yet completed and 2) the
298    // query is not still executing. Without checking the query cache here, we can end up
299    // re-executing the query since `try_start` only checks that the query is not currently
300    // executing, but another thread may have already completed the query and stores it result
301    // in the query cache.
302    if tcx.sess.threads().is_some() {
303        if let Some((value, index)) = query.cache.lookup(&key) {
304            tcx.prof.query_cache_hit(index.into());
305            return (value, Some(index));
306        }
307    }
308
309    let current_job_id = current_query_job();
310
311    match state_lock.entry(key_hash, equivalent_key(key), |(k, _)| sharded::make_hash(k)) {
312        Entry::Vacant(entry) => {
313            // Nothing has computed or is computing the query, so we start a new job and insert it
314            // in the state map.
315            let id = next_job_id(tcx);
316            let job = QueryJob::new(id, span, current_job_id);
317            entry.insert((key, ActiveKeyStatus::Started(job)));
318
319            // Drop the lock before we start executing the query.
320            drop(state_lock);
321
322            // Set up a guard object that will automatically poison the query if a
323            // panic occurs while executing the query (or any intermediate plumbing).
324            let job_guard = ActiveJobGuard { state: &query.state, key, key_hash };
325
326            // Delegate to another function to actually execute the query job.
327            let (value, dep_node_index) = if INCR {
328                execute_job_incr(query, tcx, key, dep_node.unwrap(), id)
329            } else {
330                execute_job_non_incr(query, tcx, key, id)
331            };
332
333            if query.feedable {
334                check_feedable_consistency(tcx, query, key, &value);
335            }
336
337            // Tell the guard to insert `value` in the cache and remove the status entry from
338            // `query.state`.
339            job_guard.complete(&query.cache, value, dep_node_index);
340
341            (value, Some(dep_node_index))
342        }
343        Entry::Occupied(mut entry) => {
344            match &mut entry.get_mut().1 {
345                ActiveKeyStatus::Started(job) => {
346                    if sync::is_dyn_thread_safe() {
347                        // Get the latch out
348                        let latch = job.latch();
349                        drop(state_lock);
350
351                        // Only call `wait_for_query` if we're using a Rayon thread pool
352                        // as it will attempt to mark the worker thread as blocked.
353                        wait_for_query(query, tcx, span, key, key_hash, latch, current_job_id)
354                    } else {
355                        let id = job.id;
356                        drop(state_lock);
357
358                        // If we are single-threaded we know that we have cycle error,
359                        // so we just return the error.
360                        find_and_handle_cycle(query, tcx, key, id, span)
361                    }
362                }
363                ActiveKeyStatus::Poisoned => FatalError.raise(),
364            }
365        }
366    }
367}
368
369#[inline(always)]
370fn check_feedable_consistency<'tcx, C: QueryCache>(
371    tcx: TyCtxt<'tcx>,
372    query: &'tcx QueryVTable<'tcx, C>,
373    key: C::Key,
374    value: &C::Value,
375) {
376    // We should not compute queries that also got a value via feeding.
377    // This can't happen, as query feeding adds the very dependencies to the fed query
378    // as its feeding query had. So if the fed query is red, so is its feeder, which will
379    // get evaluated first, and re-feed the query.
380    let Some((cached_value, _)) = query.cache.lookup(&key) else { return };
381
382    let Some(hash_value_fn) = query.hash_value_fn else {
383        {
    ::core::panicking::panic_fmt(format_args!("no_hash fed query later has its value computed.\nRemove `no_hash` modifier to allow recomputation.\nThe already cached value: {0}",
            (query.format_value)(&cached_value)));
};panic!(
384            "no_hash fed query later has its value computed.\n\
385            Remove `no_hash` modifier to allow recomputation.\n\
386            The already cached value: {}",
387            (query.format_value)(&cached_value)
388        );
389    };
390
391    let (old_hash, new_hash) = tcx.with_stable_hashing_context(|mut hcx| {
392        (hash_value_fn(&mut hcx, &cached_value), hash_value_fn(&mut hcx, value))
393    });
394    let formatter = query.format_value;
395    if old_hash != new_hash {
396        // We have an inconsistency. This can happen if one of the two
397        // results is tainted by errors.
398        if !tcx.dcx().has_errors().is_some() {
    {
        ::core::panicking::panic_fmt(format_args!("Computed query value for {0:?}({1:?}) is inconsistent with fed value,\ncomputed={2:#?}\nfed={3:#?}",
                query.dep_kind, key, formatter(value),
                formatter(&cached_value)));
    }
};assert!(
399            tcx.dcx().has_errors().is_some(),
400            "Computed query value for {:?}({:?}) is inconsistent with fed value,\n\
401                computed={:#?}\nfed={:#?}",
402            query.dep_kind,
403            key,
404            formatter(value),
405            formatter(&cached_value),
406        );
407    }
408}
409
410// Fast path for when incr. comp. is off.
411#[inline(always)]
412fn execute_job_non_incr<'tcx, C: QueryCache>(
413    query: &'tcx QueryVTable<'tcx, C>,
414    tcx: TyCtxt<'tcx>,
415    key: C::Key,
416    job_id: QueryJobId,
417) -> (C::Value, DepNodeIndex) {
418    if true {
    if !!tcx.dep_graph.is_fully_enabled() {
        ::core::panicking::panic("assertion failed: !tcx.dep_graph.is_fully_enabled()")
    };
};debug_assert!(!tcx.dep_graph.is_fully_enabled());
419
420    let prof_timer = tcx.prof.query_provider();
421    // Call the query provider.
422    let value = start_query(job_id, query.depth_limit, || (query.invoke_provider_fn)(tcx, key));
423    let dep_node_index = tcx.dep_graph.next_virtual_depnode_index();
424    prof_timer.finish_with_query_invocation_id(dep_node_index.into());
425
426    // Sanity: Fingerprint the key and the result to assert they don't contain anything unhashable.
427    if truecfg!(debug_assertions) {
428        let _ = key.to_fingerprint(tcx);
429        if let Some(hash_value_fn) = query.hash_value_fn {
430            tcx.with_stable_hashing_context(|mut hcx| {
431                hash_value_fn(&mut hcx, &value);
432            });
433        }
434    }
435
436    (value, dep_node_index)
437}
438
439#[inline(always)]
440fn execute_job_incr<'tcx, C: QueryCache>(
441    query: &'tcx QueryVTable<'tcx, C>,
442    tcx: TyCtxt<'tcx>,
443    key: C::Key,
444    dep_node: DepNode,
445    job_id: QueryJobId,
446) -> (C::Value, DepNodeIndex) {
447    let dep_graph_data =
448        tcx.dep_graph.data().expect("should always be present in incremental mode");
449
450    if !query.eval_always {
451        // The diagnostics for this query will be promoted to the current session during
452        // `try_mark_green()`, so we can ignore them here.
453        if let Some(ret) = start_query(job_id, false, || try {
454            let (prev_index, dep_node_index) = dep_graph_data.try_mark_green(tcx, &dep_node)?;
455            let value = load_from_disk_or_invoke_provider_green(
456                tcx,
457                dep_graph_data,
458                query,
459                key,
460                &dep_node,
461                prev_index,
462                dep_node_index,
463            );
464            (value, dep_node_index)
465        }) {
466            return ret;
467        }
468    }
469
470    let prof_timer = tcx.prof.query_provider();
471
472    let (result, dep_node_index) = start_query(job_id, query.depth_limit, || {
473        // Call the query provider.
474        dep_graph_data.with_task(
475            dep_node,
476            tcx,
477            || (query.invoke_provider_fn)(tcx, key),
478            query.hash_value_fn,
479        )
480    });
481
482    prof_timer.finish_with_query_invocation_id(dep_node_index.into());
483
484    (result, dep_node_index)
485}
486
487/// Given that the dep node for this query+key is green, obtain a value for it
488/// by loading one from disk if possible, or by invoking its query provider if
489/// necessary.
490#[inline(always)]
491fn load_from_disk_or_invoke_provider_green<'tcx, C: QueryCache>(
492    tcx: TyCtxt<'tcx>,
493    dep_graph_data: &DepGraphData,
494    query: &'tcx QueryVTable<'tcx, C>,
495    key: C::Key,
496    dep_node: &DepNode,
497    prev_index: SerializedDepNodeIndex,
498    dep_node_index: DepNodeIndex,
499) -> C::Value {
500    // Note this function can be called concurrently from the same query
501    // We must ensure that this is handled correctly.
502
503    if true {
    if !dep_graph_data.is_index_green(prev_index) {
        ::core::panicking::panic("assertion failed: dep_graph_data.is_index_green(prev_index)")
    };
};debug_assert!(dep_graph_data.is_index_green(prev_index));
504
505    // First try to load the result from the on-disk cache. Some things are never cached on disk.
506    let try_value = if query.will_cache_on_disk_for_key(key) {
507        let prof_timer = tcx.prof.incr_cache_loading();
508        let value = (query.try_load_from_disk_fn)(tcx, prev_index);
509        prof_timer.finish_with_query_invocation_id(dep_node_index.into());
510        value
511    } else {
512        None
513    };
514    let (value, verify) = match try_value {
515        Some(value) => {
516            if std::intrinsics::unlikely(tcx.sess.opts.unstable_opts.query_dep_graph) {
517                dep_graph_data.mark_debug_loaded_from_disk(*dep_node)
518            }
519
520            let prev_fingerprint = dep_graph_data.prev_value_fingerprint_of(prev_index);
521            // If `-Zincremental-verify-ich` is specified, re-hash results from
522            // the cache and make sure that they have the expected fingerprint.
523            //
524            // If not, we still seek to verify a subset of fingerprints loaded
525            // from disk. Re-hashing results is fairly expensive, so we can't
526            // currently afford to verify every hash. This subset should still
527            // give us some coverage of potential bugs.
528            let verify = prev_fingerprint.split().1.as_u64().is_multiple_of(32)
529                || tcx.sess.opts.unstable_opts.incremental_verify_ich;
530
531            (value, verify)
532        }
533        None => {
534            // We could not load a result from the on-disk cache, so recompute. The dep-graph for
535            // this computation is already in-place, so we can just call the query provider.
536            let prof_timer = tcx.prof.query_provider();
537            let value = tcx.dep_graph.with_ignore(|| (query.invoke_provider_fn)(tcx, key));
538            prof_timer.finish_with_query_invocation_id(dep_node_index.into());
539
540            (value, true)
541        }
542    };
543
544    if verify {
545        // Verify that re-running the query produced a result with the expected hash.
546        // This catches bugs in query implementations, turning them into ICEs.
547        // For example, a query might sort its result by `DefId` - since `DefId`s are
548        // not stable across compilation sessions, the result could get up getting sorted
549        // in a different order when the query is re-run, even though all of the inputs
550        // (e.g. `DefPathHash` values) were green.
551        //
552        // See issue #82920 for an example of a miscompilation that would get turned into
553        // an ICE by this check
554        incremental_verify_ich(
555            tcx,
556            dep_graph_data,
557            &value,
558            prev_index,
559            query.hash_value_fn,
560            query.format_value,
561        );
562    }
563
564    value
565}
566
567/// Checks whether a `tcx.ensure_ok()` or `tcx.ensure_done()` query call can
568/// return early without actually trying to execute.
569///
570/// This only makes sense during incremental compilation, because it relies
571/// on having the dependency graph (and in some cases a disk-cached value)
572/// from the previous incr-comp session.
573#[inline(never)]
574fn ensure_can_skip_execution<'tcx, C: QueryCache>(
575    query: &'tcx QueryVTable<'tcx, C>,
576    tcx: TyCtxt<'tcx>,
577    key: C::Key,
578    dep_node: DepNode,
579    ensure_mode: EnsureMode,
580) -> bool {
581    // Queries with `eval_always` should never skip execution.
582    if query.eval_always {
583        return false;
584    }
585
586    match tcx.dep_graph.try_mark_green(tcx, &dep_node) {
587        None => {
588            // A None return from `try_mark_green` means that this is either
589            // a new dep node or that the dep node has already been marked red.
590            // Either way, we can't call `dep_graph.read()` as we don't have the
591            // DepNodeIndex. We must invoke the query itself. The performance cost
592            // this introduces should be negligible as we'll immediately hit the
593            // in-memory cache, or another query down the line will.
594            false
595        }
596        Some((serialized_dep_node_index, dep_node_index)) => {
597            tcx.dep_graph.read_index(dep_node_index);
598            tcx.prof.query_cache_hit(dep_node_index.into());
599            match ensure_mode {
600                // In ensure-ok mode, we can skip execution for this key if the
601                // node is green. It must have succeeded in the previous
602                // session, and therefore would succeed in the current session
603                // if executed.
604                EnsureMode::Ok => true,
605
606                // In ensure-done mode, we can only skip execution for this key
607                // if there's a disk-cached value available to load later if
608                // needed, which guarantees the query provider will never run
609                // for this key.
610                EnsureMode::Done => {
611                    query.will_cache_on_disk_for_key(key)
612                        && loadable_from_disk(tcx, serialized_dep_node_index)
613                }
614            }
615        }
616    }
617}
618
619/// Called by a macro-generated impl of [`QueryVTable::execute_query_fn`],
620/// in non-incremental mode.
621#[inline(always)]
622pub(super) fn execute_query_non_incr_inner<'tcx, C: QueryCache>(
623    query: &'tcx QueryVTable<'tcx, C>,
624    tcx: TyCtxt<'tcx>,
625    span: Span,
626    key: C::Key,
627) -> C::Value {
628    ensure_sufficient_stack(|| try_execute_query::<C, false>(query, tcx, span, key, None).0)
629}
630
631/// Called by a macro-generated impl of [`QueryVTable::execute_query_fn`],
632/// in incremental mode.
633#[inline(always)]
634pub(super) fn execute_query_incr_inner<'tcx, C: QueryCache>(
635    query: &'tcx QueryVTable<'tcx, C>,
636    tcx: TyCtxt<'tcx>,
637    span: Span,
638    key: C::Key,
639    mode: QueryMode,
640) -> Option<C::Value> {
641    let dep_node = DepNode::construct(tcx, query.dep_kind, &key);
642
643    // Check if query execution can be skipped, for `ensure_ok` or `ensure_done`.
644    if let QueryMode::Ensure { ensure_mode } = mode
645        && ensure_can_skip_execution(query, tcx, key, dep_node, ensure_mode)
646    {
647        return None;
648    }
649
650    let (result, dep_node_index) = ensure_sufficient_stack(|| {
651        try_execute_query::<C, true>(query, tcx, span, key, Some(dep_node))
652    });
653    if let Some(dep_node_index) = dep_node_index {
654        tcx.dep_graph.read_index(dep_node_index)
655    }
656    Some(result)
657}
658
659/// Inner implementation of [`DepKindVTable::force_from_dep_node_fn`][force_fn]
660/// for query nodes.
661///
662/// [force_fn]: rustc_middle::dep_graph::DepKindVTable::force_from_dep_node_fn
663pub(crate) fn force_query_dep_node<'tcx, C: QueryCache>(
664    tcx: TyCtxt<'tcx>,
665    query: &'tcx QueryVTable<'tcx, C>,
666    dep_node: DepNode,
667) -> bool {
668    let Some(key) = C::Key::try_recover_key(tcx, &dep_node) else {
669        // We couldn't recover a key from the node's key fingerprint.
670        // Tell the caller that we couldn't force the node.
671        return false;
672    };
673
674    ensure_sufficient_stack(|| {
675        try_execute_query::<C, true>(query, tcx, DUMMY_SP, key, Some(dep_node))
676    });
677
678    // We did manage to recover a key and force the node, though it's up to
679    // the caller to check whether the node ended up marked red or green.
680    true
681}