From 92b2f1bd3d3aabbd03d11d5b3d50a99681b3b0f2 Mon Sep 17 00:00:00 2001 From: Xiang Xiao Date: Sat, 25 Feb 2023 16:02:11 +0800 Subject: [PATCH] fs: Undefine CONFIG_FS_LARGEFILE if compiler doesn't support long long to simplify the large file check in many place Signed-off-by: Xiang Xiao --- include/aio.h | 2 +- include/dirent.h | 2 +- include/fcntl.h | 2 +- include/ftw.h | 2 +- include/inttypes.h | 2 +- include/nuttx/compiler.h | 4 ++++ include/stdio.h | 2 +- include/stdlib.h | 2 +- include/sys/mman.h | 2 +- include/sys/resource.h | 4 ++-- include/sys/sendfile.h | 2 +- include/sys/stat.h | 2 +- include/sys/statfs.h | 2 +- include/sys/statvfs.h | 2 +- include/sys/types.h | 4 ++-- include/sys/uio.h | 2 +- include/unistd.h | 2 +- 17 files changed, 22 insertions(+), 18 deletions(-) diff --git a/include/aio.h b/include/aio.h index 60dab48827..f88cd29252 100644 --- a/include/aio.h +++ b/include/aio.h @@ -97,7 +97,7 @@ #define LIO_NOWAIT 0 #define LIO_WAIT 1 -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define aiocb64 aiocb # define aio_read64 aio_read # define aio_write64 aio_write diff --git a/include/dirent.h b/include/dirent.h index c2f936a3ad..2d9a478aef 100644 --- a/include/dirent.h +++ b/include/dirent.h @@ -86,7 +86,7 @@ #define DIRENT_ISLINK(dtype) ((dtype) == DTYPE_LINK) #define DIRENT_ISSOCK(dtype) ((dtype) == DTYPE_SOCK) -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define dirent64 dirent # define readdir64 readdir # define readdir64_r readdir_r diff --git a/include/fcntl.h b/include/fcntl.h index c0f8449e98..92cf0af7c5 100644 --- a/include/fcntl.h +++ b/include/fcntl.h @@ -148,7 +148,7 @@ #define creat(path, mode) open(path, O_WRONLY|O_CREAT|O_TRUNC, mode) -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define F_GETLK64 F_GETLK # define F_SETLK64 F_SETLK # define F_SETLKW64 F_SETLKW diff --git a/include/ftw.h b/include/ftw.h index 5a184cbd33..372c1112d7 100644 --- a/include/ftw.h +++ b/include/ftw.h @@ -63,7 +63,7 @@ * it. */ #endif -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define ftw64 ftw # define nftw64 nftw #endif diff --git a/include/inttypes.h b/include/inttypes.h index 7d15a1f390..056ad4ea62 100644 --- a/include/inttypes.h +++ b/include/inttypes.h @@ -308,7 +308,7 @@ /* off_t */ -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) #define PRIdOFF PRId64 #define PRIiOFF PRIi64 #define PRIoOFF PRIo64 diff --git a/include/nuttx/compiler.h b/include/nuttx/compiler.h index 33bc732150..6b39014b45 100644 --- a/include/nuttx/compiler.h +++ b/include/nuttx/compiler.h @@ -944,6 +944,10 @@ #endif +#ifndef CONFIG_HAVE_LONG_LONG +# undef CONFIG_FS_LARGEFILE +#endif + /**************************************************************************** * Public Function Prototypes ****************************************************************************/ diff --git a/include/stdio.h b/include/stdio.h index 268406f950..ebcfe1b430 100644 --- a/include/stdio.h +++ b/include/stdio.h @@ -87,7 +87,7 @@ #define TMP_MAX 56800235584ull -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define tmpfile64 tmpfile # define fopen64 fopen # define freopen64 freopen diff --git a/include/stdlib.h b/include/stdlib.h index 5e90eb5d08..0d98ee9785 100644 --- a/include/stdlib.h +++ b/include/stdlib.h @@ -68,7 +68,7 @@ # define environ get_environ_ptr() #endif -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define mkstemp64 mkstemp # define mkostemp64 mkostemp # define mkstemps64 mkstemps diff --git a/include/sys/mman.h b/include/sys/mman.h index 3bcdd907b4..d5b3c0393e 100644 --- a/include/sys/mman.h +++ b/include/sys/mman.h @@ -149,7 +149,7 @@ #define MFD_HUGE_2GB (31 << MFD_HUGE_SHIFT) #define MFD_HUGE_16GB (34 << MFD_HUGE_SHIFT) -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define mmap64 mmap #endif diff --git a/include/sys/resource.h b/include/sys/resource.h index 044c75aeff..0ce13783c4 100644 --- a/include/sys/resource.h +++ b/include/sys/resource.h @@ -58,7 +58,7 @@ #define RLIMIT_STACK 6 /* Limit on stack size */ #define RLIMIT_AS 7 /* Limit on address space size */ -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define RLIM_INFINITY UINT64_MAX /* No limit */ # define RLIM_SAVED_MAX UINT64_MAX /* Unrepresentable saved hard limit */ # define RLIM_SAVED_CUR UINT64_MAX /* Unrepresentable saved soft limit */ @@ -95,7 +95,7 @@ * It must be an unsigned integral type. */ -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) typedef uint64_t rlim_t; #else typedef uint32_t rlim_t; diff --git a/include/sys/sendfile.h b/include/sys/sendfile.h index c07b944cb4..0e56287868 100644 --- a/include/sys/sendfile.h +++ b/include/sys/sendfile.h @@ -39,7 +39,7 @@ # define CONFIG_SENDFILE_BUFSIZE 512 #endif -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define sendfile64 sendfile #endif diff --git a/include/sys/stat.h b/include/sys/stat.h index 7a11316cd6..74fc38d661 100644 --- a/include/sys/stat.h +++ b/include/sys/stat.h @@ -122,7 +122,7 @@ #define st_ctime st_ctim.tv_sec #define st_mtime st_mtim.tv_sec -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define stat64 stat # define fstat64 fstat # define lstat64 lstat diff --git a/include/sys/statfs.h b/include/sys/statfs.h index 1bb9bed657..5b6431a0a9 100644 --- a/include/sys/statfs.h +++ b/include/sys/statfs.h @@ -95,7 +95,7 @@ #define CROMFS_MAGIC 0x4d4f5243 #define RPMSGFS_MAGIC 0x54534f47 -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define statfs64 statfs # define fstatfs64 fstatfs #endif diff --git a/include/sys/statvfs.h b/include/sys/statvfs.h index 5787082879..c5ef93ca25 100644 --- a/include/sys/statvfs.h +++ b/include/sys/statvfs.h @@ -38,7 +38,7 @@ #define ST_RDONLY 0x0001 /* Mount read-only. */ #define ST_NOSUID 0x0002 /* Ignore suid and sgid bits. */ -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define statvfs64 statvfs # define fstatvfs64 fstatvfs #endif diff --git a/include/sys/types.h b/include/sys/types.h index d9dda31fca..5e35c4474b 100644 --- a/include/sys/types.h +++ b/include/sys/types.h @@ -83,7 +83,7 @@ #define SCHED_PRIORITY_MIN 1 #define SCHED_PRIORITY_IDLE 0 -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define fsblkcnt64_t fsblkcnt_t # define fsfilcnt64_t fsfilcnt_t # define blkcnt64_t blkcnt_t @@ -193,7 +193,7 @@ typedef int wint_t; typedef int wctype_t; -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) /* Large file versions */ typedef uint64_t fsblkcnt_t; diff --git a/include/sys/uio.h b/include/sys/uio.h index 4555d5e044..410c1483be 100644 --- a/include/sys/uio.h +++ b/include/sys/uio.h @@ -48,7 +48,7 @@ * Pre-processor Definitions ****************************************************************************/ -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define preadv64 preadv # define pwritev64 pwritev #endif diff --git a/include/unistd.h b/include/unistd.h index b2d4ec091e..c7b98e043d 100644 --- a/include/unistd.h +++ b/include/unistd.h @@ -265,7 +265,7 @@ #define optind (*(getoptindp())) #define optopt (*(getoptoptp())) -#if defined(CONFIG_FS_LARGEFILE) && defined(CONFIG_HAVE_LONG_LONG) +#if defined(CONFIG_FS_LARGEFILE) # define lseek64 lseek # define pread64 pread # define pwrite64 pwrite