From: Ivan Maidanski Date: Mon, 12 Dec 2016 23:34:28 +0000 (+0300) Subject: Fix GC_noop6 definition to avoid its calls to be optimized away X-Git-Tag: v8.0.0~990 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e3ec4a5;p=gc Fix GC_noop6 definition to avoid its calls to be optimized away * include/private/gc_priv.h (GC_ATTR_NOINLINE): New macro (effective for GCC/Clang and MS VC currently). * mark.c (GC_noop6): Use GC_ATTR_NOINLINE attribute; call AO_compiler_barrier if available, otherwise call GC_noop1(0); add comment. --- diff --git a/include/private/gc_priv.h b/include/private/gc_priv.h index 3d80ac44..a92fba0f 100644 --- a/include/private/gc_priv.h +++ b/include/private/gc_priv.h @@ -192,6 +192,16 @@ typedef char * ptr_t; /* A generic pointer to which we can add */ # define GC_INLINE static #endif +#ifndef GC_ATTR_NOINLINE +# if __GNUC__ >= 4 +# define GC_ATTR_NOINLINE __attribute__((__noinline__)) +# elif _MSC_VER >= 14 +# define GC_ATTR_NOINLINE __declspec(noinline) +# else +# define GC_ATTR_NOINLINE /* empty */ +# endif +#endif + #ifndef GC_API_OSCALL /* This is used to identify GC routines called by name from OS. */ # if defined(__GNUC__) diff --git a/mark.c b/mark.c index f631ab5f..1fd7a660 100644 --- a/mark.c +++ b/mark.c @@ -24,11 +24,17 @@ /* Make arguments appear live to compiler. Put here to minimize the */ /* risk of inlining. Used to minimize junk left in registers. */ +GC_ATTR_NOINLINE void GC_noop6(word arg1 GC_ATTR_UNUSED, word arg2 GC_ATTR_UNUSED, word arg3 GC_ATTR_UNUSED, word arg4 GC_ATTR_UNUSED, word arg5 GC_ATTR_UNUSED, word arg6 GC_ATTR_UNUSED) { - /* Empty */ + /* Avoid GC_noop6 calls to be optimized away. */ +# ifdef AO_compiler_barrier + AO_compiler_barrier(); /* to serve as a special side-effect */ +# else + GC_noop1(0); +# endif } /* Single argument version, robust against whole program analysis. */