From a0539a3edb877c11ee2caaaa0b89223cafb9c4b2 Mon Sep 17 00:00:00 2001 From: PixelyIon Date: Sat, 22 Oct 2022 17:37:03 +0530 Subject: [PATCH] Trace Scheduler Preemption/Yield in Perfetto --- app/src/main/cpp/skyline/kernel/scheduler.cpp | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/app/src/main/cpp/skyline/kernel/scheduler.cpp b/app/src/main/cpp/skyline/kernel/scheduler.cpp index 8697fafb..8107e4ad 100644 --- a/app/src/main/cpp/skyline/kernel/scheduler.cpp +++ b/app/src/main/cpp/skyline/kernel/scheduler.cpp @@ -15,12 +15,15 @@ namespace skyline::kernel { void Scheduler::SignalHandler(int signal, siginfo *info, ucontext *ctx, void **tls) { if (*tls) { TRACE_EVENT_END("guest"); - const auto &state{*reinterpret_cast(*tls)->state}; - if (signal == PreemptionSignal) - state.thread->isPreempted = false; - state.scheduler->Rotate(false); - YieldPending = false; - state.scheduler->WaitSchedule(); + { + TRACE_EVENT_FMT("scheduler", "{} Signal", signal == PreemptionSignal ? "Preemption" : "Yield"); + const auto &state{*reinterpret_cast(*tls)->state}; + if (signal == PreemptionSignal) + state.thread->isPreempted = false; + state.scheduler->Rotate(false); + YieldPending = false; + state.scheduler->WaitSchedule(); + } TRACE_EVENT_BEGIN("guest", "Guest"); } else { YieldPending = true;