This revision was landed with ongoing or failed builds. This revision was automatically updated to reflect the committed changes. Closed by commit rGfe5bab537270: [Driver][ARM] Warn about -mabi= for assembler input (authored by MaskRay).
Changed prior to commit: https://reviews.llvm.org/D153691?vs=534668&id=534705#toc Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153691/new/ https://reviews.llvm.org/D153691 Files: clang/lib/Driver/ToolChains/Arch/ARM.cpp clang/test/Driver/arm-abi.c Index: clang/test/Driver/arm-abi.c =================================================================== --- clang/test/Driver/arm-abi.c +++ clang/test/Driver/arm-abi.c @@ -61,3 +61,9 @@ // CHECK-APCS-GNU: "-target-abi" "apcs-gnu" // CHECK-AAPCS: "-target-abi" "aapcs" // CHECK-AAPCS-LINUX: "-target-abi" "aapcs-linux" + +// RUN: %clang --target=arm---gnueabi -mabi=aapcs -x assembler %s -### -o /dev/null 2>&1 \ +// RUN: | FileCheck --check-prefix=CHECK-ASM %s + +/// The combination -x assember & -mabi is not implemented, but for GCC compatibility we accept with a warning. +// CHECK-ASM: warning: argument unused during compilation: '-mabi={{.*}}' Index: clang/lib/Driver/ToolChains/Arch/ARM.cpp =================================================================== --- clang/lib/Driver/ToolChains/Arch/ARM.cpp +++ clang/lib/Driver/ToolChains/Arch/ARM.cpp @@ -524,6 +524,12 @@ } } } + + // The integrated assembler doesn't implement e_flags setting behavior for + // -meabi=gnu (gcc -mabi={apcs-gnu,atpcs} passes -meabi=gnu to gas). For + // compatibility we accept but warn. + if (Arg *A = Args.getLastArgNoClaim(options::OPT_mabi_EQ)) + A->ignoreTargetSpecific(); } if (getReadTPMode(D, Args, Triple, ForAS) == ReadTPMode::TPIDRURW)
Index: clang/test/Driver/arm-abi.c =================================================================== --- clang/test/Driver/arm-abi.c +++ clang/test/Driver/arm-abi.c @@ -61,3 +61,9 @@ // CHECK-APCS-GNU: "-target-abi" "apcs-gnu" // CHECK-AAPCS: "-target-abi" "aapcs" // CHECK-AAPCS-LINUX: "-target-abi" "aapcs-linux" + +// RUN: %clang --target=arm---gnueabi -mabi=aapcs -x assembler %s -### -o /dev/null 2>&1 \ +// RUN: | FileCheck --check-prefix=CHECK-ASM %s + +/// The combination -x assember & -mabi is not implemented, but for GCC compatibility we accept with a warning. +// CHECK-ASM: warning: argument unused during compilation: '-mabi={{.*}}' Index: clang/lib/Driver/ToolChains/Arch/ARM.cpp =================================================================== --- clang/lib/Driver/ToolChains/Arch/ARM.cpp +++ clang/lib/Driver/ToolChains/Arch/ARM.cpp @@ -524,6 +524,12 @@ } } } + + // The integrated assembler doesn't implement e_flags setting behavior for + // -meabi=gnu (gcc -mabi={apcs-gnu,atpcs} passes -meabi=gnu to gas). For + // compatibility we accept but warn. + if (Arg *A = Args.getLastArgNoClaim(options::OPT_mabi_EQ)) + A->ignoreTargetSpecific(); } if (getReadTPMode(D, Args, Triple, ForAS) == ReadTPMode::TPIDRURW)
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits