diff options
author | Susant Sahani <susant@redhat.com> | 2017-02-23 23:28:12 +0530 |
---|---|---|
committer | Susant Sahani <susant@redhat.com> | 2017-02-24 15:42:59 +0530 |
commit | 85257f48bedfec3c0fa6907c87caceee18ed1c94 (patch) | |
tree | 262a8f7dc46c8c7e79fad7cab3310969786fbcd5 | |
parent | ecc0eab247da25a6767ccabd2162a4d03de6ee8c (diff) |
socket-util: introduce in_addr_is_multicast
This patch add support to test whether a internet
address is multicast or not.
-rw-r--r-- | src/basic/in-addr-util.c | 12 | ||||
-rw-r--r-- | src/basic/in-addr-util.h | 2 |
2 files changed, 14 insertions, 0 deletions
diff --git a/src/basic/in-addr-util.c b/src/basic/in-addr-util.c index 3b06cb00ad..3927df2955 100644 --- a/src/basic/in-addr-util.c +++ b/src/basic/in-addr-util.c @@ -66,6 +66,18 @@ int in_addr_is_link_local(int family, const union in_addr_union *u) { return -EAFNOSUPPORT; } +int in_addr_is_multicast(int family, const union in_addr_union *u) { + assert(u); + + if (family == AF_INET) + return IN_MULTICAST(be32toh(u->in.s_addr)); + + if (family == AF_INET6) + return IN6_IS_ADDR_MULTICAST(&u->in6); + + return -EAFNOSUPPORT; +} + bool in4_addr_is_localhost(const struct in_addr *a) { assert(a); diff --git a/src/basic/in-addr-util.h b/src/basic/in-addr-util.h index 64a812c322..51a5aa67e4 100644 --- a/src/basic/in-addr-util.h +++ b/src/basic/in-addr-util.h @@ -39,6 +39,8 @@ struct in_addr_data { bool in4_addr_is_null(const struct in_addr *a); int in_addr_is_null(int family, const union in_addr_union *u); +int in_addr_is_multicast(int family, const union in_addr_union *u); + bool in4_addr_is_link_local(const struct in_addr *a); int in_addr_is_link_local(int family, const union in_addr_union *u); |