From 3afea6018c8d2d16a7524880e4cfd8929f35d3fe Mon Sep 17 00:00:00 2001 From: Francesco Tamagni Date: Thu, 28 Mar 2024 13:27:37 +0100 Subject: [PATCH] darwin: Take Interceptor and Cloak locks in TSM To extend the ThreadSuspendMonitor scope to prevent deadlock scenarios where threads holding the Cloak or Interceptor lock get suspended. --- lib/payload/thread-suspend-monitor.vala | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/lib/payload/thread-suspend-monitor.vala b/lib/payload/thread-suspend-monitor.vala index b0ae68400..3c1d297b1 100644 --- a/lib/payload/thread-suspend-monitor.vala +++ b/lib/payload/thread-suspend-monitor.vala @@ -84,14 +84,19 @@ namespace Frida { if (script_backend == null || thread_id == caller_thread_id) return thread_suspend (thread_id); - int result = 0; + var interceptor = Gum.Interceptor.obtain (); + int result = 0; while (true) { script_backend.with_lock_held (() => { - result = thread_suspend (thread_id); + interceptor.with_lock_held (() => { + Gum.Cloak.with_lock_held (() => { + result = thread_suspend (thread_id); + }); + }); }); - if (result != 0 || !script_backend.is_locked ()) + if (result != 0 || (!script_backend.is_locked () && !Gum.Cloak.is_locked () && !interceptor.is_locked ())) break; if (thread_resume (thread_id) != 0)