X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=libgc%2Fmark_rts.c;h=561333ab04d672ca249142e11a2b77654adbee38;hb=098e88f3a87205d92516a1fe912b6f84164d0a59;hp=b3e996a29c2d51645a8cd9374ff53194dad84e7d;hpb=3fd4901a235bda0019f03317f4ee083744195758;p=mono.git diff --git a/libgc/mark_rts.c b/libgc/mark_rts.c index b3e996a29c2..561333ab04d 100644 --- a/libgc/mark_rts.c +++ b/libgc/mark_rts.c @@ -368,6 +368,9 @@ ptr_t p; ptr_t GC_approx_sp() { +#if defined(__GNUC__) + return __builtin_frame_address(0); +#else VOLATILE word dummy; dummy = 42; /* Force stack to grow if necessary. Otherwise the */ @@ -375,18 +378,12 @@ ptr_t GC_approx_sp() /* doing something wrong. */ # ifdef _MSC_VER # pragma warning(disable:4172) -# endif -# if defined(__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ >= 408) -# pragma GCC diagnostic push -# pragma GCC diagnostic ignored "-Wreturn-local-addr" # endif return((ptr_t)(&dummy)); -# if defined(__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ >= 408) -# pragma GCC diagnostic pop -# endif # ifdef _MSC_VER # pragma warning(default:4172) # endif +#endif // __GNUC__ } /*