aboutsummaryrefslogtreecommitdiffstats
path: root/src/alloc.c
diff options
context:
space:
mode:
authorAlan Mackenzie2019-04-05 12:18:53 +0000
committerAlan Mackenzie2019-04-05 12:18:53 +0000
commitb071398ba3e8031fe8284f2aed95d714cd3c92af (patch)
treed27dd7d78dfff9a8b28778bee260dbbdf6c10e1d /src/alloc.c
parent8a23e8717008d31b4648c999c7a417f4729d239f (diff)
downloademacs-scratch/accurate-warning-pos.tar.gz
emacs-scratch/accurate-warning-pos.zip
Enhance struct Lisp_Subr to hold the alternative "BC_" function.scratch/accurate-warning-pos
Also fix a GC bug, where symbols with position were not being disabled. * src/lisp.h (union Lisp_Function): New type. (struct Lisp_Subr): Add fields normal_function, BC_function, and next. (DEFUN): Setup all three function fields to the subr (BC_function is still a dummy), set field next to NULL. * src/alloc.c (Fgarbage_collect): Move the binding of Qsymbols_with_pos_enabled to garbage_collect_1 so that it gets bound when GC is invoked via garbage_collect. * src/lread.c (subr_ptr, using_BC_subrs): New static variables. (Fswitch_to_BC_subrs, Fswitch_to_normal_subrs): New defuns. (defsubr): Chain new subr to previous using field next and variable subr_ptr. (init_lread): Initialise subr_ptr to NULL. (syms_of_lread): Create subrs Sswitch_to_BC_subrs and Sswitch_to_normal_subrs. * src/pdumper.c (dump_subr): Enhance to dump struct Lisp_Subr's new fields. Update the expected value of HASH_Lisp_Subr_xxxxxxxxxx. (dump_vectorlike): Also dump PVEC_SYMBOL_WITH_POSes.
Diffstat (limited to 'src/alloc.c')
-rw-r--r--src/alloc.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/src/alloc.c b/src/alloc.c
index 035b45864d9..e14b0d577a8 100644
--- a/src/alloc.c
+++ b/src/alloc.c
@@ -6053,12 +6053,17 @@ garbage_collect_1 (struct gcstat *gcst)
6053 struct timespec start; 6053 struct timespec start;
6054 byte_ct tot_before = 0; 6054 byte_ct tot_before = 0;
6055 6055
6056 specbind (Qsymbols_with_pos_enabled, Qnil);
6057
6056 eassert (weak_hash_tables == NULL); 6058 eassert (weak_hash_tables == NULL);
6057 6059
6058 /* Can't GC if pure storage overflowed because we can't determine 6060 /* Can't GC if pure storage overflowed because we can't determine
6059 if something is a pure object or not. */ 6061 if something is a pure object or not. */
6060 if (pure_bytes_used_before_overflow) 6062 if (pure_bytes_used_before_overflow)
6061 return false; 6063 {
6064 unbind_to (count, Qnil);
6065 return false;
6066 }
6062 6067
6063 /* Record this function, so it appears on the profiler's backtraces. */ 6068 /* Record this function, so it appears on the profiler's backtraces. */
6064 record_in_backtrace (QAutomatic_GC, 0, 0); 6069 record_in_backtrace (QAutomatic_GC, 0, 0);
@@ -6249,6 +6254,7 @@ garbage_collect_1 (struct gcstat *gcst)
6249 malloc_probe (min (swept, SIZE_MAX)); 6254 malloc_probe (min (swept, SIZE_MAX));
6250 } 6255 }
6251 6256
6257 unbind_to (count, Qnil);
6252 return true; 6258 return true;
6253} 6259}
6254 6260
@@ -6276,11 +6282,9 @@ returns nil, because real GC can't be done.
6276See Info node `(elisp)Garbage Collection'. */) 6282See Info node `(elisp)Garbage Collection'. */)
6277 (void) 6283 (void)
6278{ 6284{
6279 ptrdiff_t count = SPECPDL_INDEX ();
6280 struct gcstat gcst; 6285 struct gcstat gcst;
6281 specbind (Qsymbols_with_pos_enabled, Qnil);
6282 if (!garbage_collect_1 (&gcst)) 6286 if (!garbage_collect_1 (&gcst))
6283 return unbind_to (count, Qnil); 6287 return Qnil;
6284 6288
6285 Lisp_Object total[] = { 6289 Lisp_Object total[] = {
6286 list4 (Qconses, make_fixnum (sizeof (struct Lisp_Cons)), 6290 list4 (Qconses, make_fixnum (sizeof (struct Lisp_Cons)),
@@ -6315,7 +6319,7 @@ See Info node `(elisp)Garbage Collection'. */)
6315 make_int ((mallinfo ().fordblks + 1023) >> 10)), 6319 make_int ((mallinfo ().fordblks + 1023) >> 10)),
6316#endif 6320#endif
6317 }; 6321 };
6318 return unbind_to (count, CALLMANY (Flist, total)); 6322 return CALLMANY (Flist, total);
6319} 6323}
6320 6324
6321/* Mark Lisp objects in glyph matrix MATRIX. Currently the 6325/* Mark Lisp objects in glyph matrix MATRIX. Currently the