qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [PATCH 1/3] enable tb unlinking when compiled with NPTL


From: riku . voipio
Subject: [Qemu-devel] [PATCH 1/3] enable tb unlinking when compiled with NPTL
Date: Fri, 4 Dec 2009 15:16:30 +0200

From: Riku Voipio <address@hidden>

Fixes recieving signals when guest code is being executed in a tight
loop. For an example, try interrupting the following code with ctrl-c.

http://nchipin.kos.to/test-loop.c

The tight loop is ofcourse brainless, but it is also exactly how the waitpid* 
testcases
are implemented.

Signed-off-by: Riku Voipio <address@hidden>
---
 exec.c |    8 +++-----
 1 files changed, 3 insertions(+), 5 deletions(-)

diff --git a/exec.c b/exec.c
index eb1ee51..3f7e4eb 100644
--- a/exec.c
+++ b/exec.c
@@ -1526,24 +1526,22 @@ void cpu_set_log_filename(const char *filename)
 
 static void cpu_unlink_tb(CPUState *env)
 {
-#if defined(CONFIG_USE_NPTL)
     /* FIXME: TB unchaining isn't SMP safe.  For now just ignore the
        problem and hope the cpu will stop of its own accord.  For userspace
        emulation this often isn't actually as bad as it sounds.  Often
        signals are used primarily to interrupt blocking syscalls.  */
-#else
     TranslationBlock *tb;
     static spinlock_t interrupt_lock = SPIN_LOCK_UNLOCKED;
 
     tb = env->current_tb;
     /* if the cpu is currently executing code, we must unlink it and
        all the potentially executing TB */
-    if (tb && !testandset(&interrupt_lock)) {
+    if (tb) {
+        spin_lock(&interrupt_lock);
         env->current_tb = NULL;
         tb_reset_jump_recursive(tb);
-        resetlock(&interrupt_lock);
+        spin_unlock(&interrupt_lock);
     }
-#endif
 }
 
 /* mask must never be zero, except for A20 change call */
-- 
1.6.3.3





reply via email to

[Prev in Thread] Current Thread [Next in Thread]