X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fodhcpd.git;a=blobdiff_plain;f=src%2Fdhcpv6.h;h=de815cf6494f40bc76e631551a6fef4de683f6b3;hp=b38ae829616f8bfff9547ce56ceb6c82e64bd4a6;hb=ff5020d9c0474c6a76ee30e499983a4d3a9f27b7;hpb=4e579c4b7dbdcce624a8f031ba2a192fdde691a6 diff --git a/src/dhcpv6.h b/src/dhcpv6.h index b38ae82..de815cf 100644 --- a/src/dhcpv6.h +++ b/src/dhcpv6.h @@ -76,6 +76,9 @@ #define DHCPV6_HOP_COUNT_LIMIT 32 +#define DHCPV6_REC_TIMEOUT 2000 /* msec */ +#define DHCPV6_REC_MAX_RC 8 + struct dhcpv6_client_header { uint8_t msg_type; uint8_t transaction_id[3]; @@ -139,17 +142,21 @@ struct dhcpv6_ia_addr { struct dhcpv6_assignment { struct list_head head; + struct interface *iface; + struct sockaddr_in6 peer; time_t valid_until; - time_t reconf_sent; + + struct uloop_timeout reconf_timer; + bool accept_reconf; int reconf_cnt; - char *hostname; uint8_t key[16]; + + char *hostname; uint32_t assigned; uint32_t iaid; uint8_t mac[6]; uint8_t length; // length == 128 -> IA_NA, length <= 64 -> IA_PD - bool accept_reconf; struct odhcpd_ipaddr *managed; ssize_t managed_size; @@ -190,4 +197,4 @@ void dhcpv6_enum_ia_addrs(struct interface *iface, struct dhcpv6_assignment *c, dhcpv6_binding_cb_handler_t func, void *arg); void dhcpv6_write_statefile(void); void dhcpv6_ia_preupdate(struct interface *iface); -void dhcpv6_ia_postupdate(struct interface *iface, time_t now); +void dhcpv6_ia_postupdate(struct interface *iface);