X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flibsystemd-network%2Fsd-dhcp-server.c;h=ecdc15dff733c1789a7ede402948691941c6b197;hb=8de4a226c71ef43e652274b33b5d19211a44ac7b;hp=b1f2fa063f66ef12f57ae7649d98807afb5ff0ad;hpb=816e2e7af96886e4a43194042ef61ba9fec2c77d;p=elogind.git diff --git a/src/libsystemd-network/sd-dhcp-server.c b/src/libsystemd-network/sd-dhcp-server.c index b1f2fa063..ecdc15dff 100644 --- a/src/libsystemd-network/sd-dhcp-server.c +++ b/src/libsystemd-network/sd-dhcp-server.c @@ -58,6 +58,7 @@ int sd_dhcp_server_new(sd_dhcp_server **ret, int ifindex) { return -ENOMEM; server->n_ref = REFCNT_INIT; + server->fd_raw = -1; server->fd = -1; server->index = ifindex; @@ -106,6 +107,7 @@ int sd_dhcp_server_stop(sd_dhcp_server *server) { server->receive_message = sd_event_source_unref(server->receive_message); + server->fd_raw = safe_close(server->fd_raw); server->fd = safe_close(server->fd); log_dhcp_server(server, "STOPPED"); @@ -277,8 +279,17 @@ int sd_dhcp_server_start(sd_dhcp_server *server) { assert_return(server, -EINVAL); assert_return(server->event, -EINVAL); assert_return(!server->receive_message, -EBUSY); + assert_return(server->fd_raw == -1, -EBUSY); assert_return(server->fd == -1, -EBUSY); + r = socket(AF_PACKET, SOCK_DGRAM | SOCK_NONBLOCK, 0); + if (r < 0) { + r = -errno; + sd_dhcp_server_stop(server); + return r; + } + server->fd_raw = r; + r = dhcp_network_bind_udp_socket(INADDR_ANY, DHCP_PORT_SERVER); if (r < 0) { sd_dhcp_server_stop(server);