]> granicus.if.org Git - gc/commitdiff
Do not allow SHORT_DBG_HDRS if KEEP_BACK_PTRS or MAKE_BACK_GRAPH
authorIvan Maidanski <ivmai@mail.ru>
Tue, 2 Aug 2016 09:01:48 +0000 (12:01 +0300)
committerIvan Maidanski <ivmai@mail.ru>
Tue, 2 Aug 2016 09:01:48 +0000 (12:01 +0300)
Otherwise GC_HAS_DEBUG_INFO (defined as (p&1)) might return true
if a non-pointer is stored at the beginning of the tested object
leading further to its corruption by GC_store_back_pointer.
See issue #125 for details.

* include/private/dbg_mlc.h [KEEP_BACK_PTRS || MAKE_BACK_GRAPH]
(GC_HAS_DEBUG_INFO): Add #error (with the appropriate message) in
case of SHORT_DBG_HDRS defined.

include/private/dbg_mlc.h

index 663de702fe134ecf4f828cc3d8111b6d975dc036..ae2c70e9d26bf5951ce08bc87f23a7a280af74f6 100644 (file)
@@ -157,6 +157,10 @@ typedef struct {
 #endif
 
 #if defined(KEEP_BACK_PTRS) || defined(MAKE_BACK_GRAPH)
+# ifdef SHORT_DBG_HDRS
+#   error Non-ptr stored in object results in GC_HAS_DEBUG_INFO malfunction
+    /* We may mistakenly conclude that p has a debugging wrapper.       */
+# endif
 # define GC_HAS_DEBUG_INFO(p) \
         ((*((word *)p) & 1) && GC_has_other_debug_info(p) > 0)
 #else