summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLudovic Courtès <ludo@gnu.org>2020-03-17 22:51:40 +0100
committerLudovic Courtès <ludo@gnu.org>2020-03-17 22:57:41 +0100
commit89edd1bc2dcff50fb05c3598a846d6b51b172f7c (patch)
treed3f56b82ffedf8409ba0d62c58f6fa60144dd7a4
parent5d715dd467c19d2be5ab4c2b52e51e9a247a0867 (diff)
downloadguile-89edd1bc2dcff50fb05c3598a846d6b51b172f7c.tar.gz
Fix race condition between 'abort-to-prompt' and stack marking.
Fixes <https://bugs.gnu.org/28211>. * libguile/vm.c (scm_i_vm_emergency_abort, abort_to_prompt): Move 'vp->fp' assignment above 'sp[nargs]' assignments.
-rw-r--r--libguile/vm.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/libguile/vm.c b/libguile/vm.c
index b20c6eb5f..6fd5c554f 100644
--- a/libguile/vm.c
+++ b/libguile/vm.c
@@ -1385,6 +1385,11 @@ scm_i_vm_emergency_abort (SCM *tag_and_argv, size_t n)
fp = vp->stack_top - fp_offset;
sp = vp->stack_top - sp_offset;
+ /* Restore FP first so that a concurrent 'scm_i_vm_mark_stack' does
+ not overwrite the 'abort' arguments assigned below (see
+ <https://bugs.gnu.org/28211>). */
+ vp->fp = fp;
+
/* Continuation gets nargs+1 values: the one more is for the cont. */
sp = sp - nargs - 1;
@@ -1398,7 +1403,6 @@ scm_i_vm_emergency_abort (SCM *tag_and_argv, size_t n)
sp[nargs].as_scm = *argv++;
/* Restore VM regs */
- vp->fp = fp;
vp->sp = sp;
vp->ip = vra;
@@ -1456,6 +1460,11 @@ abort_to_prompt (scm_thread *thread, uint8_t *saved_mra)
/* Continuation gets nargs+1 values: the one more is for the cont. */
sp = sp - nargs - 1;
+ /* Restore FP first so that a concurrent 'scm_i_vm_mark_stack' does
+ not overwrite the 'abort' arguments assigned below (see
+ <https://bugs.gnu.org/28211>). */
+ vp->fp = fp;
+
/* Shuffle abort arguments down to the prompt continuation. We have
to be jumping to an older part of the stack. */
if (sp < vp->sp)
@@ -1465,7 +1474,6 @@ abort_to_prompt (scm_thread *thread, uint8_t *saved_mra)
sp[nargs] = vp->sp[nargs];
/* Restore VM regs */
- vp->fp = fp;
vp->sp = sp;
vp->ip = vra;