diff options
-rw-r--r-- | lib/Driver/Tools.cpp | 11 | ||||
-rw-r--r-- | test/Driver/unknown-gcc-arch.c | 8 |
2 files changed, 18 insertions, 1 deletions
diff --git a/lib/Driver/Tools.cpp b/lib/Driver/Tools.cpp index d79f850f07..a714be81c3 100644 --- a/lib/Driver/Tools.cpp +++ b/lib/Driver/Tools.cpp @@ -617,7 +617,8 @@ void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA, if (A->getOption().hasForwardToGCC()) { // It is unfortunate that we have to claim here, as this means // we will basically never report anything interesting for - // platforms using a generic gcc. + // platforms using a generic gcc, even if we are just using gcc + // to get to the assembler. A->claim(); A->render(Args, CmdArgs); } @@ -638,6 +639,14 @@ void gcc::Common::ConstructJob(Compilation &C, const JobAction &JA, CmdArgs.push_back(Str); } + // Try to force gcc to match the tool chain we want, if we recognize + // the arch. + const char *Str = getToolChain().getArchName().c_str(); + if (strcmp(Str, "i386") == 0 || strcmp(Str, "powerpc") == 0) + CmdArgs.push_back("-m32"); + else if (strcmp(Str, "x86_64") == 0 || strcmp(Str, "powerpc64") == 0) + CmdArgs.push_back("-m64"); + if (Output.isPipe()) { CmdArgs.push_back("-o"); CmdArgs.push_back("-"); diff --git a/test/Driver/unknown-gcc-arch.c b/test/Driver/unknown-gcc-arch.c new file mode 100644 index 0000000000..de9e8e84c4 --- /dev/null +++ b/test/Driver/unknown-gcc-arch.c @@ -0,0 +1,8 @@ +// RUN: clang -ccc-host-triple x86_64-unknown-unknown -c -x assembler %s -### 2> %t.log && +// RUN: grep '.*gcc.*"-m64"' %t.log && +// RUN: clang -ccc-host-triple x86_64-unknown-unknown -c -x assembler %s -### -m32 2> %t.log && +// RUN: grep '.*gcc.*"-m32"' %t.log && +// RUN: clang -ccc-host-triple i386-unknown-unknown -c -x assembler %s -### 2> %t.log && +// RUN: grep '.*gcc.*"-m32"' %t.log && +// RUN: clang -ccc-host-triple i386-unknown-unknown -c -x assembler %s -### -m64 2> %t.log && +// RUN: grep '.*gcc.*"-m64"' %t.log |