aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Option
diff options
context:
space:
mode:
authorPirama Arumuga Nainar <pirama@google.com>2015-04-23 11:06:58 -0700
committerPirama Arumuga Nainar <pirama@google.com>2015-04-30 17:59:43 -0700
commite1bc145815f4334641be19f1c45ecf85d25b6e5a (patch)
treeb861976c5addc22b42abe36cbbb596a04b84a1dc /lib/Option
parentb928ea3b96fd7bb0945799da90b7b122968ddc53 (diff)
downloadexternal_llvm-e1bc145815f4334641be19f1c45ecf85d25b6e5a.zip
external_llvm-e1bc145815f4334641be19f1c45ecf85d25b6e5a.tar.gz
external_llvm-e1bc145815f4334641be19f1c45ecf85d25b6e5a.tar.bz2
Export all dynamic symbols for opt and bugpoint
bug 15433215 Command line options from an LLVM module are registered and stored in a static global object in libLLVMSupport. Linking the Hello module with its own copy of libLLVMSupport meant this module's option was not registered correctly. This patch updates Hello's build rules to not link with libLLVMSupport and libLLVMCore. Given the above change, the Hello module still needs to find LLVM symbols that it used to pull directly. The second half of this patch adds linker flag --export-dynamic to tools/opt and tools/bugpoint so loaded modules can find LLVM symbols. Other notes: - The linker flag is not added to the device build of opt. No one should be running opt on the device, AFAIK. - Other tools that load modules, such as llc, lli and even clang, would need this linker flag if they were to load modules correctly. Now that we know how to fix the incorrect module loads, they can be fixed if the need arises. - Remove a duplicate from opt's llvm_opt_STATIC_LIBRARIES. All supported tests pass! Cherry pick of https://android-review.googlesource.com/#/c/148017/ from AOSP Change-Id: Ib76507ccfeae37a368718c5a1fb69da337f4f964
Diffstat (limited to 'lib/Option')
0 files changed, 0 insertions, 0 deletions