1
Fork 0

Make an optimal cold path for query_cache_hit

This commit is contained in:
John Kåre Alsaker 2023-02-01 04:49:09 +01:00
parent e60ccfc6a9
commit 9539737008
4 changed files with 28 additions and 32 deletions

View file

@ -11,6 +11,7 @@
#![feature(associated_type_bounds)] #![feature(associated_type_bounds)]
#![feature(auto_traits)] #![feature(auto_traits)]
#![feature(cell_leak)] #![feature(cell_leak)]
#![feature(core_intrinsics)]
#![feature(extend_one)] #![feature(extend_one)]
#![feature(hash_raw_entry)] #![feature(hash_raw_entry)]
#![feature(hasher_prefixfree_extras)] #![feature(hasher_prefixfree_extras)]

View file

@ -88,6 +88,7 @@ use std::borrow::Borrow;
use std::collections::hash_map::Entry; use std::collections::hash_map::Entry;
use std::error::Error; use std::error::Error;
use std::fs; use std::fs;
use std::intrinsics::unlikely;
use std::path::Path; use std::path::Path;
use std::process; use std::process;
use std::sync::Arc; use std::sync::Arc;
@ -393,13 +394,20 @@ impl SelfProfilerRef {
} }
/// Record a query in-memory cache hit. /// Record a query in-memory cache hit.
#[inline(never)] #[inline(always)]
pub fn query_cache_hit(&self, query_invocation_id: QueryInvocationId) { pub fn query_cache_hit(&self, query_invocation_id: QueryInvocationId) {
self.instant_query_event( #[inline(never)]
|profiler| profiler.query_cache_hit_event_kind, #[cold]
query_invocation_id, fn cold_call(profiler_ref: &SelfProfilerRef, query_invocation_id: QueryInvocationId) {
EventFilter::QUERY_CACHE_HITS, profiler_ref.instant_query_event(
); |profiler| profiler.query_cache_hit_event_kind,
query_invocation_id,
);
}
if unlikely(self.event_filter_mask.contains(EventFilter::QUERY_CACHE_HITS)) {
cold_call(self, query_invocation_id);
}
} }
/// Start profiling a query being blocked on a concurrent execution. /// Start profiling a query being blocked on a concurrent execution.
@ -444,20 +452,15 @@ impl SelfProfilerRef {
&self, &self,
event_kind: fn(&SelfProfiler) -> StringId, event_kind: fn(&SelfProfiler) -> StringId,
query_invocation_id: QueryInvocationId, query_invocation_id: QueryInvocationId,
event_filter: EventFilter,
) { ) {
drop(self.exec(event_filter, |profiler| { let event_id = StringId::new_virtual(query_invocation_id.0);
let event_id = StringId::new_virtual(query_invocation_id.0); let thread_id = get_thread_id();
let thread_id = get_thread_id(); let profiler = self.profiler.as_ref().unwrap();
profiler.profiler.record_instant_event(
profiler.profiler.record_instant_event( event_kind(profiler),
event_kind(profiler), EventId::from_virtual(event_id),
EventId::from_virtual(event_id), thread_id,
thread_id, );
);
TimingGuard::none()
}));
} }
pub fn with_profiler(&self, f: impl FnOnce(&SelfProfiler)) { pub fn with_profiler(&self, f: impl FnOnce(&SelfProfiler)) {

View file

@ -47,7 +47,7 @@ impl DepNodeIndex {
} }
impl From<DepNodeIndex> for QueryInvocationId { impl From<DepNodeIndex> for QueryInvocationId {
#[inline] #[inline(always)]
fn from(dep_node_index: DepNodeIndex) -> Self { fn from(dep_node_index: DepNodeIndex) -> Self {
QueryInvocationId(dep_node_index.as_u32()) QueryInvocationId(dep_node_index.as_u32())
} }

View file

@ -346,9 +346,7 @@ where
{ {
match cache.lookup(&key) { match cache.lookup(&key) {
Some((value, index)) => { Some((value, index)) => {
if std::intrinsics::unlikely(tcx.profiler().enabled()) { tcx.profiler().query_cache_hit(index.into());
tcx.profiler().query_cache_hit(index.into());
}
tcx.dep_graph().read_index(index); tcx.dep_graph().read_index(index);
Some(value) Some(value)
} }
@ -408,9 +406,7 @@ where
panic!("value must be in cache after waiting") panic!("value must be in cache after waiting")
}; };
if std::intrinsics::unlikely(qcx.dep_context().profiler().enabled()) { qcx.dep_context().profiler().query_cache_hit(index.into());
qcx.dep_context().profiler().query_cache_hit(index.into());
}
query_blocked_prof_timer.finish_with_query_invocation_id(index.into()); query_blocked_prof_timer.finish_with_query_invocation_id(index.into());
(v, Some(index)) (v, Some(index))
@ -722,9 +718,7 @@ where
} }
Some((_, dep_node_index)) => { Some((_, dep_node_index)) => {
dep_graph.read_index(dep_node_index); dep_graph.read_index(dep_node_index);
if std::intrinsics::unlikely(qcx.dep_context().profiler().enabled()) { qcx.dep_context().profiler().query_cache_hit(dep_node_index.into());
qcx.dep_context().profiler().query_cache_hit(dep_node_index.into());
}
(false, None) (false, None)
} }
} }
@ -778,9 +772,7 @@ where
// Ensure that only one of them runs the query. // Ensure that only one of them runs the query.
let cache = Q::query_cache(qcx); let cache = Q::query_cache(qcx);
if let Some((_, index)) = cache.lookup(&key) { if let Some((_, index)) = cache.lookup(&key) {
if std::intrinsics::unlikely(qcx.dep_context().profiler().enabled()) { qcx.dep_context().profiler().query_cache_hit(index.into());
qcx.dep_context().profiler().query_cache_hit(index.into());
}
return; return;
} }