From 42e4b5997a2cad5f505dfb997b83f14f91ef0546 Mon Sep 17 00:00:00 2001 From: Saleem Abdulrasool Date: Sat, 22 Feb 2014 23:37:58 +0000 Subject: [PATCH] clang: forward -no-integrated-as from the driver Forward the -no-integrated-as option to -cc1 rather than simply invoking the appropriate tool. This is useful since this option has been overloaded to permit disabling of parsing inline assembly at the MC layer. This re-applies the previous version of the patch with a renaming of the driver option to the public name rather than the internal name (-target vs -triple). The actual failure is fixed separately of an overly aggressive negative pattern match in the MIPS driver tests. It also fixes the incorrect test for targets that have the integrated assembler disabled by default. llvm-svn: 201960 --- clang/lib/Driver/Tools.cpp | 9 +++++++-- clang/test/Driver/no-integrated-as.c | 19 +++++++++++++++++++ 2 files changed, 26 insertions(+), 2 deletions(-) create mode 100644 clang/test/Driver/no-integrated-as.c diff --git a/clang/lib/Driver/Tools.cpp b/clang/lib/Driver/Tools.cpp index b6214a7177cc..31192a2b0281 100644 --- a/clang/lib/Driver/Tools.cpp +++ b/clang/lib/Driver/Tools.cpp @@ -2514,12 +2514,17 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA, // Decide whether to use verbose asm. Verbose assembly is the default on // toolchains which have the integrated assembler on by default. - bool IsVerboseAsmDefault = getToolChain().IsIntegratedAssemblerDefault(); + bool IsIntegratedAssemblerDefault = + getToolChain().IsIntegratedAssemblerDefault(); if (Args.hasFlag(options::OPT_fverbose_asm, options::OPT_fno_verbose_asm, - IsVerboseAsmDefault) || + IsIntegratedAssemblerDefault) || Args.hasArg(options::OPT_dA)) CmdArgs.push_back("-masm-verbose"); + if (!Args.hasFlag(options::OPT_integrated_as, options::OPT_no_integrated_as, + IsIntegratedAssemblerDefault)) + CmdArgs.push_back("-no-integrated-as"); + if (Args.hasArg(options::OPT_fdebug_pass_structure)) { CmdArgs.push_back("-mdebug-pass"); CmdArgs.push_back("Structure"); diff --git a/clang/test/Driver/no-integrated-as.c b/clang/test/Driver/no-integrated-as.c new file mode 100644 index 000000000000..812ab1e6463f --- /dev/null +++ b/clang/test/Driver/no-integrated-as.c @@ -0,0 +1,19 @@ +// RUN: %clang -target i386 -### -no-integrated-as -c %s 2>&1 \ +// RUN: | FileCheck %s -check-prefix NOIAS + +// NOIAS: -no-integrated-as + +// RUN: %clang -target i386 -### -integrated-as -c %s 2>&1 \ +// RUN: | FileCheck %s -check-prefix IAS + +// IAS-NOT: -no-integrated-as + +// RUN: %clang -target i386 -### -c %s 2>&1 | FileCheck %s -check-prefix DEFAULT + +// DEFAULT-NOT: -no-integrated-as + +// RUN: %clang -target msp430 -### -c %s 2>&1 \ +// RUN: | FileCheck %s -check-prefix NO-IAS-DEFAULT + +// NO-IAS-DEFAULT: -no-integrated-as +