#ifndef BCC_CONFIG_CONFIG_H
#define BCC_CONFIG_CONFIG_H
//---------------------------------------------------------------------------
// Configuration for Disassembler
//---------------------------------------------------------------------------
#if DEBUG_MC_DISASSEMBLER
#define USE_DISASSEMBLER 1
#else
#define USE_DISASSEMBLER 0
#endif
#if defined(__HOST__)
#define DEBUG_DISASSEMBLER_FILE "/tmp/mc-dis.s"
#else
#define DEBUG_DISASSEMBLER_FILE "/data/local/tmp/mc-dis.s"
#endif // defined(__HOST__)
//---------------------------------------------------------------------------
// Configuration for CodeGen and CompilerRT
//---------------------------------------------------------------------------
#if defined(FORCE_ARM_CODEGEN)
#define PROVIDE_ARM_CODEGEN
#define DEFAULT_ARM_CODEGEN
#elif defined(FORCE_ARM64_CODEGEN)
#define PROVIDE_ARM_CODEGEN
#define PROVIDE_ARM64_CODEGEN
#define DEFAULT_ARM64_CODEGEN
#elif defined(FORCE_MIPS_CODEGEN)
#define PROVIDE_MIPS_CODEGEN
#define DEFAULT_MIPS_CODEGEN
#elif defined(FORCE_MIPS64_CODEGEN)
#define PROVIDE_MIPS_CODEGEN
#define PROVIDE_MIPS64_CODEGEN
#define DEFAULT_MIPS64_CODEGEN
#elif defined(FORCE_X86_CODEGEN)
#define PROVIDE_X86_CODEGEN
#define DEFAULT_X86_CODEGEN
#elif defined(FORCE_X86_64_CODEGEN)
// There is no separate X86_64 code generation target. It is all part of X86.
#define PROVIDE_X86_CODEGEN
#define DEFAULT_X86_64_CODEGEN
#else
#define PROVIDE_ARM_CODEGEN
#define PROVIDE_ARM64_CODEGEN
#define PROVIDE_MIPS_CODEGEN
#define PROVIDE_MIPS64_CODEGEN
#define PROVIDE_X86_CODEGEN
#define PROVIDE_X86_64_CODEGEN
#if defined(__arm__)
#define DEFAULT_ARM_CODEGEN
#elif defined(__aarch64__)
#define DEFAULT_ARM64_CODEGEN
#elif defined(__mips__)
#if defined(__LP64__)
#define DEFAULT_MIPS64_CODEGEN
#else
#define DEFAULT_MIPS_CODEGEN
#endif
#elif defined(__i386__)
#define DEFAULT_X86_CODEGEN
#elif defined(__x86_64__)
#define DEFAULT_X86_64_CODEGEN
#endif
#endif
#define DEFAULT_ARM_TRIPLE_STRING "armv7-none-linux-gnueabi"
#define DEFAULT_THUMB_TRIPLE_STRING "thumbv7-none-linux-gnueabi"
#define DEFAULT_ARM64_TRIPLE_STRING "aarch64-none-linux-gnueabi"
#define DEFAULT_MIPS_TRIPLE_STRING "mipsel-none-linux-gnueabi"
#define DEFAULT_MIPS64_TRIPLE_STRING "mips64el-none-linux-gnueabi"
#define DEFAULT_X86_TRIPLE_STRING "i686-unknown-linux"
#define DEFAULT_X86_64_TRIPLE_STRING "x86_64-unknown-linux"
// Custom DataLayout string for X86 with i64 and f64 set to match the ARM32
// alignment requirement of 64-bits.
#define X86_CUSTOM_DL_STRING "e-m:e-p:32:32-i64:64-f64:64:64-f80:32-n8:16:32-S128"
// Default DataLayout string for X86. Present to detect future LLVM datalayout
// changes so X86_CUSTOM_DL_STRING above can be modified appropriately.
#define X86_DEFAULT_DL_STRING "e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128"
#if defined(DEFAULT_ARM_CODEGEN)
#define DEFAULT_TARGET_TRIPLE_STRING DEFAULT_ARM_TRIPLE_STRING
#elif defined(DEFAULT_ARM64_CODEGEN)
#define DEFAULT_TARGET_TRIPLE_STRING DEFAULT_ARM64_TRIPLE_STRING
#elif defined(DEFAULT_MIPS_CODEGEN)
#define DEFAULT_TARGET_TRIPLE_STRING DEFAULT_MIPS_TRIPLE_STRING
#elif defined(DEFAULT_MIPS64_CODEGEN)
#define DEFAULT_TARGET_TRIPLE_STRING DEFAULT_MIPS64_TRIPLE_STRING
#elif defined(DEFAULT_X86_CODEGEN)
#define DEFAULT_TARGET_TRIPLE_STRING DEFAULT_X86_TRIPLE_STRING
#elif defined(DEFAULT_X86_64_CODEGEN)
#define DEFAULT_TARGET_TRIPLE_STRING DEFAULT_X86_64_TRIPLE_STRING
#endif
#if (defined(__VFP_FP__) && !defined(__SOFTFP__))
#define ARM_USE_VFP
#endif
//---------------------------------------------------------------------------
#endif // BCC_CONFIG_CONFIG_H