From 4e895bb72e035c7c5034dd8beca7c8497413ad9e Mon Sep 17 00:00:00 2001 From: Ryo Nakamura Date: Mon, 12 Feb 2024 00:54:28 +0900 Subject: add htonll and ntohll --- src/platform.c | 3 +++ src/platform.h | 25 +++++++++++++++++++++++++ 2 files changed, 28 insertions(+) (limited to 'src') diff --git a/src/platform.c b/src/platform.c index aace709..96bbf68 100644 --- a/src/platform.c +++ b/src/platform.c @@ -22,6 +22,7 @@ #error unsupported platform #endif +#include #include #include #include @@ -163,3 +164,5 @@ int sem_release(sem_t *sem) } #endif + + diff --git a/src/platform.h b/src/platform.h index d47d620..f26e86c 100644 --- a/src/platform.h +++ b/src/platform.h @@ -4,6 +4,7 @@ #include #include +#include int nr_cpus(void); int set_thread_affinity(pthread_t tid, int core); @@ -20,4 +21,28 @@ int setutimes(const char *path, struct timespec atime, struct timespec mtime); sem_t *sem_create(int value); int sem_release(sem_t *sem); + +#ifdef HAVE_HTONLL +#include /* Apple has htonll and ntohll in arpa/inet.h */ +#endif + +/* copied from libssh: libssh/include/libssh/priv.h*/ +#ifndef HAVE_HTONLL +# ifdef WORDS_BIGENDIAN +# define htonll(x) (x) +# else +# define htonll(x) \ + (((uint64_t)htonl((x) & 0xFFFFFFFF) << 32) | htonl((x) >> 32)) +# endif +#endif + +#ifndef HAVE_NTOHLL +# ifdef WORDS_BIGENDIAN +# define ntohll(x) (x) +# else +# define ntohll(x) \ + (((uint64_t)ntohl((x) & 0xFFFFFFFF) << 32) | ntohl((x) >> 32)) +# endif +#endif + #endif /* _PLATFORM_H_ */ -- cgit v1.2.3