From 9780e4a2bbfbc40c9abbaf094ecda4f3af4ebee6 Mon Sep 17 00:00:00 2001 From: Simon Atanasyan Date: Thu, 5 Jul 2012 20:16:22 +0000 Subject: MIPS: Define __mips_dsp_rev / __mips_dspr2 / __mips_dsp macros if -mdsp or -mdspr2 options are provided. llvm-svn: 159774 --- clang/lib/Basic/Targets.cpp | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'clang/lib/Basic/Targets.cpp') diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp index 42f5d63cc36..94d664d3b69 100644 --- a/clang/lib/Basic/Targets.cpp +++ b/clang/lib/Basic/Targets.cpp @@ -3603,6 +3603,9 @@ class MipsTargetInfoBase : public TargetInfo { enum MipsFloatABI { HardFloat, SingleFloat, SoftFloat } FloatABI; + enum DspRevEnum { + NoDSP, DSP1, DSP2 + } DspRev; protected: std::string ABI; @@ -3615,6 +3618,7 @@ public: CPU(CPUStr), IsMips16(false), FloatABI(HardFloat), + DspRev(NoDSP), ABI(ABIStr) {} @@ -3648,6 +3652,20 @@ public: if (IsMips16) Builder.defineMacro("__mips16", Twine(1)); + switch (DspRev) { + default: + break; + case DSP1: + Builder.defineMacro("__mips_dsp_rev", Twine(1)); + Builder.defineMacro("__mips_dsp", Twine(1)); + break; + case DSP2: + Builder.defineMacro("__mips_dsp_rev", Twine(2)); + Builder.defineMacro("__mips_dspr2", Twine(1)); + Builder.defineMacro("__mips_dsp", Twine(1)); + break; + } + Builder.defineMacro("_MIPS_SZPTR", Twine(getPointerWidth(0))); Builder.defineMacro("_MIPS_SZINT", Twine(getIntWidth())); Builder.defineMacro("_MIPS_SZLONG", Twine(getLongWidth())); @@ -3729,6 +3747,7 @@ public: virtual void HandleTargetFeatures(std::vector &Features) { IsMips16 = false; FloatABI = HardFloat; + DspRev = NoDSP; for (std::vector::iterator it = Features.begin(), ie = Features.end(); it != ie; ++it) { @@ -3738,6 +3757,10 @@ public: FloatABI = SoftFloat; else if (*it == "+mips16") IsMips16 = true; + else if (*it == "+dsp") + DspRev = std::max(DspRev, DSP1); + else if (*it == "+dspr2") + DspRev = std::max(DspRev, DSP2); } // Remove front-end specific option. -- cgit v1.2.3