From eaa07ed646b56e928f730dde26a8af1b898e7379 Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Fri, 16 Oct 2015 21:42:09 +0200 Subject: some integer types are pointer-like types that are limited to long MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- include/bits/types.h | 29 +++++++++++++++++++++++------ 1 file changed, 23 insertions(+), 6 deletions(-) (limited to 'include/bits/types.h') diff --git a/include/bits/types.h b/include/bits/types.h index da5521b..dfaef5d 100644 --- a/include/bits/types.h +++ b/include/bits/types.h @@ -41,6 +41,20 @@ (((type)1) << sizeof(type)) #endif +/** + * An integer type for pointers, but not wider than `long int`. + */ +#ifndef __LIMITED_PTR_INT +# if __PTR_BIT == __CHAR_BIT +# define __LIMITED_PTR_INT char +# elif __PTR_BIT == __SHORT_BIT +# define __LIMITED_PTR_INT short int +# elif __PTR_BIT == __INT_BIT +# define __LIMITED_PTR_INT int +# else +# define __LIMITED_PTR_INT long int +#endif + /** * Signed integer type of the result of subtracting two pointers. @@ -48,7 +62,7 @@ */ #if defined(__NEED_ptrdiff_t) && !defined(__DEFINED_ptrdiff_t) # define __DEFINED_ptrdiff_t -typedef signed long int ptrdiff_t; +typedef signed __LIMITED_PTR_INT ptrdiff_t; #endif @@ -57,7 +71,7 @@ typedef signed long int ptrdiff_t; */ #if defined(__NEED_uptrdiff_t) && !defined(__DEFINED_uptrdiff_t) # define __DEFINED_uptrdiff_t -typedef unsigned long int uptrdiff_t; +typedef unsigned __LIMITED_PTR_INT uptrdiff_t; #endif @@ -107,11 +121,11 @@ typedef wchar_t wint_t /** * Unsigned integer type of the result of the * `sizeof` operator. May not be greater than the - * with of type long. + * width of type `long int`. */ #if defined(__NEED_size_t) && !defined(__DEFINED_size_t) # define __DEFINED_size_t -typedef unsigned long int size_t; +typedef unsigned __LIMITED_PTR_INT size_t; #endif @@ -120,7 +134,7 @@ typedef unsigned long int size_t; */ #if defined(__NEED_ssize_t) && !defined(__DEFINED_ssize_t) # define __DEFINED_ssize_t -typedef signed long int ssize_t; +typedef signed __LIMITED_PTR_INT ssize_t; #endif @@ -482,7 +496,7 @@ typedef unsigned __INT64 fsfilcnt_t; */ #if defined(__NEED_blksize_t) && !defined(__DEFINED_blksize_t) # define __DEFINED_blksize_t -typedef signed long int blksize_t; +typedef signed __LIMITED_PTR_INT blksize_t; #endif @@ -494,3 +508,6 @@ typedef signed long int blksize_t; typedef signed __INT64 blkcnt_t; #endif + +/* pid_t and suseconds_t may not exceed long int */ + -- cgit v1.2.3-70-g09d2