]> granicus.if.org Git - gc/commitdiff
Fix 'bogus LR' detection in FindTopOfStack (Darwin)
authorIvan Maidanski <ivmai@mail.ru>
Wed, 7 Dec 2016 08:02:59 +0000 (11:02 +0300)
committerIvan Maidanski <ivmai@mail.ru>
Mon, 6 Feb 2017 16:57:26 +0000 (19:57 +0300)
(fix commit 5742f86)

* darwin_stop_world.c [!DARWIN_DONT_PARSE_STACK] (GC_FindTopOfStack):
Use "UL" suffix (instead of "U") for 0x3 (on the right side of the
comparison) to avoid implicit unsigned int-to-long value extension
of "~" operator result.

darwin_stop_world.c

index 7cd5775f5c0046d101afc51b995bb1ba769e0f5c..37aee97dbcb4c5ec11b11690700e11c705bd2751 100644 (file)
@@ -83,7 +83,7 @@ GC_INNER ptr_t GC_FindTopOfStack(unsigned long stack_start)
     /* we do these next two checks after going to the next frame
        because the LR for the first stack frame in the loop
        is not set up on purpose, so we shouldn't check it. */
-    if ((frame->savedLR & ~0x3) == 0 || (frame->savedLR & ~0x3) == ~0x3U)
+    if ((frame->savedLR & ~0x3) == 0 || (frame->savedLR & ~0x3) == ~0x3UL)
       break; /* if the next LR is bogus, stop */
   }
 # ifdef DEBUG_THREADS_EXTRA