<div dir="ltr">Looks like libwidevinecdm.so is not publicly available. I don't know much about that binary blob, but it looks like it expects that that symbol is handled as if it were a global symbol.<div><br></div><div><a href="https://cs.chromium.org/chromium/src/third_party/tcmalloc/vendor/src/thread_cache.h?type=cs&q=threadlocal_heap_&sq=package:chromium&l=255">https://cs.chromium.org/chromium/src/third_party/tcmalloc/vendor/src/thread_cache.h?type=cs&q=threadlocal_heap_&sq=package:chromium&l=255</a></div><div><br></div><div>I'll send you a patch to reduce it to a warning.</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Dec 14, 2017 at 10:27 AM, Rafael Avila de Espindola <span dir="ltr"><<a href="mailto:rafael.espindola@gmail.com" target="_blank">rafael.espindola@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Is libwidevinecdm.so available somewhere?<br>
<br>
We can try to make it a warning, but what is the correct thing to do<br>
about _<wbr>ZN8tcmalloc11ThreadCache17thre<wbr>adlocal_heap_E? Should we skip it?<br>
Handle it as if it was global?<br>
<br>
Cheers,<br>
Rafael<br>
<div class="HOEnZb"><div class="h5"><br>
Hans Wennborg via Phabricator <<a href="mailto:reviews@reviews.llvm.org">reviews@reviews.llvm.org</a>> writes:<br>
<br>
> hans added a comment.<br>
><br>
> This fixes the assert, now we error on it, which breaks our build all the same. It's a pre-built .so, which I'm not sure exactly where it comes from:<br>
><br>
> FAILED: libwidevinecdmadapter.so<br>
> ../../../../../../../../work/<wbr>llvm/build.goma/bin/clang++ -shared libwidevinecdm.so -Wl,--fatal-warnings -Wl,--build-id=sha1 -fPIC -Wl,-z,noexecstack -Wl,-z,now -Wl,-z,relro -Wl,-z,defs -Wl,--no-as-needed -lpthread -Wl,--as-needed -fuse-ld=lld -Wl,--icf=all -flto=thin -Wl,--thinlto-jobs=8 -Wl,--thinlto-cache-dir=<wbr>thinlto-cache -Wl,--thinlto-cache-policy,<wbr>cache_size=10\% -Wl,--lto-O0 -fwhole-program-vtables -m64 -Werror -Wl,-O1 -Wl,--gc-sections -Wl,--gdb-index -nostdlib++ --sysroot=../../build/linux/<wbr>debian_stretch_amd64-sysroot -L../../build/linux/debian_<wbr>stretch_amd64-sysroot/lib/x86_<wbr>64-linux-gnu -Wl,-rpath-link=../../build/<wbr>linux/debian_stretch_amd64-<wbr>sysroot/lib/x86_64-linux-gnu -L../../build/linux/debian_<wbr>stretch_amd64-sysroot/usr/lib/<wbr>x86_64-linux-gnu -Wl,-rpath-link=../../build/<wbr>linux/debian_stretch_amd64-<wbr>sysroot/usr/lib/x86_64-linux-<wbr>gnu -fsanitize=cfi-vcall -Wl,-rpath=\$ORIGIN/. -Wl,-rpath-link=. -o "./libwidevinecdmadapter.so" -Wl,-soname="<wbr>libwidevinecdmadapter.so" @"./libwidevinecdmadapter.so.<wbr>rsp"<br>
> /usr/local/google/work/<wbr>chromium/src/out/release/../..<wbr>/../../../../../../work/llvm/<wbr>build.goma/bin/ld.lld: error: Found local symbol '_<wbr>ZN8tcmalloc11ThreadCache17thre<wbr>adlocal_heap_E' in global part of symbol table in file libwidevinecdm.so<br>
> clang-6.0: error: linker command failed with exit code 1 (use -v to see invocation)<br>
> ninja: build stopped: subcommand failed.<br>
><br>
> Maybe the erorr could be downgraded to a warning? (We'd need to not treat warnings as errors for this target on our side I suppose)<br>
><br>
><br>
> <a href="https://reviews.llvm.org/D41215" rel="noreferrer" target="_blank">https://reviews.llvm.org/<wbr>D41215</a><br>
</div></div></blockquote></div><br></div>