X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fodhcpd.git;a=blobdiff_plain;f=src%2Fdhcpv6.h;h=08dac6c7282558b080124b2b923f28677e687f24;hp=44ce1d71fdadeb0db73a35dee1cdb0ca7f389d69;hb=HEAD;hpb=837da652ea37cd2f8bbfb6a353057eb53e9b75e0 diff --git a/src/dhcpv6.h b/src/dhcpv6.h index 44ce1d7..08dac6c 100644 --- a/src/dhcpv6.h +++ b/src/dhcpv6.h @@ -14,6 +14,7 @@ #pragma once #include +#include "odhcpd.h" #define ALL_DHCPV6_RELAYS {{{0xff, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\ 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x02}}} @@ -59,11 +60,6 @@ #define DHCPV6_OPT_SOL_MAX_RT 82 #define DHCPV6_OPT_INF_MAX_RT 83 -#ifdef EXT_PREFIX_CLASS -/* draft-bhandari-dhc-class-based-prefix, not yet standardized */ -#define DHCPV6_OPT_PREFIX_CLASS EXT_PREFIX_CLASS -#endif - #define DHCPV6_DUID_VENDOR 2 #define DHCPV6_STATUS_OK 0 @@ -80,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]; @@ -143,25 +142,29 @@ 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; - bool all_class; - uint8_t classes_cnt; - uint16_t *classes; + + 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; struct ustream_fd managed_sock; + uint32_t leasetime; + unsigned int flags; + uint8_t clid_len; uint8_t clid_data[]; }; @@ -175,7 +178,9 @@ struct dhcpv6_cer_id { struct in6_addr addr; }; - +typedef void (*dhcpv6_binding_cb_handler_t)(struct in6_addr *addr, int prefix, + uint32_t pref, uint32_t valid, + void *arg); #define dhcpv6_for_each_option(start, end, otype, olen, odata)\ for (uint8_t *_o = (uint8_t*)(start); _o + 4 <= (end) &&\ @@ -187,5 +192,7 @@ int dhcpv6_init_ia(struct interface *iface, int socket); ssize_t dhcpv6_handle_ia(uint8_t *buf, size_t buflen, struct interface *iface, const struct sockaddr_in6 *addr, const void *data, const uint8_t *end); int dhcpv6_ia_init(void); -int setup_dhcpv6_ia_interface(struct interface *iface, bool enable); +int dhcpv6_setup_ia_interface(struct interface *iface, bool enable); +void dhcpv6_enum_ia_addrs(struct interface *iface, struct dhcpv6_assignment *c, time_t now, + dhcpv6_binding_cb_handler_t func, void *arg); void dhcpv6_write_statefile(void);