]> git.ipfire.org Git - thirdparty/haproxy.git/commitdiff
BUILD: quic_sock: address a strict-aliasing build warning with gcc 5 and 6
authorWilly Tarreau <w@1wt.eu>
Wed, 2 Apr 2025 14:07:31 +0000 (16:07 +0200)
committerWilly Tarreau <w@1wt.eu>
Wed, 2 Apr 2025 14:07:31 +0000 (16:07 +0200)
The UDP GSO code emits a build warning with older toolchains (gcc 5 and 6):

  src/quic_sock.c: In function 'cmsg_set_gso':
  src/quic_sock.c:683:2: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing]
    *((uint16_t *)CMSG_DATA(c)) = gso_size;
    ^

Let's just use the write_u16() function that's made for this purpose.
It was verified that for all versions from 5 to 13, gcc produces the
exact same code with the fix (and without the warning). It arrived in
3.1 with commit 448d3d388a ("MINOR: quic: add GSO parameter on quic_sock
send API") so this can be backported there.

src/quic_sock.c

index b7ee8f8f48d7a5ed61f8851eb4764013658b50b7..1da0743f18fb4243b043de7f5bbf91e2d05c6240 100644 (file)
@@ -680,7 +680,7 @@ static void cmsg_set_gso(struct msghdr *msg, struct cmsghdr **cmsg,
        c->cmsg_level = SOL_UDP;
        c->cmsg_type = UDP_SEGMENT;
        c->cmsg_len = CMSG_LEN(sz);
-       *((uint16_t *)CMSG_DATA(c)) = gso_size;
+       write_u16(CMSG_DATA(c), gso_size);
 #endif
 }