LIST_HEAD_INIT(network->static_addresses);
LIST_HEAD_INIT(network->static_routes);
+ network->vlans = hashmap_new(uint64_hash_func, uint64_compare_func);
+ if (!network->vlans)
+ return log_oom();
+
network->addresses_by_section = hashmap_new(uint64_hash_func, uint64_compare_func);
if (!network->addresses_by_section)
return log_oom();
address_free(network->dns);
+ hashmap_free(network->vlans);
+
while ((route = network->static_routes))
route_free(route);
void *data,
void *userdata) {
Network *network = userdata;
- Netdev *netdev;
+ NetDev *netdev;
int r;
assert(filename);
if (netdev->kind != NETDEV_KIND_BRIDGE) {
log_syntax(unit, LOG_ERR, filename, line, EINVAL,
- "Netdev is not a bridge, ignoring assignment: %s", rvalue);
+ "NetDev is not a bridge, ignoring assignment: %s", rvalue);
return 0;
}
void *data,
void *userdata) {
Network *network = userdata;
- Netdev *netdev;
+ NetDev *netdev;
int r;
assert(filename);
if (netdev->kind != NETDEV_KIND_BOND) {
log_syntax(unit, LOG_ERR, filename, line, EINVAL,
- "Netdev is not a bond, ignoring assignment: %s", rvalue);
+ "NetDev is not a bond, ignoring assignment: %s", rvalue);
return 0;
}
void *data,
void *userdata) {
Network *network = userdata;
- Netdev *netdev;
+ NetDev *netdev;
int r;
assert(filename);
if (netdev->kind != NETDEV_KIND_VLAN) {
log_syntax(unit, LOG_ERR, filename, line, EINVAL,
- "Netdev is not a VLAN, ignoring assignment: %s", rvalue);
+ "NetDev is not a VLAN, ignoring assignment: %s", rvalue);
return 0;
}
- network->vlan = netdev;
+ r = hashmap_put(network->vlans, &netdev->vlanid, netdev);
+ if (r < 0) {
+ log_syntax(unit, LOG_ERR, filename, line, EINVAL,
+ "Can not add VLAN to network: %s", rvalue);
+ return 0;
+ }
return 0;
}