diff options
author | Andy Wingo <wingo@pobox.com> | 2018-09-14 08:42:41 +0200 |
---|---|---|
committer | Andy Wingo <wingo@pobox.com> | 2018-09-14 08:52:24 +0200 |
commit | bf31fe4cf6d75c96cc4ef29fea8808dd539da361 (patch) | |
tree | 31e180ad8951d60c87ae3f91b2cf0525f2a99f62 /libguile/vm.h | |
parent | ce5c05ac4aa105a8a7b855c6cb5d811ef672cf5b (diff) | |
download | guile-bf31fe4cf6d75c96cc4ef29fea8808dd539da361.tar.gz |
VM manages hook sets itself
* libguile/vm.h (SCM_VM_ABORT_HOOK): Rename from
SCM_VM_ABORT_CONTINUATION_HOOK.
* libguile/vm-engine.c (ABORT_HOOK):
* libguile/vm.c (invoke_abort_hook): Adapt to SCM_VM_ABORT_HOOK name
change.
(reset_vm_hook_enabled): New helper.
(VM_ADD_HOOK, VM_REMOVE_HOOK): New helper macros, replacing
VM_DEFINE_HOOK.
(scm_vm_add_abort_hook_x, scm_vm_remove_abort_hook_x)
(scm_vm_add_apply_hook_x, scm_vm_remove_apply_hook_x)
(scm_vm_add_return_hook_x, scm_vm_remove_return_hook_x)
(scm_vm_add_next_hook_x, scm_vm_remove_next_hook_x): New functions,
replacing direct access to the hooks. Allows us to know in a more
fine-grained way when to enable hooks.
(scm_set_vm_trace_level_x): Use reset_vm_hook_enabled to update the
individual hook_enabled flags.
* module/statprof.scm:
* module/system/vm/coverage.scm:
* module/system/vm/traps.scm:
* module/system/vm/vm.scm: Adapt VM hook users to the new API.
Diffstat (limited to 'libguile/vm.h')
-rw-r--r-- | libguile/vm.h | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/libguile/vm.h b/libguile/vm.h index a4dc78029..8f528f63c 100644 --- a/libguile/vm.h +++ b/libguile/vm.h @@ -29,7 +29,7 @@ enum { SCM_VM_APPLY_HOOK, SCM_VM_RETURN_HOOK, SCM_VM_NEXT_HOOK, - SCM_VM_ABORT_CONTINUATION_HOOK, + SCM_VM_ABORT_HOOK, SCM_VM_NUM_HOOKS, }; @@ -57,6 +57,7 @@ struct scm_vm { union scm_vm_stack_element *stack_top; /* highest address in allocated stack */ SCM overflow_handler_stack; /* alist of max-stack-size -> thunk */ SCM hooks[SCM_VM_NUM_HOOKS]; /* hooks */ + uint8_t hooks_enabled[SCM_VM_NUM_HOOKS]; /* if corresponding hook is enabled */ jmp_buf *registers; /* registers captured at latest vm entry */ uint8_t *mra_after_abort; /* mra to resume after nonlocal exit, or NULL */ int engine; /* which vm engine we're using */ @@ -67,10 +68,14 @@ SCM_API SCM scm_call_with_vm (SCM proc, SCM args); SCM_API SCM scm_call_with_stack_overflow_handler (SCM limit, SCM thunk, SCM handler); -SCM_API SCM scm_vm_apply_hook (void); -SCM_API SCM scm_vm_return_hook (void); -SCM_API SCM scm_vm_abort_continuation_hook (void); -SCM_API SCM scm_vm_next_hook (void); +SCM_INTERNAL SCM scm_vm_add_apply_hook_x (SCM); +SCM_INTERNAL SCM scm_vm_add_return_hook_x (SCM); +SCM_INTERNAL SCM scm_vm_add_abort_hook_x (SCM); +SCM_INTERNAL SCM scm_vm_add_next_hook_x (SCM); +SCM_INTERNAL SCM scm_vm_remove_apply_hook_x (SCM); +SCM_INTERNAL SCM scm_vm_remove_return_hook_x (SCM); +SCM_INTERNAL SCM scm_vm_remove_abort_hook_x (SCM); +SCM_INTERNAL SCM scm_vm_remove_next_hook_x (SCM); SCM_API SCM scm_vm_trace_level (void); SCM_API SCM scm_set_vm_trace_level_x (SCM level); SCM_API SCM scm_vm_engine (void); |