summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2014-01-10 15:25:23 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2014-01-10 15:25:23 +0000
commit0e38aade94b4769cb2f674838fd0a3305b670f49 (patch)
tree8587a67f22a38d1242225b39cad105c68014b0c4
parent9f1d619c0758aa3f88c5dcf27152c1cbf494ba16 (diff)
downloadbcm5719-llvm-0e38aade94b4769cb2f674838fd0a3305b670f49.tar.gz
bcm5719-llvm-0e38aade94b4769cb2f674838fd0a3305b670f49.zip
Implement -m32 and -m64 with llvm::Triple functions.
Don't repeat the 32 <-> 64 architecture mapping incompletely. llvm-svn: 198943
-rw-r--r--clang/lib/Driver/Driver.cpp19
-rw-r--r--clang/test/Driver/unknown-gcc-arch.c8
2 files changed, 15 insertions, 12 deletions
diff --git a/clang/lib/Driver/Driver.cpp b/clang/lib/Driver/Driver.cpp
index d8284040eb3..253a083109c 100644
--- a/clang/lib/Driver/Driver.cpp
+++ b/clang/lib/Driver/Driver.cpp
@@ -1911,19 +1911,14 @@ static llvm::Triple computeTargetTriple(StringRef DefaultTargetTriple,
return Target;
// Handle pseudo-target flags '-m32' and '-m64'.
- // FIXME: Should this information be in llvm::Triple?
if (Arg *A = Args.getLastArg(options::OPT_m32, options::OPT_m64)) {
- if (A->getOption().matches(options::OPT_m32)) {
- if (Target.getArch() == llvm::Triple::x86_64)
- Target.setArch(llvm::Triple::x86);
- if (Target.getArch() == llvm::Triple::ppc64)
- Target.setArch(llvm::Triple::ppc);
- } else {
- if (Target.getArch() == llvm::Triple::x86)
- Target.setArch(llvm::Triple::x86_64);
- if (Target.getArch() == llvm::Triple::ppc)
- Target.setArch(llvm::Triple::ppc64);
- }
+ llvm::Triple::ArchType AT;
+ if (A->getOption().matches(options::OPT_m32))
+ AT = Target.get32BitArchVariant().getArch();
+ else
+ AT = Target.get64BitArchVariant().getArch();
+ if (AT != llvm::Triple::UnknownArch)
+ Target.setArch(AT);
}
return Target;
diff --git a/clang/test/Driver/unknown-gcc-arch.c b/clang/test/Driver/unknown-gcc-arch.c
index 184443b08cb..dd2c96ac8b8 100644
--- a/clang/test/Driver/unknown-gcc-arch.c
+++ b/clang/test/Driver/unknown-gcc-arch.c
@@ -30,3 +30,11 @@
// RUN: %clang -target powerpc-unknown-unknown -c -x assembler %s -### -m64 2>&1 \
// RUN: | FileCheck -check-prefix=PPC-M64 %s
// PPC-M64: {{.*as.*-a64}}
+
+// RUN: %clang -target sparc64-unknown-unknown -no-integrated-as -c -x assembler %s -### -m32 2>&1 \
+// RUN: | FileCheck -check-prefix=SPARCV8 %s
+// SPARCV8: {{.*as.*-32}}
+
+// RUN: %clang -target sparc-unknown-unknown -no-integrated-as -c -x assembler %s -### -m64 2>&1 \
+// RUN: | FileCheck -check-prefix=SPARCV9 %s
+// SPARCV9: {{.*as.*-64}}
OpenPOWER on IntegriCloud