{
#if XSTAT_IS_XSTAT64
# ifdef __NR_fstat64
+# ifdef __NR_fstat
/* 64-bit kABI outlier, e.g. sparc64. */
if (vers == _STAT_VER_KERNEL)
return INLINE_SYSCALL_CALL (fstat, fd, buf);
int r = INLINE_SYSCALL_CALL (fstat64, fd, &st64);
return r ?: __xstat32_conv (vers, &st64, (struct stat *) buf);
}
+# else
+ return INLINE_SYSCALL_CALL (fstat64, fd, buf);
+# endif
# elif defined __NR_fstat
/* 64-bit kABI, e.g. aarch64, ia64, powerpc64*, s390x, riscv64,
and x86_64. */
if (vers == _STAT_VER_KERNEL || vers == _STAT_VER_LINUX)
return INLINE_SYSCALL_CALL (newfstatat, fd, file, st, flag);
# elif defined __NR_fstatat64
+# ifdef __NR_fstat
/* 64-bit kABI outlier, e.g. sparc64. */
struct stat64 st64;
int r = INLINE_SYSCALL_CALL (fstatat64, fd, file, &st64, flag);
return r ?: __xstat32_conv (vers, &st64, (struct stat *) st);
+# else
+ if (vers == _STAT_VER_LINUX)
+ return INLINE_SYSCALL_CALL (fstatat64, fd, file, st, flag);
+# endif
# else
/* New 32-bit kABIs with only 64-bit time_t support, e.g. arc, riscv32. */
if (vers == _STAT_VER_KERNEL)