[libc-commits] [libc] f904c2a - [libc] Add `IN6_IS_ADDR_UNSPECIFIED` (#172311)
via libc-commits
libc-commits at lists.llvm.org
Thu Dec 18 07:06:57 PST 2025
Author: Connector Switch
Date: 2025-12-18T23:06:54+08:00
New Revision: f904c2ad59b6bdf4c52aeeee0910c23b2a42b328
URL: https://github.com/llvm/llvm-project/commit/f904c2ad59b6bdf4c52aeeee0910c23b2a42b328
DIFF: https://github.com/llvm/llvm-project/commit/f904c2ad59b6bdf4c52aeeee0910c23b2a42b328.diff
LOG: [libc] Add `IN6_IS_ADDR_UNSPECIFIED` (#172311)
This patch adds the `IN6_IS_ADDR_UNSPECIFIED` macro, which checks
whether an address is unspecified address.
Added:
Modified:
libc/include/llvm-libc-macros/netinet-in-macros.h
libc/test/include/netinet_in_test.cpp
Removed:
################################################################################
diff --git a/libc/include/llvm-libc-macros/netinet-in-macros.h b/libc/include/llvm-libc-macros/netinet-in-macros.h
index b04d6aa4b6781..f97a2dd0c3fda 100644
--- a/libc/include/llvm-libc-macros/netinet-in-macros.h
+++ b/libc/include/llvm-libc-macros/netinet-in-macros.h
@@ -38,6 +38,12 @@
// int and takes a single argument of type const struct in6_addr *:
// https://pubs.opengroup.org/onlinepubs/9799919799/basedefs/netinet_in.h.html
+#define IN6_IS_ADDR_UNSPECIFIED(a) \
+ ((__LLVM_LIBC_CAST(reinterpret_cast, uint32_t *, a)[0]) == 0 && \
+ (__LLVM_LIBC_CAST(reinterpret_cast, uint32_t *, a)[1]) == 0 && \
+ (__LLVM_LIBC_CAST(reinterpret_cast, uint32_t *, a)[2]) == 0 && \
+ (__LLVM_LIBC_CAST(reinterpret_cast, uint32_t *, a)[3]) == 0)
+
#define IN6_IS_ADDR_LINKLOCAL(a) \
((__LLVM_LIBC_CAST(reinterpret_cast, uint8_t *, a)[0]) == 0xfe && \
(__LLVM_LIBC_CAST(reinterpret_cast, uint8_t *, a)[1] & 0xc0) == 0x80)
diff --git a/libc/test/include/netinet_in_test.cpp b/libc/test/include/netinet_in_test.cpp
index 6937262f92e90..d70c780800858 100644
--- a/libc/test/include/netinet_in_test.cpp
+++ b/libc/test/include/netinet_in_test.cpp
@@ -12,6 +12,13 @@
TEST(LlvmLibcNetinetInTest, IN6Macro) {
char buff[16] = {};
+ EXPECT_TRUE(IN6_IS_ADDR_UNSPECIFIED(buff));
+ for (int i = 0; i < 16; ++i) {
+ buff[i] = 1;
+ EXPECT_FALSE(IN6_IS_ADDR_UNSPECIFIED(buff));
+ buff[i] = 0;
+ }
+
buff[0] = 0xfe;
buff[1] = 0x80;
EXPECT_TRUE(IN6_IS_ADDR_LINKLOCAL(buff));
More information about the libc-commits
mailing list