mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-05 09:17:44 +03:00
Merge pull request #1882 from teg/networkd-dhcp6-fix
networkd: link - fix ipv6ll_gained() handling
This commit is contained in:
commit
a7e565d76a
@ -259,12 +259,12 @@ int sd_dhcp6_client_set_request_option(sd_dhcp6_client *client, uint16_t option)
|
|||||||
|
|
||||||
int sd_dhcp6_client_get_lease(sd_dhcp6_client *client, sd_dhcp6_lease **ret) {
|
int sd_dhcp6_client_get_lease(sd_dhcp6_client *client, sd_dhcp6_lease **ret) {
|
||||||
assert_return(client, -EINVAL);
|
assert_return(client, -EINVAL);
|
||||||
assert_return(ret, -EINVAL);
|
|
||||||
|
|
||||||
if (!client->lease)
|
if (!client->lease)
|
||||||
return -ENOMSG;
|
return -ENOMSG;
|
||||||
|
|
||||||
*ret = client->lease;
|
if (ret)
|
||||||
|
*ret = client->lease;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -131,7 +131,8 @@ static void dhcp6_handler(sd_dhcp6_client *client, int event, void *userdata) {
|
|||||||
case SD_DHCP6_CLIENT_EVENT_STOP:
|
case SD_DHCP6_CLIENT_EVENT_STOP:
|
||||||
case SD_DHCP6_CLIENT_EVENT_RESEND_EXPIRE:
|
case SD_DHCP6_CLIENT_EVENT_RESEND_EXPIRE:
|
||||||
case SD_DHCP6_CLIENT_EVENT_RETRANS_MAX:
|
case SD_DHCP6_CLIENT_EVENT_RETRANS_MAX:
|
||||||
log_link_warning(link, "DHCPv6 lease lost");
|
if (sd_dhcp6_client_get_lease(client, NULL) >= 0)
|
||||||
|
log_link_warning(link, "DHCPv6 lease lost");
|
||||||
|
|
||||||
link->dhcp6_configured = false;
|
link->dhcp6_configured = false;
|
||||||
break;
|
break;
|
||||||
|
@ -506,9 +506,6 @@ static int link_stop_clients(Link *link) {
|
|||||||
assert(link->manager);
|
assert(link->manager);
|
||||||
assert(link->manager->event);
|
assert(link->manager->event);
|
||||||
|
|
||||||
if (!link->network)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if (link->dhcp_client) {
|
if (link->dhcp_client) {
|
||||||
k = sd_dhcp_client_stop(link->dhcp_client);
|
k = sd_dhcp_client_stop(link->dhcp_client);
|
||||||
if (k < 0)
|
if (k < 0)
|
||||||
@ -2485,7 +2482,7 @@ int link_ipv6ll_gained(Link *link) {
|
|||||||
link->ipv6ll_address = true;
|
link->ipv6ll_address = true;
|
||||||
link_check_ready(link);
|
link_check_ready(link);
|
||||||
|
|
||||||
if (link->network) {
|
if (!IN_SET(link->state, LINK_STATE_PENDING, LINK_STATE_PENDING, LINK_STATE_UNMANAGED, LINK_STATE_FAILED)) {
|
||||||
r = link_acquire_ipv6_conf(link);
|
r = link_acquire_ipv6_conf(link);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
link_enter_failed(link);
|
link_enter_failed(link);
|
||||||
@ -2501,7 +2498,7 @@ static int link_carrier_gained(Link *link) {
|
|||||||
|
|
||||||
assert(link);
|
assert(link);
|
||||||
|
|
||||||
if (link->network) {
|
if (!IN_SET(link->state, LINK_STATE_PENDING, LINK_STATE_PENDING, LINK_STATE_UNMANAGED, LINK_STATE_FAILED)) {
|
||||||
r = link_acquire_conf(link);
|
r = link_acquire_conf(link);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
link_enter_failed(link);
|
link_enter_failed(link);
|
||||||
|
Loading…
Reference in New Issue
Block a user