[PATCH] D14873: [tsan] Modify the tls_race.cc and tls_race2.cc tests to pass on OS X
Dmitry Vyukov via llvm-commits
llvm-commits at lists.llvm.org
Fri Nov 20 09:32:57 PST 2015
dvyukov added inline comments.
================
Comment at: test/tsan/tls_race.cc:23
@@ +22,2 @@
+// CHECK-FreeBSD: Location is TLS of main thread.
+// CHECK-Darwin: Location is heap block of size 4
----------------
kubabrecka wrote:
> dvyukov wrote:
> > How does the heap block allocation stack look like? Is it possible to figure out that this is TLS from the stack?
> >
> The stack looks like this:
>
> ```
> * frame #0: 0x0000000100077890 libclang_rt.tsan_osx_dynamic.dylib`::wrap_malloc(size=4294971592) at sanitizer_malloc_mac.inc:96
> frame #1: 0x00007fff86555d7d libdyld.dylib`tlv_allocate_and_initialize_for_key + 370
> frame #2: 0x00007fff8655652c libdyld.dylib`tlv_get_addr + 296
> frame #3: 0x0000000100000dc7 tls_race.cc.tmp`main + 55 at tls_race.cc:14 [opt]
> frame #4: 0x00007fff865565ad libdyld.dylib`start + 1
> ```
>
> To figure out this is a TLS, we could recognize that the caller is tlv_allocate_and_initialize_for_key, but for that we'd need to symbolicate first. FYI, there are no other calls to malloc from tlv_allocate_and_initialize_for_key. This function is internal (non-interceptible). If you have any easy solution in mind, please tell me.
OK, let's leave it as is for now.
http://reviews.llvm.org/D14873
More information about the llvm-commits
mailing list