FFIMe
FFIMe copied to clipboard
Uncaught PHPCParser\Error: Syntax error, unexpected IDENTIFIER(int_least8_t)
Hi @bwoebi
Attempting to use Redis's https://github.com/redis/hiredis library, I'm getting the following error.
PHP Fatal error: Uncaught PHPCParser\Error: Syntax error, unexpected IDENTIFIER(int_least8_t), expecting ',' or ';' on line 395 in ~/hiredis/vendor/ircmaxell/php-c-parser/lib/ParserAbstract.php:236
Stack trace:
#0 ~/hiredis/vendor/ircmaxell/php-c-parser/lib/ParserAbstract.php(105): PHPCParser\ParserAbstract->doParse()
#1 ~/hiredis/vendor/ircmaxell/php-c-parser/lib/CParser.php(24): PHPCParser\ParserAbstract->parse()
#2 ~/hiredis/vendor/ircmaxell/ffime/lib/FFIMe.php(113): PHPCParser\CParser->parse()
#3 ~/hiredis/hiredis-rev1.php(12): FFIMe\FFIMe->include()
#4 {main}
thrown in ~/hiredis/vendor/ircmaxell/php-c-parser/lib/ParserAbstract.php on line 236
The hiredis.h
file itself doesn't include any int_least8_t
yet one of its dependencies stdint.h
which is a glibc-headers
package included header.
I guess the part of interest in the stdint.h
file is the following.
/* Small types. */
/* Signed. */
typedef __int_least8_t int_least8_t;
typedef __int_least16_t int_least16_t;
typedef __int_least32_t int_least32_t;
typedef __int_least64_t int_least64_t;
/* Unsigned. */
typedef __uint_least8_t uint_least8_t;
typedef __uint_least16_t uint_least16_t;
typedef __uint_least32_t uint_least32_t;
typedef __uint_least64_t uint_least64_t;
This specific parser error happens when typedef
is followed by a not defined identifier.
On my linux system /usr/include/x86_64-linux-gnu/bits/types.h
defines __int_least8_t (which is included from <stdint.h>
on my system).
Does grep -r __int_least8_t /usr/include
find anything for you? Is <bits/types.h>
included in your stdint.h
?
@bwoebi yes, <bits/types.h>
included in my stdint.h
grep -r __int_least8_t /usr/include
/usr/include/bits/types.h:typedef __int8_t __int_least8_t;
/usr/include/stdint.h:typedef __int_least8_t int_least8_t;
@bwoebi also experienced the same attempting to use https://github.com/facebook/rocksdb/blob/main/include/rocksdb/c.h
Sorry for the delay, yes, I can reproduce it and am looking into it.
The problem is that these macros are gcc predefined macros, concretely it does not find __INT_LEAST8_TYPE__
here.
If you check echo | gcc -E -xc -v -dM -
you'll find these there... Added more of them to php-c-parser. hiredis works now for me.
@bwoebi Yeah everybody needs a downtime, eventually :)
I got the following after the update...
For the following code...
<?php
require_once __DIR__ . '/vendor/autoload.php';
(new FFIMe\FFIMe('/usr/lib64/libhiredis.so.1.0.0'))
->include('/usr/include/hiredis/hiredis.h')
->codeGen('hiredis\\hiredis', __DIR__ . '/hiredis.php');
require __DIR__ . '/hiredis.php';
I am getting...
[Warning] Skipping stdin, not found in object file
[Warning] Skipping stdout, not found in object file
[Warning] Skipping stderr, not found in object file
[Warning] Skipping remove, not found in object file
[Warning] Skipping rename, not found in object file
[Warning] Skipping renameat, not found in object file
[Warning] Skipping fclose, not found in object file
[Warning] Skipping tmpfile, not found in object file
[Warning] Skipping tmpnam, not found in object file
[Warning] Skipping tmpnam_r, not found in object file
[Warning] Skipping tempnam, not found in object file
[Warning] Skipping fflush, not found in object file
[Warning] Skipping fflush_unlocked, not found in object file
[Warning] Skipping fopen, not found in object file
[Warning] Skipping freopen, not found in object file
[Warning] Skipping fdopen, not found in object file
[Warning] Skipping fmemopen, not found in object file
[Warning] Skipping open_memstream, not found in object file
[Warning] Skipping setbuf, not found in object file
[Warning] Skipping setvbuf, not found in object file
[Warning] Skipping setbuffer, not found in object file
[Warning] Skipping setlinebuf, not found in object file
[Warning] Skipping fprintf, not found in object file
[Warning] Skipping printf, not found in object file
[Warning] Skipping sprintf, not found in object file
[Warning] Skipping vfprintf, not found in object file
[Warning] Skipping vprintf, not found in object file
[Warning] Skipping vsprintf, not found in object file
[Warning] Skipping vsnprintf, not found in object file
[Warning] Skipping vdprintf, not found in object file
[Warning] Skipping dprintf, not found in object file
[Warning] Skipping fscanf, not found in object file
[Warning] Skipping scanf, not found in object file
[Warning] Skipping sscanf, not found in object file
[Warning] Skipping fscanf, not found in object file
[Warning] Skipping scanf, not found in object file
[Warning] Skipping sscanf, not found in object file
[Warning] Skipping vfscanf, not found in object file
[Warning] Skipping vscanf, not found in object file
[Warning] Skipping vsscanf, not found in object file
[Warning] Skipping vfscanf, not found in object file
[Warning] Skipping vscanf, not found in object file
[Warning] Skipping vsscanf, not found in object file
[Warning] Skipping fgetc, not found in object file
[Warning] Skipping getc, not found in object file
[Warning] Skipping getchar, not found in object file
[Warning] Skipping getc_unlocked, not found in object file
[Warning] Skipping getchar_unlocked, not found in object file
[Warning] Skipping fgetc_unlocked, not found in object file
[Warning] Skipping fputc, not found in object file
[Warning] Skipping putc, not found in object file
[Warning] Skipping putchar, not found in object file
[Warning] Skipping fputc_unlocked, not found in object file
[Warning] Skipping putc_unlocked, not found in object file
[Warning] Skipping putchar_unlocked, not found in object file
[Warning] Skipping getw, not found in object file
[Warning] Skipping putw, not found in object file
[Warning] Skipping fgets, not found in object file
[Warning] Skipping gets, not found in object file
[Warning] Skipping __getdelim, not found in object file
[Warning] Skipping getdelim, not found in object file
[Warning] Skipping getline, not found in object file
[Warning] Skipping fputs, not found in object file
[Warning] Skipping puts, not found in object file
[Warning] Skipping ungetc, not found in object file
[Warning] Skipping fread, not found in object file
[Warning] Skipping fwrite, not found in object file
[Warning] Skipping fread_unlocked, not found in object file
[Warning] Skipping fwrite_unlocked, not found in object file
[Warning] Skipping fseek, not found in object file
[Warning] Skipping ftell, not found in object file
[Warning] Skipping rewind, not found in object file
[Warning] Skipping fseeko, not found in object file
[Warning] Skipping ftello, not found in object file
[Warning] Skipping fgetpos, not found in object file
[Warning] Skipping fsetpos, not found in object file
[Warning] Skipping clearerr, not found in object file
[Warning] Skipping feof, not found in object file
[Warning] Skipping ferror, not found in object file
[Warning] Skipping clearerr_unlocked, not found in object file
[Warning] Skipping feof_unlocked, not found in object file
[Warning] Skipping ferror_unlocked, not found in object file
[Warning] Skipping perror, not found in object file
[Warning] Skipping fileno, not found in object file
[Warning] Skipping fileno_unlocked, not found in object file
[Warning] Skipping pclose, not found in object file
[Warning] Skipping popen, not found in object file
[Warning] Skipping ctermid, not found in object file
[Warning] Skipping flockfile, not found in object file
[Warning] Skipping ftrylockfile, not found in object file
[Warning] Skipping funlockfile, not found in object file
[Warning] Skipping __uflow, not found in object file
[Warning] Skipping __overflow, not found in object file
[Warning] Skipping select, not found in object file
[Warning] Skipping pselect, not found in object file
[Warning] Skipping gettimeofday, not found in object file
[Warning] Skipping settimeofday, not found in object file
[Warning] Skipping adjtime, not found in object file
[Warning] Skipping getitimer, not found in object file
[Warning] Skipping setitimer, not found in object file
[Warning] Skipping utimes, not found in object file
[Warning] Skipping lutimes, not found in object file
[Warning] Skipping futimes, not found in object file
[Warning] __cfloat128 could not be compiled: _Complex float is not supported by ext/ffi
PHP Parse error: syntax error, unexpected floating-point number ".0", expecting "," or ";" in ~/hiredis/hiredis.php on line 716
Regardless of the earlier warning, the parsing error is in const HIREDIS_SONAME = 1.0.0;
$ readelf -d /usr/lib64/libhiredis.so | grep SONAME
0x000000000000000e (SONAME) Library soname: [libhiredis.so.1.0.0]
Output of echo | gcc -E -xc -v -dM -
Using built-in specs.
COLLECT_GCC=gcc
OFFLOAD_TARGET_NAMES=nvptx-none
OFFLOAD_TARGET_DEFAULT=1
Target: x86_64-redhat-linux
Configured with: ../configure --enable-bootstrap --enable-languages=c,c++,fortran,objc,obj-c++,ada,go,d,lto --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-shared --enable-threads=posix --enable-checking=release --enable-multilib --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-linker-build-id --with-gcc-major-version-only --enable-libstdcxx-backtrace --with-linker-hash-style=gnu --enable-plugin --enable-initfini-array --with-isl=/builddir/build/BUILD/gcc-12.2.1-20220819/obj-x86_64-redhat-linux/isl-install --enable-offload-targets=nvptx-none --without-cuda-driver --enable-offload-defaulted --enable-gnu-indirect-function --enable-cet --with-tune=generic --with-arch_32=i686 --build=x86_64-redhat-linux --with-build-config=bootstrap-lto --enable-link-serialization=1
Thread model: posix
Supported LTO compression algorithms: zlib zstd
gcc version 12.2.1 20220819 (Red Hat 12.2.1-1) (GCC)
COLLECT_GCC_OPTIONS='-E' '-v' '-dM' '-mtune=generic' '-march=x86-64'
/usr/libexec/gcc/x86_64-redhat-linux/12/cc1 -E -quiet -v - -mtune=generic -march=x86-64 -dM -dumpbase -
ignoring nonexistent directory "/usr/lib/gcc/x86_64-redhat-linux/12/include-fixed"
ignoring nonexistent directory "/usr/lib/gcc/x86_64-redhat-linux/12/../../../../x86_64-redhat-linux/include"
#include "..." search starts here:
#include <...> search starts here:
/usr/lib/gcc/x86_64-redhat-linux/12/include
/usr/local/include
/usr/include
End of search list.
#define __DBL_MIN_EXP__ (-1021)
#define __UINT_LEAST16_MAX__ 0xffff
#define __FLT16_HAS_QUIET_NAN__ 1
#define __ATOMIC_ACQUIRE 2
#define __FLT128_MAX_10_EXP__ 4932
#define __FLT_MIN__ 1.17549435082228750796873653722224568e-38F
#define __GCC_IEC_559_COMPLEX 2
#define __UINT_LEAST8_TYPE__ unsigned char
#define __SIZEOF_FLOAT80__ 16
#define __INTMAX_C(c) c ## L
#define __CHAR_BIT__ 8
#define __UINT8_MAX__ 0xff
#define __SCHAR_WIDTH__ 8
#define __WINT_MAX__ 0xffffffffU
#define __FLT32_MIN_EXP__ (-125)
#define __ORDER_LITTLE_ENDIAN__ 1234
#define __SIZE_MAX__ 0xffffffffffffffffUL
#define __WCHAR_MAX__ 0x7fffffff
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
#define __GCC_ATOMIC_CHAR_LOCK_FREE 2
#define __GCC_IEC_559 2
#define __FLT32X_DECIMAL_DIG__ 17
#define __FLT_EVAL_METHOD__ 0
#define __FLT64_DECIMAL_DIG__ 17
#define __GCC_ATOMIC_CHAR32_T_LOCK_FREE 2
#define __UINT_FAST64_MAX__ 0xffffffffffffffffUL
#define __SIG_ATOMIC_TYPE__ int
#define __DBL_MIN_10_EXP__ (-307)
#define __FINITE_MATH_ONLY__ 0
#define __FLT32X_MAX_EXP__ 1024
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
#define __FLT32_HAS_DENORM__ 1
#define __UINT_FAST8_MAX__ 0xff
#define __FLT32_MAX_10_EXP__ 38
#define __DEC64_MAX_EXP__ 385
#define __INT8_C(c) c
#define __INT_LEAST8_WIDTH__ 8
#define __UINT_LEAST64_MAX__ 0xffffffffffffffffUL
#define __SHRT_MAX__ 0x7fff
#define __LDBL_MAX__ 1.18973149535723176502126385303097021e+4932L
#define __FLT64X_MAX_10_EXP__ 4932
#define __LDBL_IS_IEC_60559__ 2
#define __FLT64X_HAS_QUIET_NAN__ 1
#define __UINT_LEAST8_MAX__ 0xff
#define __GCC_ATOMIC_BOOL_LOCK_FREE 2
#define __FLT128_DENORM_MIN__ 6.47517511943802511092443895822764655e-4966F128
#define __UINTMAX_TYPE__ long unsigned int
#define __linux 1
#define __DEC32_EPSILON__ 1E-6DF
#define __FLT_EVAL_METHOD_TS_18661_3__ 0
#define __unix 1
#define __UINT32_MAX__ 0xffffffffU
#define __DBL_DENORM_MIN__ ((double)4.94065645841246544176568792868221372e-324L)
#define __FLT128_MIN_EXP__ (-16381)
#define __WINT_MIN__ 0U
#define __FLT128_MIN_10_EXP__ (-4931)
#define __FLT32X_IS_IEC_60559__ 2
#define __INT_LEAST16_WIDTH__ 16
#define __SCHAR_MAX__ 0x7f
#define __FLT128_MANT_DIG__ 113
#define __WCHAR_MIN__ (-__WCHAR_MAX__ - 1)
#define __INT64_C(c) c ## L
#define __GCC_ATOMIC_POINTER_LOCK_FREE 2
#define __FLT32X_MANT_DIG__ 53
#define __FLT64X_EPSILON__ 1.08420217248550443400745280086994171e-19F64x
#define __STDC_HOSTED__ 1
#define __DEC64_MIN_EXP__ (-382)
#define __DBL_DIG__ 15
#define __FLT32_DIG__ 6
#define __FLT_EPSILON__ 1.19209289550781250000000000000000000e-7F
#define __SHRT_WIDTH__ 16
#define __FLT32_IS_IEC_60559__ 2
#define __LDBL_MIN__ 3.36210314311209350626267781732175260e-4932L
#define __STDC_UTF_16__ 1
#define __DBL_IS_IEC_60559__ 2
#define __DEC32_MAX__ 9.999999E96DF
#define __FLT64X_DENORM_MIN__ 3.64519953188247460252840593361941982e-4951F64x
#define __FLT32X_HAS_INFINITY__ 1
#define __INT32_MAX__ 0x7fffffff
#define __FLT16_DIG__ 3
#define __unix__ 1
#define __INT_WIDTH__ 32
#define __SIZEOF_LONG__ 8
#define __STDC_IEC_559__ 1
#define __STDC_ISO_10646__ 201706L
#define __UINT16_C(c) c
#define __DECIMAL_DIG__ 21
#define __STDC_IEC_559_COMPLEX__ 1
#define __FLT64_EPSILON__ 2.22044604925031308084726333618164062e-16F64
#define __gnu_linux__ 1
#define __FLT128_IS_IEC_60559__ 2
#define __FLT64X_MIN_10_EXP__ (-4931)
#define __LDBL_HAS_QUIET_NAN__ 1
#define __FLT16_MIN_EXP__ (-13)
#define __FLT64_MANT_DIG__ 53
#define __FLT64X_MANT_DIG__ 64
#define __GNUC__ 12
#define __MMX__ 1
#define __FLT_HAS_DENORM__ 1
#define __SIZEOF_LONG_DOUBLE__ 16
#define __BIGGEST_ALIGNMENT__ 16
#define __FLT64_MAX_10_EXP__ 308
#define __FLT16_MAX_10_EXP__ 4
#define __DBL_MAX__ ((double)1.79769313486231570814527423731704357e+308L)
#define __INT_FAST32_MAX__ 0x7fffffffffffffffL
#define __DBL_HAS_INFINITY__ 1
#define __SIZEOF_FLOAT__ 4
#define __HAVE_SPECULATION_SAFE_VALUE 1
#define __DEC32_MIN_EXP__ (-94)
#define __INTPTR_WIDTH__ 64
#define __FLT64X_HAS_INFINITY__ 1
#define __UINT_LEAST32_MAX__ 0xffffffffU
#define __FLT32X_HAS_DENORM__ 1
#define __INT_FAST16_TYPE__ long int
#define __MMX_WITH_SSE__ 1
#define __LDBL_HAS_DENORM__ 1
#define __SEG_GS 1
#define __FLT128_HAS_INFINITY__ 1
#define __DEC32_MIN__ 1E-95DF
#define __DBL_MAX_EXP__ 1024
#define __WCHAR_WIDTH__ 32
#define __FLT32_MAX__ 3.40282346638528859811704183484516925e+38F32
#define __DEC128_EPSILON__ 1E-33DL
#define __FLT16_DECIMAL_DIG__ 5
#define __SSE2_MATH__ 1
#define __ATOMIC_HLE_RELEASE 131072
#define __PTRDIFF_MAX__ 0x7fffffffffffffffL
#define __amd64 1
#define __ATOMIC_HLE_ACQUIRE 65536
#define __LONG_LONG_MAX__ 0x7fffffffffffffffLL
#define __SIZEOF_SIZE_T__ 8
#define __FLT64X_MIN_EXP__ (-16381)
#define __SIZEOF_WINT_T__ 4
#define __LONG_LONG_WIDTH__ 64
#define __FLT32_MAX_EXP__ 128
#define __GXX_ABI_VERSION 1017
#define __FLT_MIN_EXP__ (-125)
#define __GCC_HAVE_DWARF2_CFI_ASM 1
#define __INT16_MAX__ 0x7fff
#define __x86_64 1
#define __INT_FAST64_TYPE__ long int
#define __FLT64_DENORM_MIN__ 4.94065645841246544176568792868221372e-324F64
#define __DBL_MIN__ ((double)2.22507385850720138309023271733240406e-308L)
#define __FLT16_DENORM_MIN__ 5.96046447753906250000000000000000000e-8F16
#define __FLT128_EPSILON__ 1.92592994438723585305597794258492732e-34F128
#define __FLT64X_NORM_MAX__ 1.18973149535723176502126385303097021e+4932F64x
#define __SIZEOF_POINTER__ 8
#define __LP64__ 1
#define __DBL_HAS_QUIET_NAN__ 1
#define __FLT32X_EPSILON__ 2.22044604925031308084726333618164062e-16F32x
#define __DECIMAL_BID_FORMAT__ 1
#define __FLT64_MIN_EXP__ (-1021)
#define __FLT64_MIN_10_EXP__ (-307)
#define __FLT16_MIN_10_EXP__ (-4)
#define __FLT64X_DECIMAL_DIG__ 21
#define __DEC128_MIN__ 1E-6143DL
#define __REGISTER_PREFIX__
#define __UINT16_MAX__ 0xffff
#define __DBL_HAS_DENORM__ 1
#define __LDBL_HAS_INFINITY__ 1
#define __FLT32_MIN__ 1.17549435082228750796873653722224568e-38F32
#define __UINT8_TYPE__ unsigned char
#define __FLT_DIG__ 6
#define __NO_INLINE__ 1
#define __DEC_EVAL_METHOD__ 2
#define __DEC128_MAX__ 9.999999999999999999999999999999999E6144DL
#define __FLT_MANT_DIG__ 24
#define __LDBL_DECIMAL_DIG__ 21
#define __VERSION__ "12.2.1 20220819 (Red Hat 12.2.1-1)"
#define __UINT64_C(c) c ## UL
#define _STDC_PREDEF_H 1
#define __INT_LEAST32_MAX__ 0x7fffffff
#define __GCC_ATOMIC_INT_LOCK_FREE 2
#define __FLT128_MAX_EXP__ 16384
#define __FLT32_MANT_DIG__ 24
#define __FLOAT_WORD_ORDER__ __ORDER_LITTLE_ENDIAN__
#define __FLT32X_MIN_EXP__ (-1021)
#define __STDC_IEC_60559_COMPLEX__ 201404L
#define __FLT128_HAS_DENORM__ 1
#define __FLT32_DECIMAL_DIG__ 9
#define __FLT128_DIG__ 33
#define __INT32_C(c) c
#define __DEC64_EPSILON__ 1E-15DD
#define __ORDER_PDP_ENDIAN__ 3412
#define __DEC128_MIN_EXP__ (-6142)
#define __INT_FAST32_TYPE__ long int
#define __UINT_LEAST16_TYPE__ short unsigned int
#define unix 1
#define __SIZE_TYPE__ long unsigned int
#define __UINT64_MAX__ 0xffffffffffffffffUL
#define __FLT_IS_IEC_60559__ 2
#define __GNUC_WIDE_EXECUTION_CHARSET_NAME "UTF-32LE"
#define __FLT64X_DIG__ 18
#define __INT8_TYPE__ signed char
#define __ELF__ 1
#define __GCC_ASM_FLAG_OUTPUTS__ 1
#define __UINT32_TYPE__ unsigned int
#define __FLT_RADIX__ 2
#define __INT_LEAST16_TYPE__ short int
#define __LDBL_EPSILON__ 1.08420217248550443400745280086994171e-19L
#define __UINTMAX_C(c) c ## UL
#define __GNUC_RH_RELEASE__ 1
#define __SSE_MATH__ 1
#define __k8 1
#define __FLT32X_MIN__ 2.22507385850720138309023271733240406e-308F32x
#define __SIG_ATOMIC_MAX__ 0x7fffffff
#define __GCC_ATOMIC_WCHAR_T_LOCK_FREE 2
#define __USER_LABEL_PREFIX__
#define __STDC_IEC_60559_BFP__ 201404L
#define __SIZEOF_PTRDIFF_T__ 8
#define __LDBL_DIG__ 18
#define __FLT64_IS_IEC_60559__ 2
#define __x86_64__ 1
#define __FLT16_IS_IEC_60559__ 2
#define __FLT16_MAX_EXP__ 16
#define __DEC32_SUBNORMAL_MIN__ 0.000001E-95DF
#define __INT_FAST16_MAX__ 0x7fffffffffffffffL
#define __GCC_CONSTRUCTIVE_SIZE 64
#define __FLT64_DIG__ 15
#define __UINT_FAST32_MAX__ 0xffffffffffffffffUL
#define __UINT_LEAST64_TYPE__ long unsigned int
#define __FLT16_EPSILON__ 9.76562500000000000000000000000000000e-4F16
#define __FLT_HAS_QUIET_NAN__ 1
#define __FLT_MAX_10_EXP__ 38
#define __LONG_MAX__ 0x7fffffffffffffffL
#define __FLT64X_HAS_DENORM__ 1
#define __DEC128_SUBNORMAL_MIN__ 0.000000000000000000000000000000001E-6143DL
#define __FLT_HAS_INFINITY__ 1
#define __GNUC_EXECUTION_CHARSET_NAME "UTF-8"
#define __UINT_FAST16_TYPE__ long unsigned int
#define __DEC64_MAX__ 9.999999999999999E384DD
#define __INT_FAST32_WIDTH__ 64
#define __CHAR16_TYPE__ short unsigned int
#define __PRAGMA_REDEFINE_EXTNAME 1
#define __SIZE_WIDTH__ 64
#define __SEG_FS 1
#define __INT_LEAST16_MAX__ 0x7fff
#define __FLT16_NORM_MAX__ 6.55040000000000000000000000000000000e+4F16
#define __DEC64_MANT_DIG__ 16
#define __INT64_MAX__ 0x7fffffffffffffffL
#define __FLT32_DENORM_MIN__ 1.40129846432481707092372958328991613e-45F32
#define __SIG_ATOMIC_WIDTH__ 32
#define __INT_LEAST64_TYPE__ long int
#define __INT16_TYPE__ short int
#define __INT_LEAST8_TYPE__ signed char
#define __FLT16_MAX__ 6.55040000000000000000000000000000000e+4F16
#define __STDC_VERSION__ 201710L
#define __SIZEOF_INT__ 4
#define __DEC32_MAX_EXP__ 97
#define __INT_FAST8_MAX__ 0x7f
#define __FLT128_MAX__ 1.18973149535723176508575932662800702e+4932F128
#define __INTPTR_MAX__ 0x7fffffffffffffffL
#define linux 1
#define __FLT64_HAS_QUIET_NAN__ 1
#define __FLT32_MIN_10_EXP__ (-37)
#define __FLT32X_DIG__ 15
#define __PTRDIFF_WIDTH__ 64
#define __LDBL_MANT_DIG__ 64
#define __FLT64_HAS_INFINITY__ 1
#define __FLT64X_MAX__ 1.18973149535723176502126385303097021e+4932F64x
#define __FLT16_HAS_INFINITY__ 1
#define __SIG_ATOMIC_MIN__ (-__SIG_ATOMIC_MAX__ - 1)
#define __code_model_small__ 1
#define __GCC_ATOMIC_LONG_LOCK_FREE 2
#define __DEC32_MANT_DIG__ 7
#define __FLT16_MANT_DIG__ 11
#define __k8__ 1
#define __INTPTR_TYPE__ long int
#define __UINT16_TYPE__ short unsigned int
#define __WCHAR_TYPE__ int
#define __UINTPTR_MAX__ 0xffffffffffffffffUL
#define __INT_FAST64_WIDTH__ 64
#define __INT_FAST64_MAX__ 0x7fffffffffffffffL
#define __GCC_ATOMIC_TEST_AND_SET_TRUEVAL 1
#define __FLT_NORM_MAX__ 3.40282346638528859811704183484516925e+38F
#define __FLT32_HAS_INFINITY__ 1
#define __FLT64X_MAX_EXP__ 16384
#define __UINT_FAST64_TYPE__ long unsigned int
#define __INT_MAX__ 0x7fffffff
#define __linux__ 1
#define __INT64_TYPE__ long int
#define __FLT_MAX_EXP__ 128
#define __ORDER_BIG_ENDIAN__ 4321
#define __DBL_MANT_DIG__ 53
#define __SIZEOF_FLOAT128__ 16
#define __INT_LEAST64_MAX__ 0x7fffffffffffffffL
#define __GCC_ATOMIC_CHAR16_T_LOCK_FREE 2
#define __DEC64_MIN__ 1E-383DD
#define __WINT_TYPE__ unsigned int
#define __UINT_LEAST32_TYPE__ unsigned int
#define __SIZEOF_SHORT__ 2
#define __FLT32_NORM_MAX__ 3.40282346638528859811704183484516925e+38F32
#define __SSE__ 1
#define __LDBL_MIN_EXP__ (-16381)
#define __FLT64_MAX__ 1.79769313486231570814527423731704357e+308F64
#define __amd64__ 1
#define __WINT_WIDTH__ 32
#define __INT_LEAST8_MAX__ 0x7f
#define __INT_LEAST64_WIDTH__ 64
#define __LDBL_MAX_EXP__ 16384
#define __FLT32X_MAX_10_EXP__ 308
#define __SIZEOF_INT128__ 16
#define __FLT16_MIN__ 6.10351562500000000000000000000000000e-5F16
#define __FLT64X_IS_IEC_60559__ 2
#define __LDBL_MAX_10_EXP__ 4932
#define __ATOMIC_RELAXED 0
#define __DBL_EPSILON__ ((double)2.22044604925031308084726333618164062e-16L)
#define __FLT128_MIN__ 3.36210314311209350626267781732175260e-4932F128
#define _LP64 1
#define __UINT8_C(c) c
#define __FLT64_MAX_EXP__ 1024
#define __INT_LEAST32_TYPE__ int
#define __SIZEOF_WCHAR_T__ 4
#define __UINT64_TYPE__ long unsigned int
#define __GNUC_PATCHLEVEL__ 1
#define __FLT128_NORM_MAX__ 1.18973149535723176508575932662800702e+4932F128
#define __FLT64_NORM_MAX__ 1.79769313486231570814527423731704357e+308F64
#define __FLT128_HAS_QUIET_NAN__ 1
#define __INTMAX_MAX__ 0x7fffffffffffffffL
#define __INT_FAST8_TYPE__ signed char
#define __FLT64X_MIN__ 3.36210314311209350626267781732175260e-4932F64x
#define __GNUC_STDC_INLINE__ 1
#define __FLT64_HAS_DENORM__ 1
#define __FLT32_EPSILON__ 1.19209289550781250000000000000000000e-7F32
#define __FLT16_HAS_DENORM__ 1
#define __DBL_DECIMAL_DIG__ 17
#define __STDC_UTF_32__ 1
#define __INT_FAST8_WIDTH__ 8
#define __FXSR__ 1
#define __FLT32X_MAX__ 1.79769313486231570814527423731704357e+308F32x
#define __DBL_NORM_MAX__ ((double)1.79769313486231570814527423731704357e+308L)
#define __BYTE_ORDER__ __ORDER_LITTLE_ENDIAN__
#define __GCC_DESTRUCTIVE_SIZE 64
#define __INTMAX_WIDTH__ 64
#define __UINT32_C(c) c ## U
#define __FLT_DENORM_MIN__ 1.40129846432481707092372958328991613e-45F
#define __INT8_MAX__ 0x7f
#define __LONG_WIDTH__ 64
#define __UINT_FAST32_TYPE__ long unsigned int
#define __FLT32X_NORM_MAX__ 1.79769313486231570814527423731704357e+308F32x
#define __CHAR32_TYPE__ unsigned int
#define __FLT_MAX__ 3.40282346638528859811704183484516925e+38F
#define __SSE2__ 1
#define __INT32_TYPE__ int
#define __SIZEOF_DOUBLE__ 8
#define __FLT_MIN_10_EXP__ (-37)
#define __FLT64_MIN__ 2.22507385850720138309023271733240406e-308F64
#define __INT_LEAST32_WIDTH__ 32
#define __INTMAX_TYPE__ long int
#define __DEC128_MAX_EXP__ 6145
#define __FLT32X_HAS_QUIET_NAN__ 1
#define __ATOMIC_CONSUME 1
#define __GNUC_MINOR__ 2
#define __INT_FAST16_WIDTH__ 64
#define __UINTMAX_MAX__ 0xffffffffffffffffUL
#define __FLT32X_DENORM_MIN__ 4.94065645841246544176568792868221372e-324F32x
#define __DBL_MAX_10_EXP__ 308
#define __LDBL_DENORM_MIN__ 3.64519953188247460252840593361941982e-4951L
#define __INT16_C(c) c
#define __STDC__ 1
#define __PTRDIFF_TYPE__ long int
#define __ATOMIC_SEQ_CST 5
#define __FLT32X_MIN_10_EXP__ (-307)
#define __UINTPTR_TYPE__ long unsigned int
#define __DEC64_SUBNORMAL_MIN__ 0.000000000000001E-383DD
#define __DEC128_MANT_DIG__ 34
#define __LDBL_MIN_10_EXP__ (-4931)
#define __SIZEOF_LONG_LONG__ 8
#define __FLT128_DECIMAL_DIG__ 36
#define __GCC_ATOMIC_LLONG_LOCK_FREE 2
#define __FLT32_HAS_QUIET_NAN__ 1
#define __FLT_DECIMAL_DIG__ 9
#define __UINT_FAST16_MAX__ 0xffffffffffffffffUL
#define __LDBL_NORM_MAX__ 1.18973149535723176502126385303097021e+4932L
#define __GCC_ATOMIC_SHORT_LOCK_FREE 2
#define __UINT_FAST8_TYPE__ unsigned char
#define __ATOMIC_ACQ_REL 4
#define __ATOMIC_RELEASE 3
COMPILER_PATH=/usr/libexec/gcc/x86_64-redhat-linux/12/:/usr/libexec/gcc/x86_64-redhat-linux/12/:/usr/libexec/gcc/x86_64-redhat-linux/:/usr/lib/gcc/x86_64-redhat-linux/12/:/usr/lib/gcc/x86_64-redhat-linux/
LIBRARY_PATH=/usr/lib/gcc/x86_64-redhat-linux/12/:/usr/lib/gcc/x86_64-redhat-linux/12/../../../../lib64/:/lib/../lib64/:/usr/lib/../lib64/:/usr/lib/gcc/x86_64-redhat-linux/12/../../../:/lib/:/usr/lib/
COLLECT_GCC_OPTIONS='-E' '-v' '-dM' '-mtune=generic' '-march=x86-64'
Ah, I see, you have 1.0.0, which gets interpreted as number :-D (I had 1.0.3-dev which was not recognized as number)
Fixed.
😀 ah okay. Will test it right away.
@bwoebi That's what I'm currently getting.
[Warning] Skipping stdin, not found in object file
[Warning] Skipping stdout, not found in object file
[Warning] Skipping stderr, not found in object file
[Warning] Skipping remove, not found in object file
[Warning] Skipping rename, not found in object file
[Warning] Skipping renameat, not found in object file
[Warning] Skipping fclose, not found in object file
[Warning] Skipping tmpfile, not found in object file
[Warning] Skipping tmpnam, not found in object file
[Warning] Skipping tmpnam_r, not found in object file
[Warning] Skipping tempnam, not found in object file
[Warning] Skipping fflush, not found in object file
[Warning] Skipping fflush_unlocked, not found in object file
[Warning] Skipping fopen, not found in object file
[Warning] Skipping freopen, not found in object file
[Warning] Skipping fdopen, not found in object file
[Warning] Skipping fmemopen, not found in object file
[Warning] Skipping open_memstream, not found in object file
[Warning] Skipping setbuf, not found in object file
[Warning] Skipping setvbuf, not found in object file
[Warning] Skipping setbuffer, not found in object file
[Warning] Skipping setlinebuf, not found in object file
[Warning] Skipping fprintf, not found in object file
[Warning] Skipping printf, not found in object file
[Warning] Skipping sprintf, not found in object file
[Warning] Skipping vfprintf, not found in object file
[Warning] Skipping vprintf, not found in object file
[Warning] Skipping vsprintf, not found in object file
[Warning] Skipping vsnprintf, not found in object file
[Warning] Skipping vdprintf, not found in object file
[Warning] Skipping dprintf, not found in object file
[Warning] Skipping fscanf, not found in object file
[Warning] Skipping scanf, not found in object file
[Warning] Skipping sscanf, not found in object file
[Warning] Skipping fscanf, not found in object file
[Warning] Skipping scanf, not found in object file
[Warning] Skipping sscanf, not found in object file
[Warning] Skipping vfscanf, not found in object file
[Warning] Skipping vscanf, not found in object file
[Warning] Skipping vsscanf, not found in object file
[Warning] Skipping vfscanf, not found in object file
[Warning] Skipping vscanf, not found in object file
[Warning] Skipping vsscanf, not found in object file
[Warning] Skipping fgetc, not found in object file
[Warning] Skipping getc, not found in object file
[Warning] Skipping getchar, not found in object file
[Warning] Skipping getc_unlocked, not found in object file
[Warning] Skipping getchar_unlocked, not found in object file
[Warning] Skipping fgetc_unlocked, not found in object file
[Warning] Skipping fputc, not found in object file
[Warning] Skipping putc, not found in object file
[Warning] Skipping putchar, not found in object file
[Warning] Skipping fputc_unlocked, not found in object file
[Warning] Skipping putc_unlocked, not found in object file
[Warning] Skipping putchar_unlocked, not found in object file
[Warning] Skipping getw, not found in object file
[Warning] Skipping putw, not found in object file
[Warning] Skipping fgets, not found in object file
[Warning] Skipping gets, not found in object file
[Warning] Skipping __getdelim, not found in object file
[Warning] Skipping getdelim, not found in object file
[Warning] Skipping getline, not found in object file
[Warning] Skipping fputs, not found in object file
[Warning] Skipping puts, not found in object file
[Warning] Skipping ungetc, not found in object file
[Warning] Skipping fread, not found in object file
[Warning] Skipping fwrite, not found in object file
[Warning] Skipping fread_unlocked, not found in object file
[Warning] Skipping fwrite_unlocked, not found in object file
[Warning] Skipping fseek, not found in object file
[Warning] Skipping ftell, not found in object file
[Warning] Skipping rewind, not found in object file
[Warning] Skipping fseeko, not found in object file
[Warning] Skipping ftello, not found in object file
[Warning] Skipping fgetpos, not found in object file
[Warning] Skipping fsetpos, not found in object file
[Warning] Skipping clearerr, not found in object file
[Warning] Skipping feof, not found in object file
[Warning] Skipping ferror, not found in object file
[Warning] Skipping clearerr_unlocked, not found in object file
[Warning] Skipping feof_unlocked, not found in object file
[Warning] Skipping ferror_unlocked, not found in object file
[Warning] Skipping perror, not found in object file
[Warning] Skipping fileno, not found in object file
[Warning] Skipping fileno_unlocked, not found in object file
[Warning] Skipping pclose, not found in object file
[Warning] Skipping popen, not found in object file
[Warning] Skipping ctermid, not found in object file
[Warning] Skipping flockfile, not found in object file
[Warning] Skipping ftrylockfile, not found in object file
[Warning] Skipping funlockfile, not found in object file
[Warning] Skipping __uflow, not found in object file
[Warning] Skipping __overflow, not found in object file
[Warning] Skipping select, not found in object file
[Warning] Skipping pselect, not found in object file
[Warning] Skipping gettimeofday, not found in object file
[Warning] Skipping settimeofday, not found in object file
[Warning] Skipping adjtime, not found in object file
[Warning] Skipping getitimer, not found in object file
[Warning] Skipping setitimer, not found in object file
[Warning] Skipping utimes, not found in object file
[Warning] Skipping lutimes, not found in object file
[Warning] Skipping futimes, not found in object file
[Warning] __cfloat128 could not be compiled: _Complex float is not supported by ext/ffi
@bwoebi Any luck here?
I will check it out (yes, I can reproduce it), but given it's only warning, I wasn't looking at it with high priority.
@bwoebi yeah I understand, but its blocking the possibility of usage.
Thank you anyways.
@cayolblake I'm working on it - it needs recursively resolving all referenced shared libraries for all supported targets (ELF and MachO), which is a tiny bit bigger feature, please be a bit patient :-)
@bwoebi Yeah I understand :)
Having this feature, I'm planning to write a number of blog posts to promote FFIMe and showcase its usage and how far it goes into killing the barrier of entry for developing an extension for any native library 🚀
Will standby for whenever it's done to test 💪
@cayolblake I've just added recursive symbol resolution for shared objects. There should be a lot less warnings now.
Thanks @bwoebi
Will have it tested shortly and update you.
👍👍
@bwoebi just tested it after updating and getting the following output.
[Warning] Skipping stdin, not found in object file
[Warning] Skipping stdout, not found in object file
[Warning] Skipping stderr, not found in object file
[Warning] Skipping remove, not found in object file
[Warning] Skipping rename, not found in object file
[Warning] Skipping renameat, not found in object file
[Warning] Skipping fclose, not found in object file
[Warning] Skipping tmpfile, not found in object file
[Warning] Skipping tmpnam, not found in object file
[Warning] Skipping tmpnam_r, not found in object file
[Warning] Skipping tempnam, not found in object file
[Warning] Skipping fflush, not found in object file
[Warning] Skipping fflush_unlocked, not found in object file
[Warning] Skipping fopen, not found in object file
[Warning] Skipping freopen, not found in object file
[Warning] Skipping fdopen, not found in object file
[Warning] Skipping fmemopen, not found in object file
[Warning] Skipping open_memstream, not found in object file
[Warning] Skipping setbuf, not found in object file
[Warning] Skipping setvbuf, not found in object file
[Warning] Skipping setbuffer, not found in object file
[Warning] Skipping setlinebuf, not found in object file
[Warning] Skipping fprintf, not found in object file
[Warning] Skipping printf, not found in object file
[Warning] Skipping sprintf, not found in object file
[Warning] Skipping vfprintf, not found in object file
[Warning] Skipping vprintf, not found in object file
[Warning] Skipping vsprintf, not found in object file
[Warning] Skipping vsnprintf, not found in object file
[Warning] Skipping vdprintf, not found in object file
[Warning] Skipping dprintf, not found in object file
[Warning] Skipping fscanf, not found in object file
[Warning] Skipping scanf, not found in object file
[Warning] Skipping sscanf, not found in object file
[Warning] Skipping fscanf, not found in object file
[Warning] Skipping scanf, not found in object file
[Warning] Skipping sscanf, not found in object file
[Warning] Skipping vfscanf, not found in object file
[Warning] Skipping vscanf, not found in object file
[Warning] Skipping vsscanf, not found in object file
[Warning] Skipping vfscanf, not found in object file
[Warning] Skipping vscanf, not found in object file
[Warning] Skipping vsscanf, not found in object file
[Warning] Skipping fgetc, not found in object file
[Warning] Skipping getc, not found in object file
[Warning] Skipping getchar, not found in object file
[Warning] Skipping getc_unlocked, not found in object file
[Warning] Skipping getchar_unlocked, not found in object file
[Warning] Skipping fgetc_unlocked, not found in object file
[Warning] Skipping fputc, not found in object file
[Warning] Skipping putc, not found in object file
[Warning] Skipping putchar, not found in object file
[Warning] Skipping fputc_unlocked, not found in object file
[Warning] Skipping putc_unlocked, not found in object file
[Warning] Skipping putchar_unlocked, not found in object file
[Warning] Skipping getw, not found in object file
[Warning] Skipping putw, not found in object file
[Warning] Skipping fgets, not found in object file
[Warning] Skipping gets, not found in object file
[Warning] Skipping __getdelim, not found in object file
[Warning] Skipping getdelim, not found in object file
[Warning] Skipping getline, not found in object file
[Warning] Skipping fputs, not found in object file
[Warning] Skipping puts, not found in object file
[Warning] Skipping ungetc, not found in object file
[Warning] Skipping fread, not found in object file
[Warning] Skipping fwrite, not found in object file
[Warning] Skipping fread_unlocked, not found in object file
[Warning] Skipping fwrite_unlocked, not found in object file
[Warning] Skipping fseek, not found in object file
[Warning] Skipping ftell, not found in object file
[Warning] Skipping rewind, not found in object file
[Warning] Skipping fseeko, not found in object file
[Warning] Skipping ftello, not found in object file
[Warning] Skipping fgetpos, not found in object file
[Warning] Skipping fsetpos, not found in object file
[Warning] Skipping clearerr, not found in object file
[Warning] Skipping feof, not found in object file
[Warning] Skipping ferror, not found in object file
[Warning] Skipping clearerr_unlocked, not found in object file
[Warning] Skipping feof_unlocked, not found in object file
[Warning] Skipping ferror_unlocked, not found in object file
[Warning] Skipping perror, not found in object file
[Warning] Skipping fileno, not found in object file
[Warning] Skipping fileno_unlocked, not found in object file
[Warning] Skipping pclose, not found in object file
[Warning] Skipping popen, not found in object file
[Warning] Skipping ctermid, not found in object file
[Warning] Skipping flockfile, not found in object file
[Warning] Skipping ftrylockfile, not found in object file
[Warning] Skipping funlockfile, not found in object file
[Warning] Skipping __uflow, not found in object file
[Warning] Skipping __overflow, not found in object file
[Warning] Skipping select, not found in object file
[Warning] Skipping pselect, not found in object file
[Warning] Skipping gettimeofday, not found in object file
[Warning] Skipping settimeofday, not found in object file
[Warning] Skipping adjtime, not found in object file
[Warning] Skipping getitimer, not found in object file
[Warning] Skipping setitimer, not found in object file
[Warning] Skipping utimes, not found in object file
[Warning] Skipping lutimes, not found in object file
[Warning] Skipping futimes, not found in object file
[Warning] __cfloat128 could not be compiled: _Complex float is not supported by ext/ffi
@cayolblake What have you tested that on? I've tried with your hiredis reproducer, and it only gave me the very last line.
@bwoebi same hiredis code here.
I also verified I got the latest update. Tried in a new scratch project also same results.
Anyway to debug and generate you something useful?
Basically I would probably need debug information around https://github.com/ircmaxell/php-object-symbolresolver/blob/master/lib/ELF/ObjectFile.php#L78
Does it find all the self::getSharedSearchPaths()
? (see "shared library search path" section of your /usr/lib64/ld-linux-x86-64.so.2 --help
output (or where your dynamic linker resides)) Is it able to find libc in these paths?
Does it find libc in the dynamic section (i.e. $dependencies array)?
@bwoebi So, self::$sharedLibrarySearchDirectories
was hardcoded to /lib
, and /usr/lib
.
I changed that to /lib64
, and /usr/lib64
, which is basically what's on any RedHat/Fedora/openSUSE...etc. 64bit systems, and reran the reproducer code, and it worked! Only giving out the last warning line!!
Not sure why the hardcoding of things, however I guess this would definitely lead to multiple issues moving forward in many other systems/distros probably.
Is it possible to acquire such details in a dynamic way to avoid relying on pre-assumed paths or variables?
There is a bit hardcoding into the linker itself - /lib and /usr/lib are hardcoded on Ubuntu - for everything else I'm looking at /etc/ld.so.conf
, but possibly this is differently on your distro?
What's the output of cat /etc/ld.so.conf
(and if has includes, the included files, e.g. cat /etc/ld.so.conf.d/*
)?
@cayolblake But anyway, added it for now just as is: https://github.com/ircmaxell/php-object-symbolresolver/commit/778bf45448f901a97c9875eb912104a311283aea
There is a bit hardcoding into the linker itself - /lib and /usr/lib are hardcoded on Ubuntu - for everything else I'm looking at
/etc/ld.so.conf
, but possibly this is differently on your distro?What's the output of
cat /etc/ld.so.conf
(and if has includes, the included files, e.g.cat /etc/ld.so.conf.d/*
)?
Nothing in the file, and the dir as well is empty.
Thanks for the fix. I goes these covers most, if not all the possible standard locations.
May be think of exposing this as a config for anybody else wanna ping you special location? 🤔
I think that makes sense, added: https://github.com/ircmaxell/php-object-symbolresolver/commit/dfe1b1aa6c15b198bdef50fff8485e98e89f2a09.
I guess we can close this issue now, then?