aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorPhilipp Stephani2020-07-25 23:23:19 +0200
committerPhilipp Stephani2020-07-31 18:18:43 +0200
commitd767418b76818e4e83bf19cc08307c1329144c13 (patch)
treec31e705f8b49e9e92c0bd94fd83e3742e1b080ec /src
parent8c94ca94dc2772e5c651de6cf46bfffc388234d5 (diff)
downloademacs-d767418b76818e4e83bf19cc08307c1329144c13.tar.gz
emacs-d767418b76818e4e83bf19cc08307c1329144c13.zip
Backport: Make checking for liveness of global values more precise.
We can't just use a hash lookup because a global and a local reference might refer to the same Lisp object. * src/emacs-module.c (module_free_global_ref): More precise check for global liveness. (cherry picked from commit 9f01ce6327af886f26399924a9aadf16cdd4fd9f)
Diffstat (limited to 'src')
-rw-r--r--src/emacs-module.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/src/emacs-module.c b/src/emacs-module.c
index 099a6a3cf25..a90a9765dbf 100644
--- a/src/emacs-module.c
+++ b/src/emacs-module.c
@@ -448,6 +448,14 @@ module_free_global_ref (emacs_env *env, emacs_value ref)
448 Lisp_Object obj = value_to_lisp (ref); 448 Lisp_Object obj = value_to_lisp (ref);
449 ptrdiff_t i = hash_lookup (h, obj, NULL); 449 ptrdiff_t i = hash_lookup (h, obj, NULL);
450 450
451 if (module_assertions)
452 {
453 ptrdiff_t n = 0;
454 if (! module_global_reference_p (ref, &n))
455 module_abort ("Global value was not found in list of %"pD"d globals",
456 n);
457 }
458
451 if (i >= 0) 459 if (i >= 0)
452 { 460 {
453 Lisp_Object value = HASH_VALUE (h, i); 461 Lisp_Object value = HASH_VALUE (h, i);
@@ -456,11 +464,6 @@ module_free_global_ref (emacs_env *env, emacs_value ref)
456 if (--ref->refcount == 0) 464 if (--ref->refcount == 0)
457 hash_remove_from_table (h, obj); 465 hash_remove_from_table (h, obj);
458 } 466 }
459 else if (module_assertions)
460 {
461 module_abort ("Global value was not found in list of %"pD"d globals",
462 h->count);
463 }
464} 467}
465 468
466static enum emacs_funcall_exit 469static enum emacs_funcall_exit