[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Guile-commits] 05/09: Fix JIT asserts with different code generated by
From: |
Andy Wingo |
Subject: |
[Guile-commits] 05/09: Fix JIT asserts with different code generated by baseline |
Date: |
Mon, 11 May 2020 09:08:28 -0400 (EDT) |
wingo pushed a commit to branch master
in repository guile.
commit 1563f5e042e101cc065cff0452e9e842deb38447
Author: Andy Wingo <address@hidden>
AuthorDate: Mon May 11 14:34:35 2020 +0200
Fix JIT asserts with different code generated by baseline
* libguile/jit.c (UNREACHABLE): New register state.
(unreachable): New predicate.
(ASSERT_HAS_REGISTER_STATE): Succeed when unreachable.
(compile_throw, compile_throw_value, compile_throw_value_and_data):
Set unreachable flag.
(compile_receive_values): Reload FP if needed.
---
libguile/jit.c | 27 ++++++++++++++++++++++-----
1 file changed, 22 insertions(+), 5 deletions(-)
diff --git a/libguile/jit.c b/libguile/jit.c
index ede16ea..1e34b4f 100644
--- a/libguile/jit.c
+++ b/libguile/jit.c
@@ -261,8 +261,9 @@ static const jit_gpr_t T1_PRESERVED = JIT_V2;
static const uint32_t SP_IN_REGISTER = 0x1;
static const uint32_t FP_IN_REGISTER = 0x2;
-static const uint32_t SP_CACHE_GPR = 0x4;
-static const uint32_t SP_CACHE_FPR = 0x8;
+static const uint32_t UNREACHABLE = 0x4;
+static const uint32_t SP_CACHE_GPR = 0x8;
+static const uint32_t SP_CACHE_FPR = 0x10;
static const uint8_t OP_ATTR_BLOCK = 0x1;
static const uint8_t OP_ATTR_ENTRY = 0x2;
@@ -355,12 +356,19 @@ set_register_state (scm_jit_state *j, uint32_t state)
}
static uint32_t
+unreachable (scm_jit_state *j)
+{
+ return j->register_state & UNREACHABLE;
+}
+
+static uint32_t
has_register_state (scm_jit_state *j, uint32_t state)
{
return (j->register_state & state) == state;
}
-#define ASSERT_HAS_REGISTER_STATE(state) ASSERT (has_register_state (j, state))
+#define ASSERT_HAS_REGISTER_STATE(state) \
+ ASSERT (unreachable (j) || has_register_state (j, state));
static void
record_gpr_clobber (scm_jit_state *j, jit_gpr_t r)
@@ -1622,6 +1630,12 @@ compile_receive_values (scm_jit_state *j, uint32_t proc,
uint8_t allow_extra,
{
jit_gpr_t t = T0;
+ /* Although most uses of receive-values are after a call returns, the
+ baseline compiler will sometimes emit it elsewhere. In that case
+ ensure that FP is in a register for the frame-locals-count
+ branches. */
+ restore_reloadable_register_state (j, FP_IN_REGISTER);
+
if (allow_extra)
add_slow_path_patch
(j, emit_branch_if_frame_locals_count_less_than (j, t, proc + nvalues));
@@ -1873,6 +1887,7 @@ compile_throw (scm_jit_state *j, uint16_t key, uint16_t
args)
emit_call_2 (j, scm_vm_intrinsics.throw_, sp_scm_operand (j, key),
sp_scm_operand (j, args));
/* throw_ does not return. */
+ set_register_state (j, UNREACHABLE);
}
static void
compile_throw_slow (scm_jit_state *j, uint16_t key, uint16_t args)
@@ -1887,7 +1902,8 @@ compile_throw_value (scm_jit_state *j, uint32_t val,
emit_call_2 (j, scm_vm_intrinsics.throw_with_value, sp_scm_operand (j, val),
jit_operand_imm (JIT_OPERAND_ABI_POINTER,
(intptr_t) key_subr_and_message));
- /* throw_with_value does not return. */
+ /* Like throw_, throw_with_value does not return. */
+ set_register_state (j, UNREACHABLE);
}
static void
compile_throw_value_slow (scm_jit_state *j, uint32_t val,
@@ -1904,7 +1920,8 @@ compile_throw_value_and_data (scm_jit_state *j, uint32_t
val,
sp_scm_operand (j, val),
jit_operand_imm (JIT_OPERAND_ABI_POINTER,
(intptr_t) key_subr_and_message));
- /* throw_with_value_and_data does not return. */
+ /* Like throw_, throw_with_value_and_data does not return. */
+ set_register_state (j, UNREACHABLE);
}
static void
compile_throw_value_and_data_slow (scm_jit_state *j, uint32_t val,
- [Guile-commits] branch master updated (f168a66 -> 2ba3eb4), Andy Wingo, 2020/05/11
- [Guile-commits] 03/09: Baseline compiler: add pop-fluid primitive., Andy Wingo, 2020/05/11
- [Guile-commits] 06/09: Fix module capture for closures in <fix>, Andy Wingo, 2020/05/11
- [Guile-commits] 01/09: Fix baseline miscompilation of <, Andy Wingo, 2020/05/11
- [Guile-commits] 02/09: Fix baseline compilation error for make-struct/simple, Andy Wingo, 2020/05/11
- [Guile-commits] 04/09: Fix "cons" compilation in baseline compiler in some cases, Andy Wingo, 2020/05/11
- [Guile-commits] 07/09: Reload FP if needed in bind-rest also, Andy Wingo, 2020/05/11
- [Guile-commits] 08/09: Improve tail recursion in compiler, Andy Wingo, 2020/05/11
- [Guile-commits] 09/09: Fix shuffling assembler for new primcalls, Andy Wingo, 2020/05/11
- [Guile-commits] 05/09: Fix JIT asserts with different code generated by baseline,
Andy Wingo <=