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_MACROS_H_ | 5 #ifndef V8_BASE_MACROS_H_ |
6 #define V8_BASE_MACROS_H_ | 6 #define V8_BASE_MACROS_H_ |
7 | 7 |
8 #include <stddef.h> | 8 #include <stddef.h> |
9 #include <stdint.h> | 9 #include <stdint.h> |
10 | 10 |
(...skipping 264 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
275 #define V8PRIuPTR V8_PTR_PREFIX "u" | 275 #define V8PRIuPTR V8_PTR_PREFIX "u" |
276 | 276 |
277 // Fix for Mac OS X defining uintptr_t as "unsigned long": | 277 // Fix for Mac OS X defining uintptr_t as "unsigned long": |
278 #if V8_OS_MACOSX | 278 #if V8_OS_MACOSX |
279 #undef V8PRIxPTR | 279 #undef V8PRIxPTR |
280 #define V8PRIxPTR "lx" | 280 #define V8PRIxPTR "lx" |
281 #undef V8PRIuPTR | 281 #undef V8PRIuPTR |
282 #define V8PRIuPTR "lxu" | 282 #define V8PRIuPTR "lxu" |
283 #endif | 283 #endif |
284 | 284 |
| 285 // GCC on S390 31-bit expands 'size_t' to 'long unsigned int' |
| 286 // instead of 'int', resulting in compilation errors with %d. |
| 287 // The printf format specifier needs to be %zd instead. |
| 288 #if V8_HOST_ARCH_S390 && !V8_HOST_ARCH_64_BIT |
| 289 #define V8_SIZET_PREFIX "z" |
| 290 #else |
| 291 #define V8_SIZET_PREFIX "" |
| 292 #endif |
| 293 |
285 // The following macro works on both 32 and 64-bit platforms. | 294 // The following macro works on both 32 and 64-bit platforms. |
286 // Usage: instead of writing 0x1234567890123456 | 295 // Usage: instead of writing 0x1234567890123456 |
287 // write V8_2PART_UINT64_C(0x12345678,90123456); | 296 // write V8_2PART_UINT64_C(0x12345678,90123456); |
288 #define V8_2PART_UINT64_C(a, b) (((static_cast<uint64_t>(a) << 32) + 0x##b##u)) | 297 #define V8_2PART_UINT64_C(a, b) (((static_cast<uint64_t>(a) << 32) + 0x##b##u)) |
289 | 298 |
290 | 299 |
291 // Compute the 0-relative offset of some absolute value x of type T. | 300 // Compute the 0-relative offset of some absolute value x of type T. |
292 // This allows conversion of Addresses and integral types into | 301 // This allows conversion of Addresses and integral types into |
293 // 0-relative int offsets. | 302 // 0-relative int offsets. |
294 template <typename T> | 303 template <typename T> |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
333 | 342 |
334 template <> | 343 template <> |
335 inline bool is_fundamental<uint8_t>() { | 344 inline bool is_fundamental<uint8_t>() { |
336 return true; | 345 return true; |
337 } | 346 } |
338 | 347 |
339 } // namespace base | 348 } // namespace base |
340 } // namespace v8 | 349 } // namespace v8 |
341 | 350 |
342 #endif // V8_BASE_MACROS_H_ | 351 #endif // V8_BASE_MACROS_H_ |
OLD | NEW |