guile-commits
[Top][All Lists]
Advanced

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

[Guile-commits] 03/05: Revert "Fix atomics usage in handle-interrupts JI


From: Andy Wingo
Subject: [Guile-commits] 03/05: Revert "Fix atomics usage in handle-interrupts JIT."
Date: Mon, 27 May 2019 13:06:10 -0400 (EDT)

wingo pushed a commit to branch master
in repository guile.

commit d0a95bfbe8a4871840d40b89f49a97a38891918d
Author: Andy Wingo <address@hidden>
Date:   Mon May 27 18:40:41 2019 +0200

    Revert "Fix atomics usage in handle-interrupts JIT."
    
    This reverts commit e8d34258beab2799951e16d21d547299d4659364.
---
 libguile/jit.c | 12 ++++++++++--
 1 file changed, 10 insertions(+), 2 deletions(-)

diff --git a/libguile/jit.c b/libguile/jit.c
index 6cea8bb..20116c1 100644
--- a/libguile/jit.c
+++ b/libguile/jit.c
@@ -3010,8 +3010,16 @@ compile_handle_interrupts (scm_jit_state *j)
 
   void *again = jit_address (j->jit);
 
-  jit_addi (j->jit, T0, THREAD, thread_offset_pending_asyncs);
-  jit_ldr_atomic (j->jit, T0, T0);
+#if defined(__i386__) || defined(__x86_64__)
+  /* Disassembly of atomic_ref_scm is just a mov.  */
+  jit_ldxi (j->jit, T0, THREAD, thread_offset_pending_asyncs);
+#else
+  emit_call_1 (j, scm_vm_intrinsics.atomic_ref_scm,
+               jit_operand_addi (thread_operand (),
+                                 thread_offset_pending_asyncs));
+  emit_retval (j, T0);
+  restore_reloadable_register_state (j, saved_state);
+#endif
   jit_reloc_t none_pending = jit_beqi (j->jit, T0, SCM_UNPACK (SCM_EOL));
   jit_ldxi_i (j->jit, T0, THREAD, thread_offset_block_asyncs);
   jit_reloc_t blocked = jit_bnei (j->jit, T0, 0);



reply via email to

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