]> granicus.if.org Git - clang/commitdiff
Apparently it is important to define intptr_t and uintptr_t to
authorChris Lattner <sabre@nondot.org>
Sat, 7 Feb 2009 00:23:17 +0000 (00:23 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 7 Feb 2009 00:23:17 +0000 (00:23 +0000)
long instead of int.  This is because system heaers like to redefine
typedefs and that is an error if they don't exactly match.  Use long
for intptr_t on all systems where long is the right size.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@63984 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Headers/stdint.h

index e7b205a0fcc047431aac97e009a5f7089d723c90..606d396f4d805973a133bdd311987c226cc0a9f7 100644 (file)
@@ -70,7 +70,14 @@ typedef uint64_t uint_fast64_t;
 
 /* C99 7.18.1.4 Integer types capable of holding object pointers.
  */
-#if __POINTER_WIDTH__ == 64
+#if (1LL << (__POINTER_WIDTH__-1))-1 == __LONG_MAX__
+/* If the pointer size is equal to long, use long.  This is for compatibility
+ * with many systems which just use long and expect it to work in 32-bit and
+ * 64-bit mode.  If long is not suitable, we use a fixed size type below.
+ */
+typedef long          intptr_t;
+typedef unsigned long uintptr_t;
+#elif __POINTER_WIDTH__ == 64
 typedef int64_t  intptr_t;
 typedef uint64_t uintptr_t;
 #elif __POINTER_WIDTH__ == 32