| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef V8_BASE_BUILD_CONFIG_H_ | 5 #ifndef V8_BASE_BUILD_CONFIG_H_ |
| 6 #define V8_BASE_BUILD_CONFIG_H_ | 6 #define V8_BASE_BUILD_CONFIG_H_ |
| 7 | 7 |
| 8 #include "include/v8config.h" | 8 #include "include/v8config.h" |
| 9 | 9 |
| 10 // Processor architecture detection. For more info on what's defined, see: | 10 // Processor architecture detection. For more info on what's defined, see: |
| (...skipping 30 matching lines...) Expand all Loading... |
| 41 #define V8_HOST_ARCH_64_BIT 1 | 41 #define V8_HOST_ARCH_64_BIT 1 |
| 42 #elif defined(__ARMEL__) | 42 #elif defined(__ARMEL__) |
| 43 #define V8_HOST_ARCH_ARM 1 | 43 #define V8_HOST_ARCH_ARM 1 |
| 44 #define V8_HOST_ARCH_32_BIT 1 | 44 #define V8_HOST_ARCH_32_BIT 1 |
| 45 #elif defined(__mips64) | 45 #elif defined(__mips64) |
| 46 #define V8_HOST_ARCH_MIPS64 1 | 46 #define V8_HOST_ARCH_MIPS64 1 |
| 47 #define V8_HOST_ARCH_64_BIT 1 | 47 #define V8_HOST_ARCH_64_BIT 1 |
| 48 #elif defined(__MIPSEB__) || defined(__MIPSEL__) | 48 #elif defined(__MIPSEB__) || defined(__MIPSEL__) |
| 49 #define V8_HOST_ARCH_MIPS 1 | 49 #define V8_HOST_ARCH_MIPS 1 |
| 50 #define V8_HOST_ARCH_32_BIT 1 | 50 #define V8_HOST_ARCH_32_BIT 1 |
| 51 #elif defined(__PPC__) || defined(_ARCH_PPC) |
| 52 #define V8_HOST_ARCH_PPC 1 |
| 53 #if defined(__PPC64__) || defined(_ARCH_PPC64) |
| 54 #define V8_HOST_ARCH_64_BIT 1 |
| 55 #else |
| 56 #define V8_HOST_ARCH_32_BIT 1 |
| 57 #endif |
| 51 #else | 58 #else |
| 52 #error "Host architecture was not detected as supported by v8" | 59 #error "Host architecture was not detected as supported by v8" |
| 53 #endif | 60 #endif |
| 54 | 61 |
| 55 #if defined(__ARM_ARCH_7A__) || \ | 62 #if defined(__ARM_ARCH_7A__) || \ |
| 56 defined(__ARM_ARCH_7R__) || \ | 63 defined(__ARM_ARCH_7R__) || \ |
| 57 defined(__ARM_ARCH_7__) | 64 defined(__ARM_ARCH_7__) |
| 58 # define CAN_USE_ARMV7_INSTRUCTIONS 1 | 65 # define CAN_USE_ARMV7_INSTRUCTIONS 1 |
| 59 # ifndef CAN_USE_VFP3_INSTRUCTIONS | 66 # ifndef CAN_USE_VFP3_INSTRUCTIONS |
| 60 # define CAN_USE_VFP3_INSTRUCTIONS | 67 # define CAN_USE_VFP3_INSTRUCTIONS |
| 61 # endif | 68 # endif |
| 62 #endif | 69 #endif |
| 63 | 70 |
| 64 | 71 |
| 65 // Target architecture detection. This may be set externally. If not, detect | 72 // Target architecture detection. This may be set externally. If not, detect |
| 66 // in the same way as the host architecture, that is, target the native | 73 // in the same way as the host architecture, that is, target the native |
| 67 // environment as presented by the compiler. | 74 // environment as presented by the compiler. |
| 68 #if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_IA32 && !V8_TARGET_ARCH_X87 && \ | 75 #if !V8_TARGET_ARCH_X64 && !V8_TARGET_ARCH_IA32 && !V8_TARGET_ARCH_X87 && \ |
| 69 !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_MIPS && \ | 76 !V8_TARGET_ARCH_ARM && !V8_TARGET_ARCH_ARM64 && !V8_TARGET_ARCH_MIPS && \ |
| 70 !V8_TARGET_ARCH_MIPS64 | 77 !V8_TARGET_ARCH_MIPS64 && !V8_TARGET_ARCH_PPC |
| 71 #if defined(_M_X64) || defined(__x86_64__) | 78 #if defined(_M_X64) || defined(__x86_64__) |
| 72 #define V8_TARGET_ARCH_X64 1 | 79 #define V8_TARGET_ARCH_X64 1 |
| 73 #elif defined(_M_IX86) || defined(__i386__) | 80 #elif defined(_M_IX86) || defined(__i386__) |
| 74 #define V8_TARGET_ARCH_IA32 1 | 81 #define V8_TARGET_ARCH_IA32 1 |
| 75 #elif defined(__AARCH64EL__) | 82 #elif defined(__AARCH64EL__) |
| 76 #define V8_TARGET_ARCH_ARM64 1 | 83 #define V8_TARGET_ARCH_ARM64 1 |
| 77 #elif defined(__ARMEL__) | 84 #elif defined(__ARMEL__) |
| 78 #define V8_TARGET_ARCH_ARM 1 | 85 #define V8_TARGET_ARCH_ARM 1 |
| 79 #elif defined(__mips64) | 86 #elif defined(__mips64) |
| 80 #define V8_TARGET_ARCH_MIPS64 1 | 87 #define V8_TARGET_ARCH_MIPS64 1 |
| (...skipping 16 matching lines...) Expand all Loading... |
| 97 #endif | 104 #endif |
| 98 #endif | 105 #endif |
| 99 #elif V8_TARGET_ARCH_ARM | 106 #elif V8_TARGET_ARCH_ARM |
| 100 #define V8_TARGET_ARCH_32_BIT 1 | 107 #define V8_TARGET_ARCH_32_BIT 1 |
| 101 #elif V8_TARGET_ARCH_ARM64 | 108 #elif V8_TARGET_ARCH_ARM64 |
| 102 #define V8_TARGET_ARCH_64_BIT 1 | 109 #define V8_TARGET_ARCH_64_BIT 1 |
| 103 #elif V8_TARGET_ARCH_MIPS | 110 #elif V8_TARGET_ARCH_MIPS |
| 104 #define V8_TARGET_ARCH_32_BIT 1 | 111 #define V8_TARGET_ARCH_32_BIT 1 |
| 105 #elif V8_TARGET_ARCH_MIPS64 | 112 #elif V8_TARGET_ARCH_MIPS64 |
| 106 #define V8_TARGET_ARCH_64_BIT 1 | 113 #define V8_TARGET_ARCH_64_BIT 1 |
| 114 #elif V8_TARGET_ARCH_PPC |
| 115 #if V8_TARGET_ARCH_PPC64 |
| 116 #define V8_TARGET_ARCH_64_BIT 1 |
| 117 #else |
| 118 #define V8_TARGET_ARCH_32_BIT 1 |
| 119 #endif |
| 107 #elif V8_TARGET_ARCH_X87 | 120 #elif V8_TARGET_ARCH_X87 |
| 108 #define V8_TARGET_ARCH_32_BIT 1 | 121 #define V8_TARGET_ARCH_32_BIT 1 |
| 109 #else | 122 #else |
| 110 #error Unknown target architecture pointer size | 123 #error Unknown target architecture pointer size |
| 111 #endif | 124 #endif |
| 112 | 125 |
| 113 // Check for supported combinations of host and target architectures. | 126 // Check for supported combinations of host and target architectures. |
| 114 #if V8_TARGET_ARCH_IA32 && !V8_HOST_ARCH_IA32 | 127 #if V8_TARGET_ARCH_IA32 && !V8_HOST_ARCH_IA32 |
| 115 #error Target architecture ia32 is only supported on ia32 host | 128 #error Target architecture ia32 is only supported on ia32 host |
| 116 #endif | 129 #endif |
| (...skipping 30 matching lines...) Expand all Loading... |
| 147 #elif V8_TARGET_ARCH_MIPS | 160 #elif V8_TARGET_ARCH_MIPS |
| 148 #if defined(__MIPSEB__) | 161 #if defined(__MIPSEB__) |
| 149 #define V8_TARGET_BIG_ENDIAN 1 | 162 #define V8_TARGET_BIG_ENDIAN 1 |
| 150 #else | 163 #else |
| 151 #define V8_TARGET_LITTLE_ENDIAN 1 | 164 #define V8_TARGET_LITTLE_ENDIAN 1 |
| 152 #endif | 165 #endif |
| 153 #elif V8_TARGET_ARCH_MIPS64 | 166 #elif V8_TARGET_ARCH_MIPS64 |
| 154 #define V8_TARGET_LITTLE_ENDIAN 1 | 167 #define V8_TARGET_LITTLE_ENDIAN 1 |
| 155 #elif V8_TARGET_ARCH_X87 | 168 #elif V8_TARGET_ARCH_X87 |
| 156 #define V8_TARGET_LITTLE_ENDIAN 1 | 169 #define V8_TARGET_LITTLE_ENDIAN 1 |
| 170 #elif V8_TARGET_ARCH_PPC_LE |
| 171 #define V8_TARGET_LITTLE_ENDIAN 1 |
| 172 #elif V8_TARGET_ARCH_PPC_BE |
| 173 #define V8_TARGET_BIG_ENDIAN 1 |
| 157 #else | 174 #else |
| 158 #error Unknown target architecture endianness | 175 #error Unknown target architecture endianness |
| 159 #endif | 176 #endif |
| 160 | 177 |
| 161 // Number of bits to represent the page size for paged spaces. The value of 20 | 178 // Number of bits to represent the page size for paged spaces. The value of 20 |
| 162 // gives 1Mb bytes per page. | 179 // gives 1Mb bytes per page. |
| 163 const int kPageSizeBits = 20; | 180 const int kPageSizeBits = 20; |
| 164 | 181 |
| 165 #endif // V8_BASE_BUILD_CONFIG_H_ | 182 #endif // V8_BASE_BUILD_CONFIG_H_ |
| OLD | NEW |