From: Peter Collingbourne Date: Thu, 3 Jul 2014 23:28:03 +0000 (+0000) Subject: gold plugin: move target initialization to the top of the onload function. X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=1505c0a4be67089868d26c9486e9822d38762bab;p=platform%2Fupstream%2Fllvm.git gold plugin: move target initialization to the top of the onload function. On at least my machine, ar does not register an all symbols read hook (which previously triggered target initialization), but it does register a claim files hook, which depends on the targets being initialized. Differential Revision: http://reviews.llvm.org/D4372 llvm-svn: 212303 --- diff --git a/llvm/tools/gold/gold-plugin.cpp b/llvm/tools/gold/gold-plugin.cpp index 2c6257a..343a739 100644 --- a/llvm/tools/gold/gold-plugin.cpp +++ b/llvm/tools/gold/gold-plugin.cpp @@ -135,6 +135,12 @@ static ld_plugin_status cleanup_hook(void); extern "C" ld_plugin_status onload(ld_plugin_tv *tv); ld_plugin_status onload(ld_plugin_tv *tv) { + InitializeAllTargetInfos(); + InitializeAllTargets(); + InitializeAllTargetMCs(); + InitializeAllAsmParsers(); + InitializeAllAsmPrinters(); + // We're given a pointer to the first transfer vector. We read through them // until we find one where tv_tag == LDPT_NULL. The REGISTER_* tagged values // contain pointers to functions that we need to call to register our own @@ -228,11 +234,6 @@ ld_plugin_status onload(ld_plugin_tv *tv) { if (!RegisteredAllSymbolsRead) return LDPS_OK; - InitializeAllTargetInfos(); - InitializeAllTargets(); - InitializeAllTargetMCs(); - InitializeAllAsmParsers(); - InitializeAllAsmPrinters(); CodeGen = new LTOCodeGenerator(); // Pass through extra options to the code generator.