diff --git a/lld/MachO/Config.h b/lld/MachO/Config.h --- a/lld/MachO/Config.h +++ b/lld/MachO/Config.h @@ -169,6 +169,7 @@ bool deadStrip = false; bool errorForArchMismatch = false; bool ignoreAutolinking = false; + llvm::StringSet<> ignoredAutoLinkOptions; PlatformInfo platformInfo; llvm::Optional secondaryPlatformInfo; NamespaceKind namespaceKind = NamespaceKind::twolevel; diff --git a/lld/MachO/Driver.cpp b/lld/MachO/Driver.cpp --- a/lld/MachO/Driver.cpp +++ b/lld/MachO/Driver.cpp @@ -478,11 +478,15 @@ unsigned i = 0; StringRef arg = argv[i]; if (arg.consume_front("-l")) { + if (config->ignoredAutoLinkOptions.contains(arg)) + return; addLibrary(arg, /*isNeeded=*/false, /*isWeak=*/false, /*isReexport=*/false, /*isHidden=*/false, /*isExplicit=*/false, LoadType::LCLinkerOption); } else if (arg == "-framework") { StringRef name = argv[++i]; + if (config->ignoredAutoLinkOptions.contains(name)) + return; addFramework(name, /*isNeeded=*/false, /*isWeak=*/false, /*isReexport=*/false, /*isExplicit=*/false, LoadType::LCLinkerOption); @@ -1543,6 +1547,8 @@ getenv("LD_DYLIB_CPU_SUBTYPES_MUST_MATCH"); config->objcStubsMode = getObjCStubsMode(args); config->ignoreAutolinking = args.hasArg(OPT_ignore_auto_link); + for (const Arg *arg : args.filtered(OPT_ignore_auto_link_option)) + config->ignoredAutoLinkOptions.insert(arg->getValue()); for (const Arg *arg : args.filtered(OPT_alias)) { config->aliasedSymbols.push_back( diff --git a/lld/MachO/Options.td b/lld/MachO/Options.td --- a/lld/MachO/Options.td +++ b/lld/MachO/Options.td @@ -994,6 +994,12 @@ def ignore_auto_link : Flag<["-"], "ignore_auto_link">, HelpText<"Ignore LC_LINKER_OPTIONs">, Group; +def ignore_auto_link_option : Separate<["--"], "ignore-auto-link-option">, + Group; +def ignore_auto_link_option_eq : Joined<["--"], "ignore-auto-link-option=">, + Alias(ignore_auto_link_option)>, + HelpText<"Ignore a single auto-linked library or framework. Useful to ignore invalid requirements that ld64 ignores">, + Group; def grp_deprecated : OptionGroup<"deprecated">, HelpText<"DEPRECATED">; diff --git a/lld/test/MachO/lc-linker-option.ll b/lld/test/MachO/lc-linker-option.ll --- a/lld/test/MachO/lc-linker-option.ll +++ b/lld/test/MachO/lc-linker-option.ll @@ -13,6 +13,8 @@ ; FRAME-NEXT: name /System/Library/Frameworks/CoreFoundation.framework/CoreFoundation ; RUN: not %lld %t/framework.o -o %t/frame_no_autolink -ignore_auto_link 2>&1 | FileCheck --check-prefix=NO_AUTOLINK %s +; RUN: not %lld %t/framework.o -o %t/frame_no_autolink --ignore-auto-link-option CoreFoundation 2>&1 | FileCheck --check-prefix=NO_AUTOLINK %s +; RUN: not %lld %t/framework.o -o %t/frame_no_autolink --ignore-auto-link-option=CoreFoundation 2>&1 | FileCheck --check-prefix=NO_AUTOLINK %s ; NO_AUTOLINK: error: undefined symbol: __CFBigNumGetInt128 ; RUN: llvm-as %t/l.ll -o %t/l.o