aboutsummaryrefslogtreecommitdiff
path: root/lib/Driver/Tools.cpp
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-05-02 21:41:52 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-05-02 21:41:52 +0000
commit6ecc7a993f939c5255c36c7c0d965fb9c1543f2a (patch)
treeb561821434c18c700913938cc77f3e8c1d1cb47d /lib/Driver/Tools.cpp
parenta8304f67291b0182fb64f3afc621615288dd1d31 (diff)
Driver: When using the generic gcc tool, pass -m32 or -m64 if we
recognize the architecture. - This is an attempt to force gcc to the write target. - PR4094. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@70647 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Driver/Tools.cpp')
-rw-r--r--lib/Driver/Tools.cpp11
1 files changed, 10 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("-");