forked from OSchip/llvm-project
[ELF] accept thinlto options without --plugin-opt= prefix
Summary: When support for ThinLTO was first added to lld, the options that control it were prefixed with --plugin-opt= for compatibility with an existing implementation as a linker plugin. This change enables shorter versions of the options to be used, as follows: New Existing -thinlto-emit-imports-files --plugin-opt=thinlto-emit-imports-files -thinlto-index-only --plugin-opt=thinlto-index-only -thinlto-index-only= --plugin-opt=thinlto-index-only= -thinlto-object-suffix-replace= --plugin-opt=thinlto-object-suffix-replace= -thinlto-prefix-replace= --plugin-opt=thinlto-prefix-replace= -lto-obj-path= --plugin-opt=obj-path= The options with the --plugin-opt= prefix have been retained as aliases for the shorter variants so that they continue to be accepted. Reviewers: tejohnson, ruiu, espindola Reviewed By: ruiu Subscribers: emaste, arichardson, MaskRay, steven_wu, dexonsmith, arphaman, llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D67782 llvm-svn: 372798
This commit is contained in:
parent
4cd71260c2
commit
9f0f36e022
|
@ -757,6 +757,12 @@ static bool getCompressDebugSections(opt::InputArgList &args) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static StringRef getAliasSpelling(opt::Arg *arg) {
|
||||||
|
if (const opt::Arg *alias = arg->getAlias())
|
||||||
|
return alias->getSpelling();
|
||||||
|
return arg->getSpelling();
|
||||||
|
}
|
||||||
|
|
||||||
static std::pair<StringRef, StringRef> getOldNewOptions(opt::InputArgList &args,
|
static std::pair<StringRef, StringRef> getOldNewOptions(opt::InputArgList &args,
|
||||||
unsigned id) {
|
unsigned id) {
|
||||||
auto *arg = args.getLastArg(id);
|
auto *arg = args.getLastArg(id);
|
||||||
|
@ -766,7 +772,7 @@ static std::pair<StringRef, StringRef> getOldNewOptions(opt::InputArgList &args,
|
||||||
StringRef s = arg->getValue();
|
StringRef s = arg->getValue();
|
||||||
std::pair<StringRef, StringRef> ret = s.split(';');
|
std::pair<StringRef, StringRef> ret = s.split(';');
|
||||||
if (ret.second.empty())
|
if (ret.second.empty())
|
||||||
error(arg->getSpelling() + " expects 'old;new' format, but got " + s);
|
error(getAliasSpelling(arg) + " expects 'old;new' format, but got " + s);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -858,7 +864,7 @@ static void readConfigs(opt::InputArgList &args) {
|
||||||
config->ltoNewPassManager = args.hasArg(OPT_lto_new_pass_manager);
|
config->ltoNewPassManager = args.hasArg(OPT_lto_new_pass_manager);
|
||||||
config->ltoNewPmPasses = args.getLastArgValue(OPT_lto_newpm_passes);
|
config->ltoNewPmPasses = args.getLastArgValue(OPT_lto_newpm_passes);
|
||||||
config->ltoo = args::getInteger(args, OPT_lto_O, 2);
|
config->ltoo = args::getInteger(args, OPT_lto_O, 2);
|
||||||
config->ltoObjPath = args.getLastArgValue(OPT_plugin_opt_obj_path_eq);
|
config->ltoObjPath = args.getLastArgValue(OPT_lto_obj_path_eq);
|
||||||
config->ltoPartitions = args::getInteger(args, OPT_lto_partitions, 1);
|
config->ltoPartitions = args::getInteger(args, OPT_lto_partitions, 1);
|
||||||
config->ltoSampleProfile = args.getLastArgValue(OPT_lto_sample_profile);
|
config->ltoSampleProfile = args.getLastArgValue(OPT_lto_sample_profile);
|
||||||
config->mapFile = args.getLastArgValue(OPT_Map);
|
config->mapFile = args.getLastArgValue(OPT_Map);
|
||||||
|
@ -903,17 +909,15 @@ static void readConfigs(opt::InputArgList &args) {
|
||||||
config->thinLTOCachePolicy = CHECK(
|
config->thinLTOCachePolicy = CHECK(
|
||||||
parseCachePruningPolicy(args.getLastArgValue(OPT_thinlto_cache_policy)),
|
parseCachePruningPolicy(args.getLastArgValue(OPT_thinlto_cache_policy)),
|
||||||
"--thinlto-cache-policy: invalid cache policy");
|
"--thinlto-cache-policy: invalid cache policy");
|
||||||
config->thinLTOEmitImportsFiles =
|
config->thinLTOEmitImportsFiles = args.hasArg(OPT_thinlto_emit_imports_files);
|
||||||
args.hasArg(OPT_plugin_opt_thinlto_emit_imports_files);
|
config->thinLTOIndexOnly = args.hasArg(OPT_thinlto_index_only) ||
|
||||||
config->thinLTOIndexOnly = args.hasArg(OPT_plugin_opt_thinlto_index_only) ||
|
args.hasArg(OPT_thinlto_index_only_eq);
|
||||||
args.hasArg(OPT_plugin_opt_thinlto_index_only_eq);
|
config->thinLTOIndexOnlyArg = args.getLastArgValue(OPT_thinlto_index_only_eq);
|
||||||
config->thinLTOIndexOnlyArg =
|
|
||||||
args.getLastArgValue(OPT_plugin_opt_thinlto_index_only_eq);
|
|
||||||
config->thinLTOJobs = args::getInteger(args, OPT_thinlto_jobs, -1u);
|
config->thinLTOJobs = args::getInteger(args, OPT_thinlto_jobs, -1u);
|
||||||
config->thinLTOObjectSuffixReplace =
|
config->thinLTOObjectSuffixReplace =
|
||||||
getOldNewOptions(args, OPT_plugin_opt_thinlto_object_suffix_replace_eq);
|
getOldNewOptions(args, OPT_thinlto_object_suffix_replace_eq);
|
||||||
config->thinLTOPrefixReplace =
|
config->thinLTOPrefixReplace =
|
||||||
getOldNewOptions(args, OPT_plugin_opt_thinlto_prefix_replace_eq);
|
getOldNewOptions(args, OPT_thinlto_prefix_replace_eq);
|
||||||
config->trace = args.hasArg(OPT_trace);
|
config->trace = args.hasArg(OPT_trace);
|
||||||
config->undefined = args::getStrings(args, OPT_undefined);
|
config->undefined = args::getStrings(args, OPT_undefined);
|
||||||
config->undefinedVersion =
|
config->undefinedVersion =
|
||||||
|
|
|
@ -481,6 +481,7 @@ def lto_cs_profile_generate: F<"lto-cs-profile-generate">,
|
||||||
HelpText<"Perform context senstive PGO instrumentation">;
|
HelpText<"Perform context senstive PGO instrumentation">;
|
||||||
def lto_cs_profile_file: J<"lto-cs-profile-file=">,
|
def lto_cs_profile_file: J<"lto-cs-profile-file=">,
|
||||||
HelpText<"Context sensitive profile file path">;
|
HelpText<"Context sensitive profile file path">;
|
||||||
|
def lto_obj_path_eq: J<"lto-obj-path=">;
|
||||||
def lto_sample_profile: J<"lto-sample-profile=">,
|
def lto_sample_profile: J<"lto-sample-profile=">,
|
||||||
HelpText<"Sample profile file path">;
|
HelpText<"Sample profile file path">;
|
||||||
def disable_verify: F<"disable-verify">;
|
def disable_verify: F<"disable-verify">;
|
||||||
|
@ -498,7 +499,12 @@ def save_temps: F<"save-temps">;
|
||||||
def thinlto_cache_dir: J<"thinlto-cache-dir=">,
|
def thinlto_cache_dir: J<"thinlto-cache-dir=">,
|
||||||
HelpText<"Path to ThinLTO cached object file directory">;
|
HelpText<"Path to ThinLTO cached object file directory">;
|
||||||
defm thinlto_cache_policy: Eq<"thinlto-cache-policy", "Pruning policy for the ThinLTO cache">;
|
defm thinlto_cache_policy: Eq<"thinlto-cache-policy", "Pruning policy for the ThinLTO cache">;
|
||||||
|
def thinlto_emit_imports_files: F<"thinlto-emit-imports-files">;
|
||||||
|
def thinlto_index_only: F<"thinlto-index-only">;
|
||||||
|
def thinlto_index_only_eq: J<"thinlto-index-only=">;
|
||||||
def thinlto_jobs: J<"thinlto-jobs=">, HelpText<"Number of ThinLTO jobs">;
|
def thinlto_jobs: J<"thinlto-jobs=">, HelpText<"Number of ThinLTO jobs">;
|
||||||
|
def thinlto_object_suffix_replace_eq: J<"thinlto-object-suffix-replace=">;
|
||||||
|
def thinlto_prefix_replace_eq: J<"thinlto-prefix-replace=">;
|
||||||
|
|
||||||
def: J<"plugin-opt=O">, Alias<lto_O>, HelpText<"Alias for -lto-O">;
|
def: J<"plugin-opt=O">, Alias<lto_O>, HelpText<"Alias for -lto-O">;
|
||||||
def: F<"plugin-opt=debug-pass-manager">,
|
def: F<"plugin-opt=debug-pass-manager">,
|
||||||
|
@ -512,19 +518,31 @@ def: J<"plugin-opt=lto-partitions=">, Alias<lto_partitions>, HelpText<"Alias for
|
||||||
def plugin_opt_mcpu_eq: J<"plugin-opt=mcpu=">;
|
def plugin_opt_mcpu_eq: J<"plugin-opt=mcpu=">;
|
||||||
def: F<"plugin-opt=new-pass-manager">,
|
def: F<"plugin-opt=new-pass-manager">,
|
||||||
Alias<lto_new_pass_manager>, HelpText<"Alias for -lto-new-pass-manager">;
|
Alias<lto_new_pass_manager>, HelpText<"Alias for -lto-new-pass-manager">;
|
||||||
def plugin_opt_obj_path_eq: J<"plugin-opt=obj-path=">;
|
|
||||||
def: F<"plugin-opt=cs-profile-generate">,
|
def: F<"plugin-opt=cs-profile-generate">,
|
||||||
Alias<lto_cs_profile_generate>, HelpText<"Alias for -lto-cs-profile-generate">;
|
Alias<lto_cs_profile_generate>, HelpText<"Alias for -lto-cs-profile-generate">;
|
||||||
def: J<"plugin-opt=cs-profile-path=">,
|
def: J<"plugin-opt=cs-profile-path=">,
|
||||||
Alias<lto_cs_profile_file>, HelpText<"Alias for -lto-cs-profile-file">;
|
Alias<lto_cs_profile_file>, HelpText<"Alias for -lto-cs-profile-file">;
|
||||||
|
def: J<"plugin-opt=obj-path=">,
|
||||||
|
Alias<lto_obj_path_eq>,
|
||||||
|
HelpText<"Alias for -lto-obj-path=">;
|
||||||
def: J<"plugin-opt=sample-profile=">,
|
def: J<"plugin-opt=sample-profile=">,
|
||||||
Alias<lto_sample_profile>, HelpText<"Alias for -lto-sample-profile">;
|
Alias<lto_sample_profile>, HelpText<"Alias for -lto-sample-profile">;
|
||||||
def: F<"plugin-opt=save-temps">, Alias<save_temps>, HelpText<"Alias for -save-temps">;
|
def: F<"plugin-opt=save-temps">, Alias<save_temps>, HelpText<"Alias for -save-temps">;
|
||||||
def plugin_opt_thinlto_emit_imports_files: F<"plugin-opt=thinlto-emit-imports-files">;
|
def: F<"plugin-opt=thinlto-emit-imports-files">,
|
||||||
def plugin_opt_thinlto_index_only: F<"plugin-opt=thinlto-index-only">;
|
Alias<thinlto_emit_imports_files>,
|
||||||
def plugin_opt_thinlto_index_only_eq: J<"plugin-opt=thinlto-index-only=">;
|
HelpText<"Alias for -thinlto-emit-imports-files">;
|
||||||
def plugin_opt_thinlto_object_suffix_replace_eq: J<"plugin-opt=thinlto-object-suffix-replace=">;
|
def: F<"plugin-opt=thinlto-index-only">,
|
||||||
def plugin_opt_thinlto_prefix_replace_eq: J<"plugin-opt=thinlto-prefix-replace=">;
|
Alias<thinlto_index_only>,
|
||||||
|
HelpText<"Alias for -thinlto-index-only">;
|
||||||
|
def: J<"plugin-opt=thinlto-index-only=">,
|
||||||
|
Alias<thinlto_index_only_eq>,
|
||||||
|
HelpText<"Alias for -thinlto-index-only=">;
|
||||||
|
def: J<"plugin-opt=thinlto-object-suffix-replace=">,
|
||||||
|
Alias<thinlto_object_suffix_replace_eq>,
|
||||||
|
HelpText<"Alias for -thinlto-object-suffix-replace=">;
|
||||||
|
def: J<"plugin-opt=thinlto-prefix-replace=">,
|
||||||
|
Alias<thinlto_prefix_replace_eq>,
|
||||||
|
HelpText<"Alias for -thinlto-prefix-replace=">;
|
||||||
|
|
||||||
// Ignore LTO plugin-related options.
|
// Ignore LTO plugin-related options.
|
||||||
// clang -flto passes -plugin and -plugin-opt to the linker. This is required
|
// clang -flto passes -plugin and -plugin-opt to the linker. This is required
|
||||||
|
|
|
@ -14,15 +14,15 @@
|
||||||
|
|
||||||
; The imports file for this module contains the bitcode file for
|
; The imports file for this module contains the bitcode file for
|
||||||
; Inputs/thinlto.ll
|
; Inputs/thinlto.ll
|
||||||
; RUN: cat %t1.o.imports | count 1
|
; RUN: count 1 < %t1.o.imports
|
||||||
; RUN: cat %t1.o.imports | FileCheck %s --check-prefix=IMPORTS1
|
; RUN: FileCheck %s --check-prefix=IMPORTS1 < %t1.o.imports
|
||||||
; IMPORTS1: thinlto-emit-imports.ll.tmp2.o
|
; IMPORTS1: thinlto-emit-imports.ll.tmp2.o
|
||||||
|
|
||||||
; The imports file for Input/thinlto.ll is empty as it does not import anything.
|
; The imports file for Input/thinlto.ll is empty as it does not import anything.
|
||||||
; RUN: cat %t2.o.imports | count 0
|
; RUN: count 0 < %t2.o.imports
|
||||||
|
|
||||||
; The imports file for Input/thinlto_empty.ll is empty but should exist.
|
; The imports file for Input/thinlto_empty.ll is empty but should exist.
|
||||||
; RUN: cat %t3.o.imports | count 0
|
; RUN: count 0 < %t3.o.imports
|
||||||
|
|
||||||
; The index file should be created even for the input with an empty summary.
|
; The index file should be created even for the input with an empty summary.
|
||||||
; RUN: ls %t3.o.thinlto.bc
|
; RUN: ls %t3.o.thinlto.bc
|
||||||
|
@ -43,6 +43,13 @@
|
||||||
; RUN: not ls %t2.o.imports
|
; RUN: not ls %t2.o.imports
|
||||||
; RUN: not ls %t3.o.imports
|
; RUN: not ls %t3.o.imports
|
||||||
|
|
||||||
|
; Check that imports files are generated also when -thinlto-index-only
|
||||||
|
; is specified without --plugin-opt=.
|
||||||
|
; RUN: rm -f %t1.o.imports
|
||||||
|
; RUN: ld.lld -thinlto-index-only -thinlto-emit-imports-files -shared %t1.o %t2.o %t3.o -o %t4
|
||||||
|
; RUN: count 1 < %t1.o.imports
|
||||||
|
; RUN: FileCheck %s --check-prefix=IMPORTS1 < %t1.o.imports
|
||||||
|
|
||||||
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
||||||
target triple = "x86_64-unknown-linux-gnu"
|
target triple = "x86_64-unknown-linux-gnu"
|
||||||
|
|
||||||
|
|
|
@ -6,12 +6,16 @@
|
||||||
; RUN: opt -module-summary %p/Inputs/thinlto_empty.ll -o %t3.o
|
; RUN: opt -module-summary %p/Inputs/thinlto_empty.ll -o %t3.o
|
||||||
|
|
||||||
; Ensure lld writes linked files to linked objects file
|
; Ensure lld writes linked files to linked objects file
|
||||||
; RUN: ld.lld --plugin-opt=thinlto-index-only=%t.idx -shared %t1.o %t2.o %t3.o -o %t4
|
; RUN: ld.lld --plugin-opt=thinlto-index-only=%t.idx -shared %t1.o %t2.o %t3.o -o /dev/null
|
||||||
; RUN: FileCheck %s < %t.idx
|
; RUN: FileCheck %s < %t.idx
|
||||||
; CHECK: {{.*}}thinlto-index-file.ll.tmp1.o
|
; CHECK: {{.*}}thinlto-index-file.ll.tmp1.o
|
||||||
; CHECK: {{.*}}thinlto-index-file.ll.tmp2.o
|
; CHECK: {{.*}}thinlto-index-file.ll.tmp2.o
|
||||||
; CHECK: {{.*}}thinlto-index-file.ll.tmp3.o
|
; CHECK: {{.*}}thinlto-index-file.ll.tmp3.o
|
||||||
|
|
||||||
|
; Check that this also works without the --plugin-opt= prefix.
|
||||||
|
; RUN: ld.lld -thinlto-index-only=%t.idx -shared %t1.o %t2.o %t3.o -o /dev/null
|
||||||
|
; RUN: FileCheck %s < %t.idx
|
||||||
|
|
||||||
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
||||||
target triple = "x86_64-unknown-linux-gnu"
|
target triple = "x86_64-unknown-linux-gnu"
|
||||||
|
|
||||||
|
|
|
@ -5,11 +5,16 @@
|
||||||
|
|
||||||
; Test to ensure that thinlto-index-only with obj-path creates the file.
|
; Test to ensure that thinlto-index-only with obj-path creates the file.
|
||||||
; RUN: rm -f %t4.o
|
; RUN: rm -f %t4.o
|
||||||
; RUN: ld.lld --plugin-opt=thinlto-index-only --plugin-opt=obj-path=%t4.o -shared %t1.o %t2.o -o %t3
|
; RUN: ld.lld --plugin-opt=thinlto-index-only --plugin-opt=obj-path=%t4.o -shared %t1.o %t2.o -o /dev/null
|
||||||
; RUN: llvm-readobj -h %t4.o | FileCheck %s
|
; RUN: llvm-readobj -h %t4.o | FileCheck %s
|
||||||
; RUN: llvm-nm %t4.o 2>&1 | FileCheck %s -check-prefix=NO-SYMBOLS
|
; RUN: llvm-nm %t4.o 2>&1 | FileCheck %s -check-prefix=NO-SYMBOLS
|
||||||
; NO-SYMBOLS: no symbols
|
; NO-SYMBOLS: no symbols
|
||||||
|
|
||||||
|
; Check that this also works without the --plugin-opt= prefix.
|
||||||
|
; RUN: rm -f %t4.o
|
||||||
|
; RUN: ld.lld -thinlto-index-only -lto-obj-path=%t4.o -shared %t1.o %t2.o -o /dev/null
|
||||||
|
; RUN: llvm-readobj -h %t4.o | FileCheck %s
|
||||||
|
|
||||||
; CHECK: Format: ELF64-x86-64
|
; CHECK: Format: ELF64-x86-64
|
||||||
|
|
||||||
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
|
||||||
|
|
|
@ -21,6 +21,11 @@
|
||||||
; RUN: --plugin-opt=thinlto-object-suffix-replace=".thinlink.bc;.o" \
|
; RUN: --plugin-opt=thinlto-object-suffix-replace=".thinlink.bc;.o" \
|
||||||
; RUN: -shared %t1.thinlink.bc -o %t3
|
; RUN: -shared %t1.thinlink.bc -o %t3
|
||||||
; RUN: diff %t1.o.thinlto.bc.orig %t1.o.thinlto.bc
|
; RUN: diff %t1.o.thinlto.bc.orig %t1.o.thinlto.bc
|
||||||
|
; Also check that this works without the --plugin-opt= prefix.
|
||||||
|
; RUN: ld.lld -thinlto-index-only \
|
||||||
|
; RUN: -thinlto-object-suffix-replace=".thinlink.bc;.o" \
|
||||||
|
; RUN: -shared %t1.thinlink.bc -o %t3
|
||||||
|
; RUN: diff %t1.o.thinlto.bc.orig %t1.o.thinlto.bc
|
||||||
|
|
||||||
; Ensure lld generates error if object suffix replace option does not have 'old;new' format
|
; Ensure lld generates error if object suffix replace option does not have 'old;new' format
|
||||||
; RUN: rm -f %t1.o.thinlto.bc
|
; RUN: rm -f %t1.o.thinlto.bc
|
||||||
|
|
|
@ -9,6 +9,11 @@
|
||||||
; RUN: ld.lld --plugin-opt=thinlto-index-only --plugin-opt=thinlto-prefix-replace="%t/oldpath/;%t/newpath/" -shared %t/oldpath/thinlto_prefix_replace.o -o %t/thinlto_prefix_replace
|
; RUN: ld.lld --plugin-opt=thinlto-index-only --plugin-opt=thinlto-prefix-replace="%t/oldpath/;%t/newpath/" -shared %t/oldpath/thinlto_prefix_replace.o -o %t/thinlto_prefix_replace
|
||||||
; RUN: ls %t/newpath/thinlto_prefix_replace.o.thinlto.bc
|
; RUN: ls %t/newpath/thinlto_prefix_replace.o.thinlto.bc
|
||||||
|
|
||||||
|
; Check that this also works without the --plugin-opt= prefix.
|
||||||
|
; RUN: rm -f %t/newpath/thinlto_prefix_replace.o.thinlto.bc
|
||||||
|
; RUN: ld.lld -thinlto-index-only -thinlto-prefix-replace="%t/oldpath/;%t/newpath/" -shared %t/oldpath/thinlto_prefix_replace.o -o %t/thinlto_prefix_replace
|
||||||
|
; RUN: ls %t/newpath/thinlto_prefix_replace.o.thinlto.bc
|
||||||
|
|
||||||
; Ensure that lld generates error if prefix replace option does not have 'old;new' format
|
; Ensure that lld generates error if prefix replace option does not have 'old;new' format
|
||||||
; RUN: rm -f %t/newpath/thinlto_prefix_replace.o.thinlto.bc
|
; RUN: rm -f %t/newpath/thinlto_prefix_replace.o.thinlto.bc
|
||||||
; RUN: not ld.lld --plugin-opt=thinlto-index-only --plugin-opt=thinlto-prefix-replace=abc:def -shared %t/oldpath/thinlto_prefix_replace.o -o %t/thinlto_prefix_replace 2>&1 | FileCheck %s --check-prefix=ERR
|
; RUN: not ld.lld --plugin-opt=thinlto-index-only --plugin-opt=thinlto-prefix-replace=abc:def -shared %t/oldpath/thinlto_prefix_replace.o -o %t/thinlto_prefix_replace 2>&1 | FileCheck %s --check-prefix=ERR
|
||||||
|
|
Loading…
Reference in New Issue