mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-11 22:31:12 +02:00
Refactor vm_abort
* libguile/vm.c (vm_abort): * libguile/vm-i-system.c (abort): Refactor abort interface so that it is more amenable to the RTL VM.
This commit is contained in:
parent
5bd4b6585b
commit
99511cd0ab
2 changed files with 20 additions and 17 deletions
|
@ -1475,10 +1475,14 @@ VM_DEFINE_INSTRUCTION (88, wind, "wind", 0, 2, 0)
|
|||
|
||||
VM_DEFINE_INSTRUCTION (89, abort, "abort", 1, -1, -1)
|
||||
{
|
||||
unsigned n = FETCH ();
|
||||
SYNC_REGISTER ();
|
||||
ptrdiff_t n = FETCH ();
|
||||
SCM tag, *stack_args, tail;
|
||||
PRE_CHECK_UNDERFLOW (n + 2);
|
||||
vm_abort (vm, n, ®isters);
|
||||
SYNC_REGISTER ();
|
||||
tail = sp[0];
|
||||
stack_args = sp - n;
|
||||
tag = sp[-(n + 1)];
|
||||
vm_abort (vm, tag, n, stack_args, tail, sp - (n + 2), ®isters);
|
||||
/* vm_abort should not return */
|
||||
abort ();
|
||||
}
|
||||
|
|
|
@ -273,33 +273,32 @@ vm_dispatch_hook (SCM vm, int hook_num, SCM *argv, int n)
|
|||
}
|
||||
|
||||
static void
|
||||
vm_abort (SCM vm, size_t n, scm_i_jmp_buf *current_registers) SCM_NORETURN;
|
||||
vm_abort (SCM vm, SCM tag, size_t nstack, SCM *stack_args, SCM tail, SCM *sp,
|
||||
scm_i_jmp_buf *current_registers) SCM_NORETURN;
|
||||
|
||||
static void
|
||||
vm_abort (SCM vm, size_t n, scm_i_jmp_buf *current_registers)
|
||||
vm_abort (SCM vm, SCM tag, size_t nstack, SCM *stack_args, SCM tail, SCM *sp,
|
||||
scm_i_jmp_buf *current_registers)
|
||||
{
|
||||
size_t i;
|
||||
ssize_t tail_len;
|
||||
SCM tag, tail, *argv;
|
||||
SCM *argv;
|
||||
|
||||
/* FIXME: VM_ENABLE_STACK_NULLING */
|
||||
tail = *(SCM_VM_DATA (vm)->sp--);
|
||||
/* NULLSTACK (1) */
|
||||
tail_len = scm_ilength (tail);
|
||||
if (tail_len < 0)
|
||||
scm_misc_error ("vm-engine", "tail values to abort should be a list",
|
||||
scm_list_1 (tail));
|
||||
|
||||
tag = SCM_VM_DATA (vm)->sp[-n];
|
||||
argv = alloca ((n + tail_len) * sizeof (SCM));
|
||||
for (i = 0; i < n; i++)
|
||||
argv[i] = SCM_VM_DATA (vm)->sp[-(n-1-i)];
|
||||
for (; i < n + tail_len; i++, tail = scm_cdr (tail))
|
||||
argv = alloca ((nstack + tail_len) * sizeof (SCM));
|
||||
for (i = 0; i < nstack; i++)
|
||||
argv[i] = stack_args[i];
|
||||
for (; i < nstack + tail_len; i++, tail = scm_cdr (tail))
|
||||
argv[i] = scm_car (tail);
|
||||
/* NULLSTACK (n + 1) */
|
||||
SCM_VM_DATA (vm)->sp -= n + 1;
|
||||
|
||||
scm_c_abort (vm, tag, n + tail_len, argv, current_registers);
|
||||
/* FIXME: NULLSTACK (SCM_VM_DATA (vp)->sp - sp) */
|
||||
SCM_VM_DATA (vm)->sp = sp;
|
||||
|
||||
scm_c_abort (vm, tag, nstack + tail_len, argv, current_registers);
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue