[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Guile-commits] 06/09: Inline the atomic intrinsics
From: |
Andy Wingo |
Subject: |
[Guile-commits] 06/09: Inline the atomic intrinsics |
Date: |
Mon, 27 May 2019 08:27:04 -0400 (EDT) |
wingo pushed a commit to branch master
in repository guile.
commit 230a5559764679d75e3e8941e97a268a2b2e6a53
Author: Andy Wingo <address@hidden>
Date: Mon May 27 12:01:38 2019 +0200
Inline the atomic intrinsics
* libguile/intrinsics.h (SCM_FOR_ALL_VM_INTRINSICS):
* libguile/intrinsics.c (scm_bootstrap_intrinsics): Remove the atomic
intrinsics, as the JIT no longer needs them.
* libguile/vm-engine.c (VM_NAME): Inline the intrinsics.
---
libguile/intrinsics.c | 28 ----------------------------
libguile/intrinsics.h | 6 +-----
libguile/vm-engine.c | 12 ++++++------
3 files changed, 7 insertions(+), 39 deletions(-)
diff --git a/libguile/intrinsics.c b/libguile/intrinsics.c
index a8c6fa7..ab6b6a8 100644
--- a/libguile/intrinsics.c
+++ b/libguile/intrinsics.c
@@ -438,30 +438,6 @@ push_prompt (scm_thread *thread, uint8_t escape_only_p,
vra, mra, thread->vm.registers);
}
-static SCM
-atomic_ref_scm (SCM *loc)
-{
- return scm_atomic_ref_scm (loc);
-}
-
-static void
-atomic_set_scm (SCM *loc, SCM val)
-{
- scm_atomic_set_scm (loc, val);
-}
-
-static SCM
-atomic_swap_scm (SCM *loc, SCM val)
-{
- return scm_atomic_swap_scm (loc, val);
-}
-
-static SCM
-atomic_compare_and_swap_scm (SCM *loc, SCM expected, SCM desired)
-{
- return scm_atomic_compare_and_swap_scm (loc, expected, desired);
-}
-
void
scm_bootstrap_intrinsics (void)
{
@@ -530,10 +506,6 @@ scm_bootstrap_intrinsics (void)
scm_vm_intrinsics.allocate_words = allocate_words;
scm_vm_intrinsics.current_module = current_module;
scm_vm_intrinsics.push_prompt = push_prompt;
- scm_vm_intrinsics.atomic_ref_scm = atomic_ref_scm;
- scm_vm_intrinsics.atomic_set_scm = atomic_set_scm;
- scm_vm_intrinsics.atomic_swap_scm = atomic_swap_scm;
- scm_vm_intrinsics.atomic_compare_and_swap_scm = atomic_compare_and_swap_scm;
scm_c_register_extension ("libguile-" SCM_EFFECTIVE_VERSION,
"scm_init_intrinsics",
diff --git a/libguile/intrinsics.h b/libguile/intrinsics.h
index 397dffe..2c1b53a 100644
--- a/libguile/intrinsics.h
+++ b/libguile/intrinsics.h
@@ -1,4 +1,4 @@
-/* Copyright 2018
+/* Copyright 2018-2019
Free Software Foundation, Inc.
This file is part of Guile.
@@ -160,10 +160,6 @@ typedef uint32_t* scm_t_vcode_intrinsic;
M(scm_from_thread, current_module, "current-module", CURRENT_MODULE) \
M(thread_u8_scm_sp_vra_mra, push_prompt, "push-prompt", PUSH_PROMPT) \
M(thread_scm, unpack_values_object, "unpack-values-object",
UNPACK_VALUES_OBJECT) \
- M(scm_from_ptr, atomic_ref_scm, "atomic-ref-scm", ATOMIC_REF_SCM) \
- M(ptr_scm, atomic_set_scm, "atomic-set-scm", ATOMIC_SET_SCM) \
- M(scm_from_ptr_scm, atomic_swap_scm, "atomic-swap-scm", ATOMIC_SWAP_SCM) \
- M(scm_from_ptr_scm_scm, atomic_compare_and_swap_scm,
"atomic-compare-and-swap-scm", ATOMIC_COMPARE_AND_SWAP_SCM) \
M(vcode, handle_interrupt_code, "%handle-interrupt-code",
HANDLE_INTERRUPT_CODE) \
/* Add new intrinsics here; also update scm_bootstrap_intrinsics. */
diff --git a/libguile/vm-engine.c b/libguile/vm-engine.c
index 3b57fa1..6505662 100644
--- a/libguile/vm-engine.c
+++ b/libguile/vm-engine.c
@@ -1,4 +1,4 @@
-/* Copyright 2001,2009-2015,2017-2018
+/* Copyright 2001,2009-2015,2017-2019
Free Software Foundation, Inc.
This file is part of Guile.
@@ -2079,7 +2079,7 @@ VM_NAME (scm_thread *thread)
SCM *loc;
UNPACK_8_8_8 (op, dst, obj, offset);
loc = SCM_CELL_OBJECT_LOC (SP_REF (obj), offset);
- SP_SET (dst, CALL_INTRINSIC (atomic_ref_scm, (loc)));
+ SP_SET (dst, scm_atomic_ref_scm (loc));
NEXT (1);
}
@@ -2095,7 +2095,7 @@ VM_NAME (scm_thread *thread)
SCM *loc;
UNPACK_8_8_8 (op, obj, offset, val);
loc = SCM_CELL_OBJECT_LOC (SP_REF (obj), offset);
- CALL_INTRINSIC (atomic_set_scm, (loc, SP_REF (val)));
+ scm_atomic_set_scm (loc, SP_REF (val));
NEXT (1);
}
@@ -2114,7 +2114,7 @@ VM_NAME (scm_thread *thread)
UNPACK_24 (ip[1], obj);
UNPACK_8_24 (ip[2], offset, val);
loc = SCM_CELL_OBJECT_LOC (SP_REF (obj), offset);
- SP_SET (dst, CALL_INTRINSIC (atomic_swap_scm, (loc, SP_REF (val))));
+ SP_SET (dst, scm_atomic_swap_scm (loc, SP_REF (val)));
NEXT (3);
}
@@ -2137,8 +2137,8 @@ VM_NAME (scm_thread *thread)
UNPACK_8_24 (ip[2], offset, expected);
UNPACK_24 (ip[3], desired);
loc = SCM_CELL_OBJECT_LOC (SP_REF (obj), offset);
- got = CALL_INTRINSIC (atomic_compare_and_swap_scm,
- (loc, SP_REF (expected), SP_REF (desired)));
+ got = scm_atomic_compare_and_swap_scm, (loc, SP_REF (expected),
+ SP_REF (desired));
SP_SET (dst, got);
NEXT (4);
}
- [Guile-commits] branch master updated (8b8ce79 -> 09e4fc4), Andy Wingo, 2019/05/27
- [Guile-commits] 01/09: Switch to use atomic_compare_exchange_strong, Andy Wingo, 2019/05/27
- [Guile-commits] 06/09: Inline the atomic intrinsics,
Andy Wingo <=
- [Guile-commits] 08/09: Fix accidental change to ARMv7 ldr, Andy Wingo, 2019/05/27
- [Guile-commits] 02/09: Correctly handle overflow when emitting literal pools, Andy Wingo, 2019/05/27
- [Guile-commits] 04/09: Merge remote-tracking branch 'lightening/master', Andy Wingo, 2019/05/27
- [Guile-commits] 07/09: Fix atomics usage in handle-interrupts JIT., Andy Wingo, 2019/05/27
- [Guile-commits] 05/09: Use new atomic instructions from lightening, Andy Wingo, 2019/05/27
- [Guile-commits] 09/09: Merge remote-tracking branch 'lightening/master', Andy Wingo, 2019/05/27
- [Guile-commits] 03/09: Add atomic operations, Andy Wingo, 2019/05/27