diff options
author | pelaufer <paul@laufernet.com> | 2023-09-01 18:34:26 +0200 |
---|---|---|
committer | pelaufer <paul@laufernet.com> | 2023-09-01 20:34:13 +0200 |
commit | 4502f82beb240066f6619a1471134e5264226217 (patch) | |
tree | 78583c5ebcc3acf26b2f0886419dcce2510b2061 /src/libsystemd-network/sd-dhcp-client.c | |
parent | Journal: Add message IDs for emergency-level log messages (diff) | |
download | systemd-4502f82beb240066f6619a1471134e5264226217.tar.xz systemd-4502f82beb240066f6619a1471134e5264226217.zip |
Adding client_set_state to sd-dhcp-client.c to support a client state change hook
Diffstat (limited to 'src/libsystemd-network/sd-dhcp-client.c')
-rw-r--r-- | src/libsystemd-network/sd-dhcp-client.c | 30 |
1 files changed, 19 insertions, 11 deletions
diff --git a/src/libsystemd-network/sd-dhcp-client.c b/src/libsystemd-network/sd-dhcp-client.c index 21b6592037..cbea55dd63 100644 --- a/src/libsystemd-network/sd-dhcp-client.c +++ b/src/libsystemd-network/sd-dhcp-client.c @@ -730,6 +730,15 @@ int sd_dhcp_client_set_fallback_lease_lifetime(sd_dhcp_client *client, uint32_t return 0; } +static void client_set_state(sd_dhcp_client *client, DHCPState state) { + assert(client); + + if (client->state == state) + return; + + client->state = state; +} + static int client_notify(sd_dhcp_client *client, int event) { assert(client); @@ -753,7 +762,7 @@ static int client_initialize(sd_dhcp_client *client) { client->attempt = 0; - client->state = DHCP_STATE_STOPPED; + client_set_state(client, DHCP_STATE_STOPPED); client->xid = 0; client->lease = sd_dhcp_lease_unref(client->lease); @@ -1307,7 +1316,7 @@ static int client_timeout_resend( case DHCP_STATE_INIT: r = client_send_discover(client); if (r >= 0) { - client->state = DHCP_STATE_SELECTING; + client_set_state(client, DHCP_STATE_SELECTING); client->attempt = 0; } else if (client->attempt >= client->max_attempts) goto error; @@ -1330,7 +1339,7 @@ static int client_timeout_resend( goto error; if (client->state == DHCP_STATE_INIT_REBOOT) - client->state = DHCP_STATE_REBOOTING; + client_set_state(client, DHCP_STATE_REBOOTING); client->request_sent = time_now; break; @@ -1479,7 +1488,7 @@ static int client_timeout_t2(sd_event_source *s, uint64_t usec, void *userdata) client->receive_message = sd_event_source_disable_unref(client->receive_message); client->fd = safe_close(client->fd); - client->state = DHCP_STATE_REBINDING; + client_set_state(client, DHCP_STATE_REBINDING); client->attempt = 0; r = dhcp_network_bind_raw_socket(client->ifindex, &client->link, client->xid, @@ -1500,9 +1509,9 @@ static int client_timeout_t1(sd_event_source *s, uint64_t usec, void *userdata) DHCP_CLIENT_DONT_DESTROY(client); if (client->lease) - client->state = DHCP_STATE_RENEWING; + client_set_state(client, DHCP_STATE_RENEWING); else if (client->state != DHCP_STATE_INIT) - client->state = DHCP_STATE_INIT_REBOOT; + client_set_state(client, DHCP_STATE_INIT_REBOOT); client->attempt = 0; return client_initialize_time_events(client); @@ -1782,7 +1791,7 @@ static int client_handle_message(sd_dhcp_client *client, DHCPMessage *message, i if (r < 0) goto error; - client->state = DHCP_STATE_REQUESTING; + client_set_state(client, DHCP_STATE_REQUESTING); client->attempt = 0; r = event_reset_time(client->event, &client->timeout_resend, @@ -1831,7 +1840,7 @@ static int client_handle_message(sd_dhcp_client *client, DHCPMessage *message, i client->receive_message = sd_event_source_disable_unref(client->receive_message); client->fd = safe_close(client->fd); - client->state = DHCP_STATE_BOUND; + client_set_state(client, DHCP_STATE_BOUND); client->attempt = 0; client->last_addr = client->lease->address; @@ -2047,7 +2056,7 @@ int sd_dhcp_client_send_renew(sd_dhcp_client *client) { client->start_delay = 0; client->attempt = 1; - client->state = DHCP_STATE_RENEWING; + client_set_state(client, DHCP_STATE_RENEWING); return client_initialize_time_events(client); } @@ -2083,7 +2092,7 @@ int sd_dhcp_client_start(sd_dhcp_client *client) { the client MAY issue a DHCPREQUEST to try to reclaim the current address. */ if (client->last_addr && !client->anonymize) - client->state = DHCP_STATE_INIT_REBOOT; + client_set_state(client, DHCP_STATE_INIT_REBOOT); r = client_start(client); if (r >= 0) @@ -2176,7 +2185,6 @@ int sd_dhcp_client_stop(sd_dhcp_client *client) { DHCP_CLIENT_DONT_DESTROY(client); client_stop(client, SD_DHCP_CLIENT_EVENT_STOP); - client->state = DHCP_STATE_STOPPED; return 0; } |