Re: [PATCH 1/6] libsepol: use IN6ADDR_ANY_INIT to initialize IPv6 addresses

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 09/03/2017 08:19 AM, Nicolas Iooss wrote:
When compiling libsepol with clang and some warning flags, the compiler
complains about the way IPv6 addresses are initialized:

     kernel_to_cil.c:2795:35: error: suggest braces around initialization
     of subobject [-Werror,-Wmissing-braces]
             struct in6_addr subnet_prefix = {0};
                                              ^
                                              {}

When replacing the initializer as suggested, gcc 4.8.4 complains:

     kernel_to_cil.c: In function ‘write_selinux_ibpkey_rules_to_cil’:
     kernel_to_cil.c:2795:9: error: missing initializer for field
     ‘__in6_u’ of ‘struct in6_addr’ [-Werror=missing-field-initializers]
       struct in6_addr subnet_prefix = {};
              ^

Thankfully netinet/in.h provides a macro to initialize struct in6_addr
variables:

     #define IN6ADDR_ANY_INIT { { { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 } } }

Both clang and gcc no longer report warnings when using this macro.

Signed-off-by: Nicolas Iooss <nicolas.iooss@xxxxxxx>

This series has been applied.

Thanks,
Jim

---
  libsepol/src/kernel_to_cil.c  | 2 +-
  libsepol/src/kernel_to_conf.c | 2 +-
  libsepol/src/module_to_cil.c  | 2 +-
  3 files changed, 3 insertions(+), 3 deletions(-)

diff --git a/libsepol/src/kernel_to_cil.c b/libsepol/src/kernel_to_cil.c
index f1905a958ec0..0055c2386695 100644
--- a/libsepol/src/kernel_to_cil.c
+++ b/libsepol/src/kernel_to_cil.c
@@ -2788,7 +2788,7 @@ static int write_selinux_ibpkey_rules_to_cil(FILE *out, struct policydb *pdb)
  {
  	struct ocontext *ibpkeycon;
  	char subnet_prefix_str[INET6_ADDRSTRLEN];
-	struct in6_addr subnet_prefix = {0};
+	struct in6_addr subnet_prefix = IN6ADDR_ANY_INIT;
  	uint16_t low;
  	uint16_t high;
  	char low_high_str[44]; /* 2^64 <= 20 digits so "(low high)" <= 44 chars */
diff --git a/libsepol/src/kernel_to_conf.c b/libsepol/src/kernel_to_conf.c
index a74873f01687..95aa92fc8c26 100644
--- a/libsepol/src/kernel_to_conf.c
+++ b/libsepol/src/kernel_to_conf.c
@@ -2649,7 +2649,7 @@ static int write_selinux_ibpkey_rules_to_conf(FILE *out, struct policydb *pdb)
  {
  	struct ocontext *ibpkeycon;
  	char subnet_prefix_str[INET6_ADDRSTRLEN];
-	struct in6_addr subnet_prefix = {0};
+	struct in6_addr subnet_prefix = IN6ADDR_ANY_INIT;
  	uint16_t low;
  	uint16_t high;
  	char low_high_str[44]; /* 2^64 <= 20 digits so "low-high" <= 44 chars */
diff --git a/libsepol/src/module_to_cil.c b/libsepol/src/module_to_cil.c
index 619a48f8c7b6..15b58a7aacee 100644
--- a/libsepol/src/module_to_cil.c
+++ b/libsepol/src/module_to_cil.c
@@ -2687,7 +2687,7 @@ static int ocontext_selinux_ibpkey_to_cil(struct policydb *pdb,
  	int rc = -1;
  	struct ocontext *ibpkeycon;
  	char subnet_prefix_str[INET6_ADDRSTRLEN];
-	struct in6_addr subnet_prefix = {0};
+	struct in6_addr subnet_prefix = IN6ADDR_ANY_INIT;
  	uint16_t high;
  	uint16_t low;


--
James Carter <jwcart2@xxxxxxxxxxxxx>
National Security Agency



[Index of Archives]     [Selinux Refpolicy]     [Linux SGX]     [Fedora Users]     [Fedora Desktop]     [Yosemite Photos]     [Yosemite Camping]     [Yosemite Campsites]     [KDE Users]     [Gnome Users]

  Powered by Linux