| /* |
| * Copyright 2012, The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #ifndef BCC_SUPPORT_TARGET_COMPILER_CONFIGS_H |
| #define BCC_SUPPORT_TARGET_COMPILER_CONFIGS_H |
| |
| #include "bcc/Config/Config.h" |
| #include "bcc/Support/CompilerConfig.h" |
| |
| namespace bcc { |
| |
| //===----------------------------------------------------------------------===// |
| // ARM |
| //===----------------------------------------------------------------------===// |
| #if defined(PROVIDE_ARM_CODEGEN) |
| class ARMBaseCompilerConfig : public CompilerConfig { |
| private: |
| bool mEnableNEON; |
| bool mInThumbMode; |
| |
| static bool HasThumb2(); |
| |
| static void GetFeatureVector(std::vector<std::string> &pAttributes, |
| bool pInThumbMode, bool pEnableNEON); |
| |
| protected: |
| ARMBaseCompilerConfig(const std::string &pTriple, bool pInThumbMode); |
| |
| public: |
| // Return true if config has been changed after returning from this function. |
| bool enableNEON(bool pEnable = true); |
| |
| bool isInThumbMode() const |
| { return mInThumbMode; } |
| }; |
| |
| class ARMCompilerConfig : public ARMBaseCompilerConfig { |
| public: |
| ARMCompilerConfig() |
| : ARMBaseCompilerConfig(DEFAULT_ARM_TRIPLE_STRING, |
| /* pInThumbMode */false) { } |
| }; |
| |
| class ThumbCompilerConfig : public ARMBaseCompilerConfig { |
| public: |
| ThumbCompilerConfig() |
| : ARMBaseCompilerConfig(DEFAULT_THUMB_TRIPLE_STRING, |
| /* pInThumbMode */true) { } |
| }; |
| #endif // defined(PROVIDE_ARM_CODEGEN) |
| |
| //===----------------------------------------------------------------------===// |
| // MIPS |
| //===----------------------------------------------------------------------===// |
| #if defined(PROVIDE_MIPS_CODEGEN) |
| class MipsCompilerConfig : public CompilerConfig { |
| public: |
| MipsCompilerConfig() : CompilerConfig(DEFAULT_MIPS_TRIPLE_STRING) {} |
| }; |
| #endif // defined(PROVIDE_MIPS_CODEGEN) |
| |
| //===----------------------------------------------------------------------===// |
| // X86 and X86_64 |
| //===----------------------------------------------------------------------===// |
| #if defined(PROVIDE_X86_CODEGEN) |
| class X86FamilyCompilerConfigBase : public CompilerConfig { |
| protected: |
| X86FamilyCompilerConfigBase(const std::string &pTriple) |
| : CompilerConfig(pTriple) { |
| // Disable frame pointer elimination optimization on x86 family. |
| getTargetOptions().NoFramePointerElim = true; |
| getTargetOptions().UseInitArray = true; |
| return; |
| } |
| }; |
| |
| class X86_32CompilerConfig : public X86FamilyCompilerConfigBase { |
| public: |
| X86_32CompilerConfig() : |
| X86FamilyCompilerConfigBase(DEFAULT_X86_TRIPLE_STRING) { } |
| }; |
| |
| class X86_64CompilerConfig : public X86FamilyCompilerConfigBase { |
| public: |
| X86_64CompilerConfig() : |
| X86FamilyCompilerConfigBase(DEFAULT_X86_64_TRIPLE_STRING) { |
| setCodeModel(llvm::CodeModel::Medium); |
| } |
| }; |
| #endif // defined(PROVIDE_X86_CODEGEN) |
| |
| //===----------------------------------------------------------------------===// |
| // Default target |
| //===----------------------------------------------------------------------===// |
| class DefaultCompilerConfig : public |
| #if defined(DEFAULT_ARM_CODEGEN) |
| ARMCompilerConfig |
| #elif defined(DEFAULT_MIPS_CODEGEN) |
| MipsCompilerConfig |
| #elif defined(DEFAULT_X86_CODEGEN) |
| X86_32CompilerConfig |
| #elif defined(DEFAULT_X86_64_CODEGEN) |
| X86_64CompilerConfig |
| #else |
| # error "Unsupported Default Target!" |
| #endif |
| { }; |
| |
| } // end namespace bcc |
| |
| #endif // BCC_SUPPORT_TARGET_COMPILER_CONFIGS_H |