diff options
author | Simon Atanasyan <satanasyan@mips.com> | 2012-06-05 13:06:56 +0000 |
---|---|---|
committer | Simon Atanasyan <satanasyan@mips.com> | 2012-06-05 13:06:56 +0000 |
commit | d3d173ddca6c3bc1cdd74b5ab2e6b932de212aa4 (patch) | |
tree | c80ef4fbe90d584ef14fbd1e9886db99ebf4734d /clang/lib/Basic/Targets.cpp | |
parent | cc88531760980e1ead7d969bc55ed0c4a9b0d7be (diff) | |
download | bcm5719-llvm-d3d173ddca6c3bc1cdd74b5ab2e6b932de212aa4.tar.gz bcm5719-llvm-d3d173ddca6c3bc1cdd74b5ab2e6b932de212aa4.zip |
Mips: Define __mips_hard_float macro additional to __mips_single_float
when single float ABI is selected.
llvm-svn: 157996
Diffstat (limited to 'clang/lib/Basic/Targets.cpp')
-rw-r--r-- | clang/lib/Basic/Targets.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp index c4a80dd14a6..66433c9f987 100644 --- a/clang/lib/Basic/Targets.cpp +++ b/clang/lib/Basic/Targets.cpp @@ -3530,14 +3530,15 @@ public: virtual void getArchDefines(const LangOptions &Opts, MacroBuilder &Builder) const { - if (SoftFloat) + if (SoftFloat && SingleFloat) + llvm_unreachable("Invalid float ABI for Mips."); + else if (SoftFloat) Builder.defineMacro("__mips_soft_float", Twine(1)); - else if (SingleFloat) - Builder.defineMacro("__mips_single_float", Twine(1)); - else if (!SoftFloat && !SingleFloat) + else { Builder.defineMacro("__mips_hard_float", Twine(1)); - else - llvm_unreachable("Invalid float ABI for Mips."); + if (SingleFloat) + Builder.defineMacro("__mips_single_float", Twine(1)); + } Builder.defineMacro("_MIPS_SZPTR", Twine(getPointerWidth(0))); Builder.defineMacro("_MIPS_SZINT", Twine(getIntWidth())); |