diff options
Diffstat (limited to 'src/bytecode.c')
| -rw-r--r-- | src/bytecode.c | 49 | 
1 files changed, 5 insertions, 44 deletions
| diff --git a/src/bytecode.c b/src/bytecode.c index 55789b41ad9..86d44aba46b 100644 --- a/src/bytecode.c +++ b/src/bytecode.c @@ -296,7 +296,7 @@ enum byte_code_op  };  /* Whether to maintain a `top' and `bottom' field in the stack frame.  */ -#define BYTE_MAINTAIN_TOP (BYTE_CODE_SAFE || BYTE_MARK_STACK) +#define BYTE_MAINTAIN_TOP BYTE_CODE_SAFE  /* Structure describing a value stack used during byte-code execution     in Fbyte_code.  */ @@ -319,12 +319,6 @@ struct byte_stack    Lisp_Object byte_string;    const unsigned char *byte_string_start; -#if BYTE_MARK_STACK -  /* The vector of constants used during byte-code execution.  Storing -     this here protects it from GC because mark_byte_stack marks it.  */ -  Lisp_Object constants; -#endif -    /* Next entry in byte_stack_list.  */    struct byte_stack *next;  }; @@ -332,46 +326,16 @@ struct byte_stack  /* A list of currently active byte-code execution value stacks.     Fbyte_code adds an entry to the head of this list before it starts     processing byte-code, and it removes the entry again when it is -   done.  Signaling an error truncates the list analogous to -   gcprolist.  */ +   done.  Signaling an error truncates the list.  */  struct byte_stack *byte_stack_list; -/* Mark objects on byte_stack_list.  Called during GC.  */ - -#if BYTE_MARK_STACK -void -mark_byte_stack (void) -{ -  struct byte_stack *stack; -  Lisp_Object *obj; - -  for (stack = byte_stack_list; stack; stack = stack->next) -    { -      /* If STACK->top is null here, this means there's an opcode in -	 Fbyte_code that wasn't expected to GC, but did.  To find out -	 which opcode this is, record the value of `stack', and walk -	 up the stack in a debugger, stopping in frames of Fbyte_code. -	 The culprit is found in the frame of Fbyte_code where the -	 address of its local variable `stack' is equal to the -	 recorded value of `stack' here.  */ -      eassert (stack->top); - -      for (obj = stack->bottom; obj <= stack->top; ++obj) -	mark_object (*obj); - -      mark_object (stack->byte_string); -      mark_object (stack->constants); -    } -} -#endif - -/* Unmark objects in the stacks on byte_stack_list.  Relocate program -   counters.  Called when GC has completed.  */ +/* Relocate program counters in the stacks on byte_stack_list.  Called +   when GC has completed.  */  void -unmark_byte_stack (void) +relocate_byte_stack (void)  {    struct byte_stack *stack; @@ -554,9 +518,6 @@ exec_byte_code (Lisp_Object bytestr, Lisp_Object vector, Lisp_Object maxdepth,    stack.byte_string = bytestr;    stack.pc = stack.byte_string_start = SDATA (bytestr); -#if BYTE_MARK_STACK -  stack.constants = vector; -#endif    if (MAX_ALLOCA / word_size <= XFASTINT (maxdepth))      memory_full (SIZE_MAX);    top = alloca ((XFASTINT (maxdepth) + 1) * sizeof *top); | 
