assert_return(lease, -EINVAL);
assert_return(addr, -EINVAL);
- if (!lease->have_broadcast)
+ if (lease->broadcast == INADDR_ANY)
return -ENODATA;
addr->s_addr = lease->broadcast;
assert_return(lease, -EINVAL);
assert_return(addr, -EINVAL);
- if (!lease->have_subnet_mask)
+ if (lease->subnet_mask == INADDR_ANY)
return -ENODATA;
addr->s_addr = lease->subnet_mask;
r = lease_parse_be32(option, len, &lease->subnet_mask);
if (r < 0)
log_debug_errno(r, "Failed to parse subnet mask, ignoring: %m");
- else
- lease->have_subnet_mask = true;
break;
case SD_DHCP_OPTION_BROADCAST:
r = lease_parse_be32(option, len, &lease->broadcast);
if (r < 0)
log_debug_errno(r, "Failed to parse broadcast address, ignoring: %m");
- else
- lease->have_broadcast = true;
break;
case SD_DHCP_OPTION_ROUTER:
r = inet_pton(AF_INET, netmask, &lease->subnet_mask);
if (r <= 0)
log_debug("Failed to parse netmask %s, ignoring.", netmask);
- else
- lease->have_subnet_mask = true;
}
if (server_address) {
r = inet_pton(AF_INET, broadcast, &lease->broadcast);
if (r <= 0)
log_debug("Failed to parse broadcast address %s, ignoring.", broadcast);
- else
- lease->have_broadcast = true;
}
if (dns) {
assert(lease);
- if (lease->have_subnet_mask)
+ if (lease->subnet_mask != INADDR_ANY)
return 0;
if (lease->address == 0)
return r;
lease->subnet_mask = mask.s_addr;
- lease->have_subnet_mask = true;
return 0;
}