[ccan] [PATCH v2 11/13] configurator: Return pointer difference as ptrdiff_t
Kevin Locke
kevin at kevinlocke.name
Fri Sep 23 13:33:14 AEST 2016
On LLP64 systems (like 64-bit Windows) long is 32 bits while pointers
are 64 bits, which results in a warning similar to the following:
warning C4244: 'return': conversion from '__int64' to 'long', possible loss of data
for HAVE_STACK_GROWS_UPWARDS. Fix this by using the ptrdiff_t type
introduced by C99 for this purpose.
Signed-off-by: Kevin Locke <kevin at kevinlocke.name>
---
tools/configurator/configurator.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/tools/configurator/configurator.c b/tools/configurator/configurator.c
index a43061b..2acb0b2 100644
--- a/tools/configurator/configurator.c
+++ b/tools/configurator/configurator.c
@@ -298,7 +298,8 @@ static struct test tests[] = {
" return __stop_mysec - __start_mysec;\n"
"}\n" },
{ "HAVE_STACK_GROWS_UPWARDS", DEFINES_EVERYTHING|EXECUTE, NULL, NULL,
- "static long nest(const void *base, unsigned int i)\n"
+ "#include <stddef.h>\n"
+ "static ptrdiff_t nest(const void *base, unsigned int i)\n"
"{\n"
" if (i == 0)\n"
" return (const char *)&i - (const char *)base;\n"
--
2.9.3
More information about the ccan
mailing list