mirror of
https://github.com/systemd/systemd.git
synced 2025-01-25 10:04:04 +03:00
network: split netdev_create() into two
This commit is contained in:
parent
9aa2585e2f
commit
b4d6ae63ba
@ -542,17 +542,14 @@ static int netdev_create_message(NetDev *netdev, Link *link, sd_netlink_message
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int netdev_create(NetDev *netdev, Link *link, link_netlink_message_handler_t callback) {
|
static int independent_netdev_create(NetDev *netdev) {
|
||||||
_cleanup_(sd_netlink_message_unrefp) sd_netlink_message *m = NULL;
|
_cleanup_(sd_netlink_message_unrefp) sd_netlink_message *m = NULL;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
assert(netdev);
|
assert(netdev);
|
||||||
assert(!link || callback);
|
|
||||||
|
|
||||||
/* create netdev */
|
/* create netdev */
|
||||||
if (NETDEV_VTABLE(netdev)->create) {
|
if (NETDEV_VTABLE(netdev)->create) {
|
||||||
assert(!link);
|
|
||||||
|
|
||||||
r = NETDEV_VTABLE(netdev)->create(netdev);
|
r = NETDEV_VTABLE(netdev)->create(netdev);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
@ -563,65 +560,50 @@ static int netdev_create(NetDev *netdev, Link *link, link_netlink_message_handle
|
|||||||
|
|
||||||
r = sd_rtnl_message_new_link(netdev->manager->rtnl, &m, RTM_NEWLINK, 0);
|
r = sd_rtnl_message_new_link(netdev->manager->rtnl, &m, RTM_NEWLINK, 0);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_netdev_error_errno(netdev, r, "Could not allocate netlink message: %m");
|
return r;
|
||||||
|
|
||||||
r = netdev_create_message(netdev, link, m);
|
r = netdev_create_message(netdev, NULL, m);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_netdev_error_errno(netdev, r, "Could not create netlink message: %m");
|
return r;
|
||||||
|
|
||||||
if (link) {
|
r = netlink_call_async(netdev->manager->rtnl, NULL, m, netdev_create_handler,
|
||||||
r = netlink_call_async(netdev->manager->rtnl, NULL, m, callback,
|
netdev_destroy_callback, netdev);
|
||||||
link_netlink_destroy_callback, link);
|
if (r < 0)
|
||||||
if (r < 0)
|
return r;
|
||||||
return log_netdev_error_errno(netdev, r, "Could not send netlink message: %m");
|
|
||||||
|
|
||||||
link_ref(link);
|
netdev_ref(netdev);
|
||||||
} else {
|
|
||||||
r = netlink_call_async(netdev->manager->rtnl, NULL, m, netdev_create_handler,
|
|
||||||
netdev_destroy_callback, netdev);
|
|
||||||
if (r < 0)
|
|
||||||
return log_netdev_error_errno(netdev, r, "Could not send netlink message: %m");
|
|
||||||
|
|
||||||
netdev_ref(netdev);
|
|
||||||
}
|
|
||||||
|
|
||||||
netdev->state = NETDEV_STATE_CREATING;
|
netdev->state = NETDEV_STATE_CREATING;
|
||||||
|
|
||||||
log_netdev_debug(netdev, "Creating");
|
log_netdev_debug(netdev, "Creating");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int netdev_create_after_configured(NetDev *netdev, Link *link) {
|
static int stacked_netdev_create(NetDev *netdev, Link *link, link_netlink_message_handler_t callback) {
|
||||||
assert(netdev);
|
_cleanup_(sd_netlink_message_unrefp) sd_netlink_message *m = NULL;
|
||||||
assert(link);
|
|
||||||
assert(NETDEV_VTABLE(netdev)->create_after_configured);
|
|
||||||
|
|
||||||
return NETDEV_VTABLE(netdev)->create_after_configured(netdev, link);
|
|
||||||
}
|
|
||||||
|
|
||||||
int netdev_join(NetDev *netdev, Link *link, link_netlink_message_handler_t callback) {
|
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
assert(netdev);
|
assert(netdev);
|
||||||
assert(netdev->manager);
|
assert(netdev->manager);
|
||||||
assert(netdev->manager->rtnl);
|
assert(link);
|
||||||
|
assert(callback);
|
||||||
|
|
||||||
switch (netdev_get_create_type(netdev)) {
|
r = sd_rtnl_message_new_link(netdev->manager->rtnl, &m, RTM_NEWLINK, 0);
|
||||||
case NETDEV_CREATE_STACKED:
|
if (r < 0)
|
||||||
r = netdev_create(netdev, link, callback);
|
return r;
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
break;
|
r = netdev_create_message(netdev, link, m);
|
||||||
case NETDEV_CREATE_AFTER_CONFIGURED:
|
if (r < 0)
|
||||||
r = netdev_create_after_configured(netdev, link);
|
return r;
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
assert_not_reached();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
r = netlink_call_async(netdev->manager->rtnl, NULL, m, callback,
|
||||||
|
link_netlink_destroy_callback, link);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
link_ref(link);
|
||||||
|
|
||||||
|
netdev->state = NETDEV_STATE_CREATING;
|
||||||
|
log_netdev_debug(netdev, "Creating");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -655,21 +637,34 @@ static int netdev_is_ready_to_create(NetDev *netdev, Link *link) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int request_process_stacked_netdev(Request *req) {
|
int request_process_stacked_netdev(Request *req) {
|
||||||
|
NetDev *netdev;
|
||||||
|
Link *link;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
assert(req);
|
assert(req);
|
||||||
assert(req->link);
|
|
||||||
assert(req->type == REQUEST_TYPE_NETDEV_STACKED);
|
assert(req->type == REQUEST_TYPE_NETDEV_STACKED);
|
||||||
assert(req->netdev);
|
|
||||||
assert(req->netlink_handler);
|
assert(req->netlink_handler);
|
||||||
|
|
||||||
r = netdev_is_ready_to_create(req->netdev, req->link);
|
netdev = ASSERT_PTR(req->netdev);
|
||||||
|
link = ASSERT_PTR(req->link);
|
||||||
|
|
||||||
|
r = netdev_is_ready_to_create(netdev, link);
|
||||||
if (r <= 0)
|
if (r <= 0)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
r = netdev_join(req->netdev, req->link, req->netlink_handler);
|
switch (netdev_get_create_type(netdev)) {
|
||||||
|
case NETDEV_CREATE_STACKED:
|
||||||
|
r = stacked_netdev_create(netdev, link, req->netlink_handler);
|
||||||
|
break;
|
||||||
|
case NETDEV_CREATE_AFTER_CONFIGURED:
|
||||||
|
assert(NETDEV_VTABLE(netdev)->create_after_configured);
|
||||||
|
r = NETDEV_VTABLE(netdev)->create_after_configured(netdev, link);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
assert_not_reached();
|
||||||
|
}
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_link_error_errno(req->link, r, "Failed to create stacked netdev '%s': %m", req->netdev->ifname);
|
return log_netdev_warning_errno(netdev, r, "Failed to create netdev: %m");
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -762,24 +757,26 @@ int link_request_stacked_netdev(Link *link, NetDev *netdev) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int request_process_independent_netdev(Request *req) {
|
int request_process_independent_netdev(Request *req) {
|
||||||
|
NetDev *netdev;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
assert(req);
|
assert(req);
|
||||||
assert(req->type == REQUEST_TYPE_NETDEV_INDEPENDENT);
|
assert(req->type == REQUEST_TYPE_NETDEV_INDEPENDENT);
|
||||||
assert(req->netdev);
|
|
||||||
|
|
||||||
r = netdev_is_ready_to_create(req->netdev, NULL);
|
netdev = ASSERT_PTR(req->netdev);
|
||||||
|
|
||||||
|
r = netdev_is_ready_to_create(netdev, NULL);
|
||||||
if (r <= 0)
|
if (r <= 0)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
r = netdev_create(req->netdev, NULL, NULL);
|
r = independent_netdev_create(netdev);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return log_netdev_warning_errno(netdev, r, "Failed to create netdev: %m");
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int netdev_request(NetDev *netdev) {
|
static int netdev_request_to_create(NetDev *netdev) {
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
assert(netdev);
|
assert(netdev);
|
||||||
@ -791,12 +788,20 @@ static int netdev_request(NetDev *netdev) {
|
|||||||
r = netdev_is_ready_to_create(netdev, NULL);
|
r = netdev_is_ready_to_create(netdev, NULL);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
if (r > 0)
|
if (r > 0) {
|
||||||
/* If the netdev has no dependency, then create it now. */
|
/* If the netdev has no dependency, then create it now. */
|
||||||
return netdev_create(netdev, NULL, NULL);
|
r = independent_netdev_create(netdev);
|
||||||
|
if (r < 0)
|
||||||
|
return log_netdev_warning_errno(netdev, r, "Failed to create netdev: %m");
|
||||||
|
|
||||||
/* Otherwise, wait for the dependencies being resolved. */
|
} else {
|
||||||
return netdev_queue_request(netdev, NULL);
|
/* Otherwise, wait for the dependencies being resolved. */
|
||||||
|
r = netdev_queue_request(netdev, NULL);
|
||||||
|
if (r < 0)
|
||||||
|
return log_netdev_warning_errno(netdev, r, "Failed to request to create: %m");
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int netdev_load_one(Manager *manager, const char *filename) {
|
int netdev_load_one(Manager *manager, const char *filename) {
|
||||||
@ -909,9 +914,9 @@ int netdev_load_one(Manager *manager, const char *filename) {
|
|||||||
|
|
||||||
log_netdev_debug(netdev, "loaded %s", netdev_kind_to_string(netdev->kind));
|
log_netdev_debug(netdev, "loaded %s", netdev_kind_to_string(netdev->kind));
|
||||||
|
|
||||||
r = netdev_request(netdev);
|
r = netdev_request_to_create(netdev);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_netdev_warning_errno(netdev, r, "Failed to request to create: %m");
|
return r;
|
||||||
|
|
||||||
TAKE_PTR(netdev);
|
TAKE_PTR(netdev);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -213,7 +213,6 @@ int netdev_get(Manager *manager, const char *name, NetDev **ret);
|
|||||||
int netdev_set_ifindex(NetDev *netdev, sd_netlink_message *newlink);
|
int netdev_set_ifindex(NetDev *netdev, sd_netlink_message *newlink);
|
||||||
int netdev_generate_hw_addr(NetDev *netdev, Link *link, const char *name,
|
int netdev_generate_hw_addr(NetDev *netdev, Link *link, const char *name,
|
||||||
const struct hw_addr_data *hw_addr, struct hw_addr_data *ret);
|
const struct hw_addr_data *hw_addr, struct hw_addr_data *ret);
|
||||||
int netdev_join(NetDev *netdev, Link *link, link_netlink_message_handler_t cb);
|
|
||||||
|
|
||||||
int request_process_independent_netdev(Request *req);
|
int request_process_independent_netdev(Request *req);
|
||||||
int request_process_stacked_netdev(Request *req);
|
int request_process_stacked_netdev(Request *req);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user