X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fodhcpd.git;a=blobdiff_plain;f=src%2Fdhcpv6.h;h=09aa6f13eb77602fb677ee227419d659be372ec5;hp=936a350f89b10c2c7265e3a97b6cea05966677c3;hb=dc671c62730d9ff20e7cf06322fb8db203e7bf3f;hpb=2b4200f2510874a3ee9c09f594d5ab6340ffb336 diff --git a/src/dhcpv6.h b/src/dhcpv6.h index 936a350..09aa6f1 100644 --- a/src/dhcpv6.h +++ b/src/dhcpv6.h @@ -57,11 +57,7 @@ #define DHCPV6_OPT_INFO_REFRESH 32 #define DHCPV6_OPT_FQDN 39 #define DHCPV6_OPT_SOL_MAX_RT 82 - -#ifdef EXT_PREFIX_CLASS -/* draft-bhandari-dhc-class-based-prefix, not yet standardized */ -#define DHCPV6_OPT_PREFIX_CLASS EXT_PREFIX_CLASS -#endif +#define DHCPV6_OPT_INF_MAX_RT 83 #define DHCPV6_DUID_VENDOR 2 @@ -69,6 +65,7 @@ #define DHCPV6_STATUS_NOADDRSAVAIL 2 #define DHCPV6_STATUS_NOBINDING 3 #define DHCPV6_STATUS_NOTONLINK 4 +#define DHCPV6_STATUS_USEMULTICAST 5 #define DHCPV6_STATUS_NOPREFIXAVAIL 6 // I just remembered I have an old one lying around... @@ -144,9 +141,6 @@ struct dhcpv6_assignment { struct sockaddr_in6 peer; time_t valid_until; time_t reconf_sent; - bool all_class; - uint8_t classes_cnt; - uint16_t *classes; int reconf_cnt; char *hostname; uint8_t key[16]; @@ -164,6 +158,15 @@ struct dhcpv6_assignment { uint8_t clid_data[]; }; +struct dhcpv6_cer_id { + uint16_t type; + uint16_t len; + uint16_t reserved; + uint16_t auth_type; + uint8_t auth[16]; + struct in6_addr addr; +}; + #define dhcpv6_for_each_option(start, end, otype, olen, odata)\ @@ -173,7 +176,7 @@ struct dhcpv6_assignment { _o += 4 + (_o[2] << 8 | _o[3])) int dhcpv6_init_ia(struct interface *iface, int socket); -size_t dhcpv6_handle_ia(uint8_t *buf, size_t buflen, struct interface *iface, +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);