]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
migration/rdma: define htonll/ntohll only if not predefined
authorNick Briggs <nicholas.h.briggs@gmail.com>
Thu, 11 Jan 2024 18:20:17 +0000 (13:20 -0500)
committerMichael Tokarev <mjt@tls.msk.ru>
Sat, 20 Jan 2024 14:57:17 +0000 (17:57 +0300)
Solaris has #defines for htonll and ntohll which cause syntax errors
when compiling code that attempts to (re)define these functions..

Signed-off-by: Nick Briggs <nicholas.h.briggs@gmail.com>
Link: https://lore.kernel.org/r/65a04a7d.497ab3.3e7bef1f@gateway.sonic.net
Signed-off-by: Peter Xu <peterx@redhat.com>
(cherry picked from commit 44ce1b5d2fc77343f6a318cb3de613336a240048)
Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
migration/rdma.c

index ca430d319d9dd4ae8ff71b350fc0414d52a63981..8212fa6a5a3dc79620a2e8832d4834c8332a503c 100644 (file)
@@ -268,6 +268,7 @@ static const char *control_desc(unsigned int rdma_control)
     return strs[rdma_control];
 }
 
+#if !defined(htonll)
 static uint64_t htonll(uint64_t v)
 {
     union { uint32_t lv[2]; uint64_t llv; } u;
@@ -275,13 +276,16 @@ static uint64_t htonll(uint64_t v)
     u.lv[1] = htonl(v & 0xFFFFFFFFULL);
     return u.llv;
 }
+#endif
 
+#if !defined(ntohll)
 static uint64_t ntohll(uint64_t v)
 {
     union { uint32_t lv[2]; uint64_t llv; } u;
     u.llv = v;
     return ((uint64_t)ntohl(u.lv[0]) << 32) | (uint64_t) ntohl(u.lv[1]);
 }
+#endif
 
 static void dest_block_to_network(RDMADestBlock *db)
 {