12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- /*
- * Copyright (c) 2019 BayLibre SAS
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #ifndef ZEPHYR_INCLUDE_TOOLCHAIN_STDINT_H_
- #define ZEPHYR_INCLUDE_TOOLCHAIN_STDINT_H_
- /*
- * Some gcc versions and/or configurations as found in the Zephyr SDK
- * (questionably) define __INT32_TYPE__ and derrivatives as a long int
- * which makes the printf format checker to complain about long vs int
- * mismatch when %u is given a uint32_t argument, and uint32_t pointers not
- * being compatible with int pointers. Let's redefine them to follow
- * common expectations and usage.
- */
- #if __SIZEOF_INT__ != 4
- #error "unexpected int width"
- #endif
- #undef __INT32_TYPE__
- #undef __UINT32_TYPE__
- #undef __INT_LEAST32_TYPE__
- #undef __UINT_LEAST32_TYPE__
- #undef __INT64_TYPE__
- #undef __UINT64_TYPE__
- #define __INT32_TYPE__ int
- #define __UINT32_TYPE__ unsigned int
- #define __INT_LEAST32_TYPE__ __INT32_TYPE__
- #define __UINT_LEAST32_TYPE__ __UINT32_TYPE__
- #define __INT64_TYPE__ long long int
- #define __UINT64_TYPE__ unsigned long long int
- /*
- * The confusion also exists with __INTPTR_TYPE__ which is either an int
- * (even when __INT32_TYPE__ is a long int) or a long int. Let's redefine
- * it to a long int to get some uniformity. Doing so also makes it compatible
- * with LP64 (64-bit) targets where a long is always 64-bit wide.
- */
- #if __SIZEOF_POINTER__ != __SIZEOF_LONG__
- #error "unexpected size difference between pointers and long ints"
- #endif
- #undef __INTPTR_TYPE__
- #undef __UINTPTR_TYPE__
- #define __INTPTR_TYPE__ long int
- #define __UINTPTR_TYPE__ long unsigned int
- #endif /* ZEPHYR_INCLUDE_TOOLCHAIN_STDINT_H_ */
|