git: 4e22cd3bf0b4 - main - add types: (u)int64ptr_t
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Thu, 27 Nov 2025 14:56:11 UTC
The branch main has been updated by brooks:
URL: https://cgit.FreeBSD.org/src/commit/?id=4e22cd3bf0b4112e541bc585a6be57662cb0b52b
commit 4e22cd3bf0b4112e541bc585a6be57662cb0b52b
Author: Brooks Davis <brooks@FreeBSD.org>
AuthorDate: 2025-11-27 14:54:56 +0000
Commit: Brooks Davis <brooks@FreeBSD.org>
CommitDate: 2025-11-27 14:54:56 +0000
add types: (u)int64ptr_t
This type represents an integer value of at least 64 bits which is
capable of being cast to and from pointer types. It is intended to
replace various spellings of (u)int64_t there the value is expected to
hold a pointer. This is common in Linux code to allow 32-bit and 64-bit
structures to be the same and used other places including OpenZFS. With
the introduction of CHERI this no longer works, but we need to preserve
the ABI for integer pointer targets. Rather than adding ifdefs in every
case, we introduce a new type.
Reviewed by: kib, markj
Effort: CHERI upstreaming
Sponsored by: Innovate UK
Differential Revision: https://reviews.freebsd.org/D53823
---
sys/sys/_stdint.h | 16 ++++++++++++++++
sys/sys/_types.h | 6 ++++++
2 files changed, 22 insertions(+)
diff --git a/sys/sys/_stdint.h b/sys/sys/_stdint.h
index 5bb089adfba3..a2caec7e9eb9 100644
--- a/sys/sys/_stdint.h
+++ b/sys/sys/_stdint.h
@@ -78,6 +78,22 @@ typedef __intptr_t intptr_t;
typedef __uintptr_t uintptr_t;
#define _UINTPTR_T_DECLARED
#endif
+#if defined(__BSD_VISIBLE) && __BSD_VISIBLE
+/*
+ * Integer types which are 64-bits unless it needs to be larger to hold
+ * a pointer. These are to be used when the ABI for integer targets
+ * uses a fixed 64-bit integer to hold values including pointers in
+ * order to simplify 32- and 64-bit compatibility.
+ */
+#ifndef _INT64PTR_T_DECLARED
+typedef __int64ptr_t int64ptr_t;
+#define _INT64PTR_T_DECLARED
+#endif
+#ifndef _UINT64PTR_T_DECLARED
+typedef __uint64ptr_t uint64ptr_t;
+#define _UINT64PTR_T_DECLARED
+#endif
+#endif
#ifndef _INTMAX_T_DECLARED
typedef __intmax_t intmax_t;
#define _INTMAX_T_DECLARED
diff --git a/sys/sys/_types.h b/sys/sys/_types.h
index 6be3d2c66012..e368f44f950e 100644
--- a/sys/sys/_types.h
+++ b/sys/sys/_types.h
@@ -70,18 +70,24 @@ typedef __uint64_t __uintmax_t;
#ifdef __CHERI__
typedef __intcap_t __intptr_t;
typedef __intcap_t __intfptr_t;
+typedef __intptr_t __int64ptr_t;
typedef __uintcap_t __uintptr_t;
typedef __uintcap_t __uintfptr_t;
+typedef __uintptr_t __uint64ptr_t;
#elif __SIZEOF_POINTER__ == 8
typedef __int64_t __intptr_t;
typedef __int64_t __intfptr_t;
+typedef __int64_t __int64ptr_t;
typedef __uint64_t __uintptr_t;
typedef __uint64_t __uintfptr_t;
+typedef __uint64_t __uint64ptr_t;
#elif __SIZEOF_POINTER__ == 4
typedef __int32_t __intptr_t;
typedef __int32_t __intfptr_t;
+typedef __int64_t __int64ptr_t;
typedef __uint32_t __uintptr_t;
typedef __uint32_t __uintfptr_t;
+typedef __uint64_t __uint64ptr_t;
#else
#error unsupported pointer size
#endif