powerc64-xtoolchain-gcc with -m32 on powerpc64 vs. lib32/libedit and wchar_t use: gcc 4.9.1 forces __WCHAR_TYPE__ (underlying type?) long int
Mark Millard
markmi at dsl-only.net
Sat Apr 11 03:17:18 UTC 2015
I got the following when trying WITH_LIB32= with powerpc64-xtoolchain-gcc (on a powerpc64 box, WITHOUT_BOOT= ) :
> . . . parse.c:181:25: error: array of inappropriate type initialized from string constant
> const Char hex[] = STR("0123456789ABCDEF");
> ^
The rest of this note is about what I found when I looked into this. Read only if you care. File for later if you likely would care later?
The libedit/Makefile uses -DWIDECHAR and libedit/chartype.h defines for that case:
> #define Char wchar_t
> . . .
> #define STR(x) L ## x
> #define UC(c) c
There were lots of warnings for incompatible pointer types for libedit/. . . including the following one that was explicit about which type is involved:
> note: expected 'const wchar_t *' but argument is of type 'long int *'
> int wcscmp(const wchar_t *, const wchar_t *) __pure;
> ^
So how did the long int type end up involved? I expect the following may contribute.
Turns out that long int (and L suffix use in __WCHAR_MAX__) is specific to 4.9.1 -m32 handling when compared to gcc 4.2.1 . . .
> # gcc -dM -E -m32 - < /dev/null | grep WCHAR
> #define __WCHAR_MAX__ 2147483647
> #define __WCHAR_TYPE__ int
> # /usr/local/bin/powerpc64-portbld-freebsd11.0-gcc-4.9.1 -dM -E -m32 - < /dev/null | grep WCHAR
> #define __WCHAR_MAX__ 2147483647L
> #define __WCHAR_MIN__ (-__WCHAR_MAX__ - 1)
> #define __GCC_ATOMIC_WCHAR_T_LOCK_FREE 2
> #define __WCHAR_TYPE__ long int
> #define __SIZEOF_WCHAR_T__ 4
and compared to -m64 for both 4.2.1 and 4.9.1 . . .
> # gcc -dM -E -m64 - < /dev/null | grep WCHAR
> #define __WCHAR_MAX__ 2147483647
> #define __WCHAR_TYPE__ int
> # /usr/local/bin/powerpc64-portbld-freebsd11.0-gcc-4.9.1 -dM -E -m64 - < /dev/null | grep WCHAR
> #define __WCHAR_MAX__ 2147483647
> #define __WCHAR_MIN__ (-__WCHAR_MAX__ - 1)
> #define __GCC_ATOMIC_WCHAR_T_LOCK_FREE 2
> #define __WCHAR_TYPE__ int
> #define __SIZEOF_WCHAR_T__ 4
(where I expect that __WCHAR_TYPE__ is the underlying type used for wchar_t).
The following ended up installed for the 4.9.1 compiler . . .
> #undef WCHAR_TYPE
> #define WCHAR_TYPE (TARGET_64BIT ? "int" : "long int")
> #undef WCHAR_TYPE_SIZE
> #define WCHAR_TYPE_SIZE 32
> /usr/local/lib/gcc/powerpc64-portbld-freebsd11.0/4.9.1/plugin/include/config/rs6000/freebsd64.h
> #undef WCHAR_TYPE
> #define WCHAR_TYPE "long int"
> #undef WCHAR_TYPE_SIZE
> #define WCHAR_TYPE_SIZE 32
> /usr/local/lib/gcc/powerpc64-portbld-freebsd11.0/4.9.1/plugin/include/config/rs6000/sysv4.h
===
Mark Millard
markmi at dsl-only.net
More information about the freebsd-toolchain
mailing list