From 15925720f1094a7c50d6406a9a3b84c7282273f8 Mon Sep 17 00:00:00 2001 From: "Huang weiliang(weller)" Date: Mon, 3 Jun 2024 22:37:54 +0000 Subject: [PATCH 1/2] Support platform QNX OS Compile with SDP7.1: ./configure --cc=aarch64-unknown-nto-qnx7.1.0-gcc --disable-shm make Function is verfied by UFS device read and write test. --- backend.c | 16 +++++++ client.c | 12 ++++++ configure | 6 +++ engines/e4defrag.c | 1 + init.c | 6 +++ memory.c | 4 ++ os/os-qnx.h | 103 +++++++++++++++++++++++++++++++++++++++++++++ os/os.h | 4 +- oslib/inet_aton.h | 4 +- server.c | 4 ++ 10 files changed, 158 insertions(+), 2 deletions(-) create mode 100755 os/os-qnx.h diff --git a/backend.c b/backend.c index fe03eab387..f6648dbf40 100644 --- a/backend.c +++ b/backend.c @@ -118,12 +118,20 @@ static void set_sig_handlers(void) memset(&act, 0, sizeof(act)); act.sa_handler = sig_int; + #if defined(__QNX__) + act.sa_flags = SA_NOCLDSTOP; + #else act.sa_flags = SA_RESTART; + #endif sigaction(SIGINT, &act, NULL); memset(&act, 0, sizeof(act)); act.sa_handler = sig_int; + #if defined(__QNX__) + act.sa_flags = SA_NOCLDSTOP; + #else act.sa_flags = SA_RESTART; + #endif sigaction(SIGTERM, &act, NULL); /* Windows uses SIGBREAK as a quit signal from other applications */ @@ -136,13 +144,21 @@ static void set_sig_handlers(void) memset(&act, 0, sizeof(act)); act.sa_handler = sig_show_status; + #if defined(__QNX__) + act.sa_flags = SA_NOCLDSTOP; + #else act.sa_flags = SA_RESTART; + #endif sigaction(SIGUSR1, &act, NULL); if (is_backend) { memset(&act, 0, sizeof(act)); act.sa_handler = sig_int; + #if defined(__QNX__) + act.sa_flags = SA_NOCLDSTOP; + #else act.sa_flags = SA_RESTART; + #endif sigaction(SIGPIPE, &act, NULL); } } diff --git a/client.c b/client.c index 4cb7dffede..227a875cbb 100644 --- a/client.c +++ b/client.c @@ -652,12 +652,20 @@ static void client_signal_handler(void) memset(&act, 0, sizeof(act)); act.sa_handler = sig_int; + #if defined(__QNX__) + act.sa_flags = SA_NOCLDSTOP; + #else act.sa_flags = SA_RESTART; + #endif sigaction(SIGINT, &act, NULL); memset(&act, 0, sizeof(act)); act.sa_handler = sig_int; + #if defined(__QNX__) + act.sa_flags = SA_NOCLDSTOP; + #else act.sa_flags = SA_RESTART; + #endif sigaction(SIGTERM, &act, NULL); /* Windows uses SIGBREAK as a quit signal from other applications */ @@ -670,7 +678,11 @@ static void client_signal_handler(void) memset(&act, 0, sizeof(act)); act.sa_handler = sig_show_status; + #if defined(__QNX__) + act.sa_flags = SA_NOCLDSTOP; + #else act.sa_flags = SA_RESTART; + #endif sigaction(SIGUSR1, &act, NULL); } diff --git a/configure b/configure index 3eef022b90..f3cb18a0c4 100755 --- a/configure +++ b/configure @@ -366,6 +366,8 @@ elif check_define __sun__ ; then CFLAGS="$CFLAGS -D_REENTRANT" elif check_define _WIN32 ; then targetos='CYGWIN' +elif check_define __QNX__ ; then + targetos='QNX' else targetos=`uname -s` fi @@ -466,6 +468,9 @@ CYGWIN*) pthread_condattr_setclock="no" pthread_affinity="no" ;; +QNX) + LIBS="-lsocket" + ;; esac # Now we know the target platform we can have another guess at the preferred @@ -1090,6 +1095,7 @@ if test "$have_vasprintf" != "yes" ; then fi cat > $TMPC << EOF #include +#include int main(int argc, char **argv) { diff --git a/engines/e4defrag.c b/engines/e4defrag.c index 37cc2ada81..65ef0da700 100644 --- a/engines/e4defrag.c +++ b/engines/e4defrag.c @@ -11,6 +11,7 @@ #include #include #include +#include #include "../fio.h" #include "../optgroup.h" diff --git a/init.c b/init.c index ff3e9a90d5..7961a41308 100644 --- a/init.c +++ b/init.c @@ -18,8 +18,14 @@ #include "fio.h" #ifndef FIO_NO_HAVE_SHM_H +#if defined(__QNX__) +#include +#else #include #endif +#endif + + #include "parse.h" #include "smalloc.h" diff --git a/memory.c b/memory.c index 2fdca65768..537456c82a 100644 --- a/memory.c +++ b/memory.c @@ -8,8 +8,12 @@ #include "fio.h" #ifndef FIO_NO_HAVE_SHM_H +#if defined(__QNX__) +#include +#else #include #endif +#endif void fio_unpin_memory(struct thread_data *td) { diff --git a/os/os-qnx.h b/os/os-qnx.h new file mode 100755 index 0000000000..3fa290d5b3 --- /dev/null +++ b/os/os-qnx.h @@ -0,0 +1,103 @@ +#ifndef FIO_OS_QNX_H +#define FIO_OS_QNX_H + +#define FIO_OS os_qnx +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +/* XXX hack to avoid conflicts between rbtree.h and */ +#undef RB_BLACK +#undef RB_RED +#undef RB_ROOT + +#include "../file.h" + +typedef uint64_t __u64; +typedef unsigned int __u32; + +#define FIO_USE_GENERIC_INIT_RANDOM_STATE +#define FIO_HAVE_FS_STAT +#define FIO_HAVE_GETTID + +#define OS_MAP_ANON MAP_ANON + +#ifndef PTHREAD_STACK_MIN +#define PTHREAD_STACK_MIN 4096 +#endif + +#define fio_swap16(x) swap16(x) +#define fio_swap32(x) swap32(x) +#define fio_swap64(x) swap64(x) + +#ifdef CONFIG_PTHREAD_GETAFFINITY +#define FIO_HAVE_GET_THREAD_AFFINITY +#define fio_get_thread_affinity(mask) \ + pthread_getaffinity_np(pthread_self(), sizeof(mask), &(mask)) +#endif + +static inline int blockdev_size(struct fio_file *f, unsigned long long *bytes) +{ + + struct stat statbuf, *pstat; + pstat = &statbuf; + if ( fstat(f->fd, pstat ) == -1 ) { + perror( "fstat" ); + } else { + *bytes = (unsigned long long)(pstat->st_blocksize * pstat->st_nblocks); + return 0; + } + + *bytes = 0; + return errno; +} + +static inline int blockdev_invalidate_cache(struct fio_file *f) +{ + return ENOTSUP; +} + +static inline unsigned long long os_phys_mem(void) +{ + int mib[2] = { CTL_HW, HW_PHYSMEM64 }; + uint64_t mem; + size_t len = sizeof(mem); + + sysctl(mib, 2, &mem, &len, NULL, 0); + return mem; +} + +#ifndef CONFIG_HAVE_GETTID +#error +static inline int gettid(void) +{ + return (int)(intptr_t) pthread_self(); +} +#endif + +static inline unsigned long long get_fs_free_size(const char *path) +{ + unsigned long long ret; + struct statvfs s; + + if (statvfs(path, &s) < 0) + return -1ULL; + + ret = s.f_frsize; + ret *= (unsigned long long) s.f_bfree; + return ret; +} + +#ifdef MADV_FREE +#define FIO_MADV_FREE MADV_FREE +#endif + +#endif diff --git a/os/os.h b/os/os.h index 0f1823240f..45c2f1e984 100644 --- a/os/os.h +++ b/os/os.h @@ -24,7 +24,7 @@ enum { os_windows, os_android, os_dragonfly, - + os_qnx, os_nr, }; @@ -39,6 +39,8 @@ typedef enum { #include "os-freebsd.h" #elif defined(__OpenBSD__) #include "os-openbsd.h" +#elif defined(__QNX__) +#include "os-qnx.h" #elif defined(__NetBSD__) #include "os-netbsd.h" #elif defined(__sun__) diff --git a/oslib/inet_aton.h b/oslib/inet_aton.h index c93c87f86f..4f3a48d22d 100644 --- a/oslib/inet_aton.h +++ b/oslib/inet_aton.h @@ -2,7 +2,9 @@ #define FIO_INET_ATON_LIB_H #include - +#if defined(__QNX__) +#include +#endif int inet_aton(const char *cp, struct in_addr *inp); #endif diff --git a/server.c b/server.c index afaeb3482b..32a1fbb85b 100644 --- a/server.c +++ b/server.c @@ -2742,7 +2742,11 @@ static void set_sig_handlers(void) { struct sigaction act = { .sa_handler = sig_int, + #if defined(__QNX__) + .sa_flags = SA_NOCLDSTOP, + #else .sa_flags = SA_RESTART, + #endif }; sigaction(SIGINT, &act, NULL); From aea6b3e98158072bbc9944e750169ab005d0e2c8 Mon Sep 17 00:00:00 2001 From: "Huang weiliang(weller)" Date: Mon, 3 Jun 2024 22:37:54 +0000 Subject: [PATCH 2/2] Support platform QNX OS Compile with QNX SDP7.1: ./configure --cc=aarch64-unknown-nto-qnx7.1.0-gcc --disable-shm make Function is verfied by UFS device read and write test. Signed-off-by: Huang weiliang(weller) --- init.c | 2 ++ os/os-qnx.h | 7 +++++++ 2 files changed, 9 insertions(+) diff --git a/init.c b/init.c index 7961a41308..41ebb0fd99 100644 --- a/init.c +++ b/init.c @@ -27,6 +27,8 @@ + + #include "parse.h" #include "smalloc.h" #include "filehash.h" diff --git a/os/os-qnx.h b/os/os-qnx.h index 3fa290d5b3..8c449257df 100755 --- a/os/os-qnx.h +++ b/os/os-qnx.h @@ -21,6 +21,13 @@ #include "../file.h" +/* QNX is not supporting SA_RESTART. Use SA_NOCLDSTOP instead of it */ +#ifndef SA_RESTART +#define SA_RESTART SA_NOCLDSTOP +#endif + +#define FIO_NO_HAVE_SHM_H + typedef uint64_t __u64; typedef unsigned int __u32;