FFIMe icon indicating copy to clipboard operation
FFIMe copied to clipboard

Uncaught PHPCParser\Error: Syntax error, unexpected IDENTIFIER(int_least8_t)

Open cayolblake opened this issue 2 years ago • 25 comments

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;

cayolblake avatar Aug 23 '22 01:08 cayolblake

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 avatar Aug 23 '22 16:08 bwoebi

@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;

cayolblake avatar Aug 24 '22 12:08 cayolblake

@bwoebi also experienced the same attempting to use https://github.com/facebook/rocksdb/blob/main/include/rocksdb/c.h

cayolblake avatar Aug 25 '22 05:08 cayolblake

Sorry for the delay, yes, I can reproduce it and am looking into it.

bwoebi avatar Aug 26 '22 18:08 bwoebi

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 avatar Aug 26 '22 18:08 bwoebi

@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'

cayolblake avatar Aug 27 '22 12:08 cayolblake

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.

bwoebi avatar Aug 27 '22 17:08 bwoebi

😀 ah okay. Will test it right away.

cayolblake avatar Aug 27 '22 19:08 cayolblake

@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

cayolblake avatar Aug 28 '22 15:08 cayolblake

@bwoebi Any luck here?

cayolblake avatar Aug 31 '22 18:08 cayolblake

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 avatar Sep 01 '22 10:09 bwoebi

@bwoebi yeah I understand, but its blocking the possibility of usage.

Thank you anyways.

cayolblake avatar Sep 01 '22 17:09 cayolblake

@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 avatar Sep 03 '22 11:09 bwoebi

@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 avatar Sep 03 '22 12:09 cayolblake

@cayolblake I've just added recursive symbol resolution for shared objects. There should be a lot less warnings now.

bwoebi avatar Sep 07 '22 19:09 bwoebi

Thanks @bwoebi

Will have it tested shortly and update you.

👍👍

cayolblake avatar Sep 07 '22 20:09 cayolblake

@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 avatar Sep 07 '22 23:09 cayolblake

@cayolblake What have you tested that on? I've tried with your hiredis reproducer, and it only gave me the very last line.

bwoebi avatar Sep 12 '22 18:09 bwoebi

@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?

cayolblake avatar Sep 12 '22 21:09 cayolblake

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 avatar Sep 12 '22 23:09 bwoebi

@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?

cayolblake avatar Sep 13 '22 15:09 cayolblake

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/*)?

bwoebi avatar Sep 13 '22 17:09 bwoebi

@cayolblake But anyway, added it for now just as is: https://github.com/ircmaxell/php-object-symbolresolver/commit/778bf45448f901a97c9875eb912104a311283aea

bwoebi avatar Sep 14 '22 18:09 bwoebi

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.

cayolblake avatar Sep 14 '22 22:09 cayolblake

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? 🤔

cayolblake avatar Sep 14 '22 22:09 cayolblake

I think that makes sense, added: https://github.com/ircmaxell/php-object-symbolresolver/commit/dfe1b1aa6c15b198bdef50fff8485e98e89f2a09.

I guess we can close this issue now, then?

bwoebi avatar Sep 15 '22 18:09 bwoebi