summaryrefslogtreecommitdiff
path: root/includes/stg
diff options
context:
space:
mode:
authorTomas Carnecky <tomas.carnecky@gmail.com>2016-05-08 14:44:07 +0200
committerBen Gamari <ben@smart-cactus.org>2016-05-10 08:40:50 +0200
commit260a5648c299636a94b12b9b97bf9743b0a1496d (patch)
tree2de1ffe579d1558d4352e496cf2e53b907e954d1 /includes/stg
parentdd3e84701db7d05a6664aa5826732da3ee8ce265 (diff)
downloadhaskell-260a5648c299636a94b12b9b97bf9743b0a1496d.tar.gz
Use stdint types for Stg{Word,Int}{8,16,32,64}
We can't define Stg{Int,Word} in terms of {,u}intptr_t because STG depends on them being the exact same size as void*, and {,u}intptr_t does not make that guarantee. Furthermore, we also need to define StgHalf{Int,Word}, so the preprocessor if needs to stay. But we can at least keep it in a single place instead of repeating it in various files. Also define STG_{INT,WORD}{8,16,32,64}_{MIN,MAX} and use it in HsFFI.h, further reducing the need for CPP in other files. Reviewers: austin, bgamari, simonmar, hvr, erikd Subscribers: thomie Differential Revision: https://phabricator.haskell.org/D2182
Diffstat (limited to 'includes/stg')
-rw-r--r--includes/stg/Types.h130
1 files changed, 75 insertions, 55 deletions
diff --git a/includes/stg/Types.h b/includes/stg/Types.h
index b27430f218..48201b1c55 100644
--- a/includes/stg/Types.h
+++ b/includes/stg/Types.h
@@ -21,6 +21,16 @@
#ifndef STGTYPES_H
#define STGTYPES_H
+/* ISO C 99 says:
+ * "C++ implementations should define these macros only when
+ * __STDC_LIMIT_MACROS is defined before <stdint.h> is included."
+ *
+ * C++11 does not require it anymore. Remove once we upgrade to C++11 or newer.
+ */
+#define __STDC_LIMIT_MACROS
+#import <inttypes.h>
+
+
/*
* This module should define types *only*, all beginning with "Stg".
*
@@ -45,43 +55,41 @@
* First, platform-dependent definitions of size-specific integers.
*/
-typedef signed char StgInt8;
-typedef unsigned char StgWord8;
-
-typedef signed short StgInt16;
-typedef unsigned short StgWord16;
-
-#if SIZEOF_INT == 4
-typedef signed int StgInt32;
-typedef unsigned int StgWord32;
-#define FMT_Word32 "u"
-#define FMT_HexWord32 "x"
-#define FMT_Int32 "d"
-#elif SIZEOF_LONG == 4
-typedef signed long StgInt32;
-typedef unsigned long StgWord32;
-#define FMT_Word32 "lu"
-#define FMT_HexWord32 "lx"
-#define FMT_Int32 "ld"
-#else
-#error GHC untested on this architecture: sizeof(int) != 4
-#endif
+typedef int8_t StgInt8;
+typedef uint8_t StgWord8;
-#if SIZEOF_LONG == 8
-typedef signed long StgInt64;
-typedef unsigned long StgWord64;
-#define FMT_Word64 "lu"
-#define FMT_HexWord64 "lx"
-#define FMT_Int64 "ld"
-#elif SIZEOF_LONG_LONG == 8
-typedef signed long long int StgInt64;
-typedef unsigned long long int StgWord64;
-#define FMT_Word64 "llu"
-#define FMT_HexWord64 "llx"
-#define FMT_Int64 "lld"
-#else
-#error cannot find a way to define StgInt64
-#endif
+#define STG_INT8_MIN INT8_MIN
+#define STG_INT8_MAX INT8_MAX
+#define STG_WORD8_MAX UINT8_MAX
+
+typedef int16_t StgInt16;
+typedef uint16_t StgWord16;
+
+#define STG_INT16_MIN INT16_MIN
+#define STG_INT16_MAX INT16_MAX
+#define STG_WORD16_MAX UINT16_MAX
+
+typedef int32_t StgInt32;
+typedef uint32_t StgWord32;
+
+#define STG_INT32_MIN INT32_MIN
+#define STG_INT32_MAX INT32_MAX
+#define STG_WORD32_MAX UINT32_MAX
+
+#define FMT_Word32 PRIu32
+#define FMT_HexWord32 PRIx32
+#define FMT_Int32 PRId32
+
+typedef int64_t StgInt64;
+typedef uint64_t StgWord64;
+
+#define STG_INT64_MIN INT64_MIN
+#define STG_INT64_MAX INT64_MAX
+#define STG_WORD64_MAX UINT64_MAX
+
+#define FMT_Word64 PRIu64
+#define FMT_HexWord64 PRIx64
+#define FMT_Int64 PRId64
typedef struct { StgWord64 h; StgWord64 l; } StgWord128;
@@ -90,31 +98,43 @@ typedef struct { StgWord128 h; StgWord128 l; } StgWord256;
typedef struct { StgWord256 h; StgWord256 l; } StgWord512;
/*
- * Define the standard word size we'll use on this machine: make it
- * big enough to hold a pointer.
+ * Stg{Int,Word} are defined such that they have the exact same size as a
+ * void pointer.
*/
#if SIZEOF_VOID_P == 8
-typedef StgInt64 StgInt;
-typedef StgWord64 StgWord;
-typedef StgInt32 StgHalfInt;
-typedef StgWord32 StgHalfWord;
-#define FMT_Word FMT_Word64
-#define FMT_HexWord FMT_HexWord64
-#define FMT_Int FMT_Int64
-#else
-#if SIZEOF_VOID_P == 4
-typedef StgInt32 StgInt;
-typedef StgWord32 StgWord;
-typedef StgInt16 StgHalfInt;
-typedef StgWord16 StgHalfWord;
-#define FMT_Word FMT_Word32
-#define FMT_HexWord FMT_HexWord32
-#define FMT_Int FMT_Int32
+typedef int64_t StgInt;
+typedef uint64_t StgWord;
+
+typedef int32_t StgHalfInt;
+typedef uint32_t StgHalfWord;
+
+#define STG_INT_MIN INT64_MIN
+#define STG_INT_MAX INT64_MAX
+#define STG_WORD_MAX UINT64_MAX
+
+#define FMT_Word FMT_Word64
+#define FMT_HexWord FMT_HexWord64
+#define FMT_Int FMT_Int64
+
+#elif SIZEOF_VOID_P == 4
+typedef int32_t StgInt;
+typedef uint32_t StgWord;
+
+typedef int16_t StgHalfInt;
+typedef uint16_s StgHalfWord;
+
+#define STG_INT_MIN INT32_MIN
+#define STG_INT_MAX INT32_MAX
+#define STG_WORD_MAX UINT32_MAX
+
+#define FMT_Word FMT_Word32
+#define FMT_HexWord FMT_HexWord32
+#define FMT_Int FMT_Int32
+
#else
#error GHC untested on this architecture: sizeof(void *) != 4 or 8
#endif
-#endif
#define W_MASK (sizeof(W_)-1)