folly/detail/ThreadLocalDetail.h: avoid UBSAN-detected memcpy abuse
authorJim Meyering <meyering@fb.com>
Wed, 25 Nov 2015 19:06:24 +0000 (11:06 -0800)
committerfacebook-github-bot-4 <folly-bot@fb.com>
Wed, 25 Nov 2015 19:20:23 +0000 (11:20 -0800)
commitf6f52f3e575f1c7dc75bddcfa39db37e79753836
treec4e7e20ac8bc7fff95c64e64a160f1ade8db8044
parentffe26edc53bc90a14078c66e46764ea3e6a81df6
folly/detail/ThreadLocalDetail.h: avoid UBSAN-detected memcpy abuse

Summary: [technically, the existing code is probably a no-op on
all systems we care about, but since it is officially UB, switching
to a more strict platform could cause trouble, so it's worth fixing]

Calling memcpy with "nullptr" as 2nd argument is undefined, even when
the third argument is zero, and causes a failure when testing with an
UBSAN-enabled binary (-fsanitize=undefined).
Before this change, the buck-run test below would evoke this failure:

  [ RUN      ] ThreadLocalPtr.BasicDestructor
  folly/detail/ThreadLocalDetail.h:533:29: runtime error: null pointer passed as argument 2, which is declared to never be null
  third-party-buck/build/glibc/include/string.h:47:45: note: nonnull attribute specified here

Ironically, the failure of the target-determinator-buck_push_blocking test (due to an unrelated proxygen dep problem) would block me from landing this, so I am adding this line to override it.

Reviewed By: luciang, alexshap

Differential Revision: D2692625

fb-gh-sync-id: 8bdc5cd2899705f39c9565d640921de1f363807d
folly/detail/ThreadLocalDetail.h