From: Yedidya Feldblum Date: Sun, 10 Dec 2017 01:09:24 +0000 (-0800) Subject: Fix signed integer overflow in StaticTracepointTest.cpp X-Git-Tag: v2017.12.11.00~3 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=015306906e2811cc0cf3dab0c4142d45434a2801;p=folly.git Fix signed integer overflow in StaticTracepointTest.cpp Summary: [Folly] Fix signed integer overflow in `StaticTracepointTest.cpp`. It is undefined behavior and is caught by UBSAN in some test runs. Reviewed By: Orvid Differential Revision: D6528445 fbshipit-source-id: e4a199e9005b57bcd93c8c4b69f37ccb1e072bdf --- diff --git a/folly/tracing/test/StaticTracepointTest.cpp b/folly/tracing/test/StaticTracepointTest.cpp index 75a89b7c..df472b98 100644 --- a/folly/tracing/test/StaticTracepointTest.cpp +++ b/folly/tracing/test/StaticTracepointTest.cpp @@ -234,11 +234,11 @@ static bool getTracepointArguments( return false; } -static int arrayTestFunc() { - int v1 = folly::Random::rand32(); - int v2 = folly::Random::rand32(); - int64_t v3 = v1 + v2; - int a[4] = {v1, v2, v1, v2}; +static uint32_t arrayTestFunc() { + uint32_t v1 = folly::Random::rand32(); + uint32_t v2 = folly::Random::rand32(); + uint64_t v3 = v1 + v2; + uint32_t a[4] = {v1, v2, v1, v2}; FOLLY_SDT(folly, test_static_tracepoint_array, a, v1, v3); return v1 + v2; } @@ -253,9 +253,9 @@ TEST(StaticTracepoint, TestArray) { checkTracepointArguments(arguments, expected); } -static int pointerTestFunc() { - int v1 = folly::Random::rand32(); - int v2 = folly::Random::rand32(); +static uint32_t pointerTestFunc() { + uint32_t v1 = folly::Random::rand32(); + uint32_t v2 = folly::Random::rand32(); std::string str = "test string"; const char* a = str.c_str(); FOLLY_SDT(folly, test_static_tracepoint_pointer, a, v2, &v1); @@ -285,7 +285,7 @@ TEST(StaticTracepoint, TestEmpty) { EXPECT_TRUE(arguments.empty()); } -static int manyArgTypesTestFunc() { +static uint32_t manyArgTypesTestFunc() { uint32_t a = folly::Random::rand32(); uint32_t b = folly::Random::rand32(); bool bool_ = (a % 2) == (b % 2); @@ -327,7 +327,7 @@ TEST(StaticTracepoint, TestManyArgTypes) { checkTracepointArguments(arguments, expected); } -FOLLY_ALWAYS_INLINE static int alwaysInlineTestFunc() { +FOLLY_ALWAYS_INLINE static uint32_t alwaysInlineTestFunc() { uint32_t a = folly::Random::rand32(); uint32_t b = folly::Random::rand32(); FOLLY_SDT(folly, test_static_tracepoint_always_inline, a, b); @@ -346,7 +346,7 @@ TEST(StaticTracepoint, TestAlwaysInline) { static void branchTestFunc() { uint32_t a = folly::Random::rand32(); - uint32_t b = folly::Random::rand32(); + uint32_t b = std::max(1u, folly::Random::rand32()); if (a > b) { FOLLY_SDT(folly, test_static_tracepoint_branch_1, a / b); } else {