2
0
mirror of https://gitlab.isc.org/isc-projects/dhcp synced 2025-09-02 07:15:44 +00:00

Merged IA_XXrelated structures

This commit is contained in:
Francis Dupont
2008-03-17 15:35:37 +00:00
parent bd72740e3c
commit 9322442f8a
8 changed files with 618 additions and 1879 deletions

View File

@@ -71,6 +71,8 @@ work on other platforms. Please report any problems and suggested fixes to
- Prefix pools are attached to shared network scopes.
- Merged IA_XX related structures.
Changes since 4.0.0 (new features)
- Added DHCPv6 rapid commit support.

View File

@@ -813,7 +813,6 @@ struct shared_network {
struct ipv6_pool **ipv6_pools; /* NULL-terminated array */
int last_ipv6_pool; /* offset of last IPv6 pool
used to issue a lease */
struct ipv6_ppool **ipv6_ppools; /* NULL-terminated array */
struct group *group;
#if defined (FAILOVER_PROTOCOL)
dhcp_failover_state_t *failover_peer;
@@ -1334,19 +1333,22 @@ typedef unsigned char option_mask [16];
#define MIN_TIME 0
/* these are referenced */
typedef struct hash_table ia_na_hash_t;
typedef struct hash_table ia_hash_t;
typedef struct hash_table iaaddr_hash_t;
/* should be lease6 */
/* shared with iaprefix */
struct iaaddr {
int refcnt; /* reference count */
struct in6_addr addr; /* IPv6 address */
u_int8_t plen; /* unused/placeholder */
struct in6_addr addr; /* IPv6 address/prefix */
u_int8_t plen; /* iaprefix prefix length */
binding_state_t state; /* state */
struct binding_scope *scope; /* "set var = value;" */
time_t hard_lifetime_end_time; /* time address expires */
time_t soft_lifetime_end_time; /* time ephemeral expires */
struct ia_na *ia_na; /* IA for this address */
struct ipv6_pool *ipv6_pool; /* pool for this address */
struct ia_xx *ia; /* IA for this lease */
struct ipv6_pool *ipv6_pool; /* pool for this lease */
/*
* For now, just pick an arbitrary time to keep old hard leases
* around (value in seconds).
@@ -1357,23 +1359,25 @@ struct iaaddr {
(internal use only) */
};
struct ia_na {
struct ia_xx {
int refcnt; /* reference count */
struct data_string iaid_duid; /* from the client */
u_int16_t ia_type; /* IA_NA or IA_TA */
int num_iaaddr; /* number of IAADDR for this IA_NA */
u_int16_t ia_type; /* IA_XX */
int num_iaaddr; /* number of IAADDR for this IA */
int max_iaaddr; /* space available for IAADDR */
struct iaaddr **iaaddr; /* pointers to the various IAADDRs */
};
extern ia_na_hash_t *ia_na_active;
extern ia_na_hash_t *ia_ta_active;
extern ia_hash_t *ia_na_active;
extern ia_hash_t *ia_ta_active;
extern ia_hash_t *ia_pd_active;
struct ipv6_pool {
int refcnt; /* reference count */
u_int16_t pool_type; /* IA_xx */
struct in6_addr start_addr; /* first IPv6 address */
#define POOL_IS_FOR_TEMP 0x8000
int bits; /* number of bits, CIDR style */
int units; /* allocation unit in bits */
iaaddr_hash_t *addrs; /* non-free IAADDR */
int num_active; /* count of active IAADDR */
isc_heap_t *active_timeouts; /* timeouts for active leases */
@@ -1387,54 +1391,6 @@ struct ipv6_pool {
extern struct ipv6_pool **pools;
extern int num_pools;
/* Sames thing for IA_PDs */
typedef struct hash_table ia_pd_hash_t;
typedef struct hash_table iaprefix_hash_t;
struct iaprefix {
/* Must keep the same layout than iaaddr */
int refcnt; /* reference count */
struct in6_addr pref; /* IPv6 prefix */
u_int8_t plen; /* prefix length */
binding_state_t state; /* state */
struct binding_scope *scope; /* "set var = value;" */
time_t hard_lifetime_end_time; /* time prefix expires */
time_t soft_lifetime_end_time; /* time ephemeral expires */
struct ia_pd *ia_pd; /* IA for this prefix */
struct ipv6_ppool *ipv6_ppool; /* pool for this prefix */
int heap_index; /* index into heap, or -1
(internal use only) */
};
struct ia_pd {
int refcnt; /* reference count */
struct data_string iaid_duid; /* from the client */
int num_iaprefix; /* number of IAPREFIX for this IA_PD */
int max_iaprefix; /* space available for IAPREFIX */
struct iaprefix **iaprefix; /* pointers to the various IAPREFIXs */
};
extern ia_pd_hash_t *ia_pd_active;
struct ipv6_ppool {
int refcnt; /* reference count */
struct in6_addr start_pref; /* first IPv6 prefix */
u_int8_t pool_plen; /* pool prefix length */
u_int8_t alloc_plen; /* allocation prefix length */
iaprefix_hash_t *prefs; /* non-free IAPREFIX */
int num_active; /* count of active IAPREFIX */
isc_heap_t *active_timeouts; /* timeouts for active leases */
int num_inactive; /* count of inactive IAADDR */
isc_heap_t *inactive_timeouts; /* timeouts for expired or
released leases */
struct shared_network *shared_network; /* shared_network for
this pool */
};
extern struct ipv6_ppool **ppools;
extern int num_ppools;
/* External definitions... */
HASH_FUNCTIONS_DECL (group, const char *, struct group_object, group_hash_t)
@@ -2590,8 +2546,7 @@ int commit_leases PROTO ((void));
void db_startup PROTO ((int));
int new_lease_file PROTO ((void));
int group_writer (struct group_object *);
int write_ia(const struct ia_na *);
int write_ia_pd(const struct ia_pd *);
int write_ia(const struct ia_xx *);
/* packet.c */
u_int32_t checksum PROTO ((unsigned char *, unsigned, u_int32_t));
@@ -3240,7 +3195,7 @@ isc_result_t dhcp_failover_process_update_request_all (dhcp_failover_state_t *,
failover_message_t *);
isc_result_t dhcp_failover_process_update_done (dhcp_failover_state_t *,
failover_message_t *);
void ia_na_remove_all_iaaddr(struct ia_na *ia_na, const char *file, int line);
void ia_remove_all_iaaddr(struct ia_xx *ia, const char *file, int line);
void dhcp_failover_recover_done (void *);
void failover_print PROTO ((char *, unsigned *, unsigned, const char *));
void update_partner PROTO ((struct lease *));
@@ -3268,11 +3223,8 @@ const char *binding_state_print (enum failover_state);
/* mdb6.c */
HASH_FUNCTIONS_DECL(ia_na, unsigned char *, struct ia_na, ia_na_hash_t);
HASH_FUNCTIONS_DECL(ia_pd, unsigned char *, struct ia_pd, ia_pd_hash_t);
HASH_FUNCTIONS_DECL(ia, unsigned char *, struct ia_xx, ia_hash_t);
HASH_FUNCTIONS_DECL(iaaddr, struct in6_addr *, struct iaaddr, iaaddr_hash_t);
HASH_FUNCTIONS_DECL(iaprefix, struct in6_addr *,
struct iaprefix, iaaddr_hash_t);
isc_result_t iaaddr_allocate(struct iaaddr **iaaddr,
const char *file, int line);
@@ -3281,60 +3233,31 @@ isc_result_t iaaddr_reference(struct iaaddr **iaaddr, struct iaaddr *src,
isc_result_t iaaddr_dereference(struct iaaddr **iaaddr,
const char *file, int line);
isc_result_t iaprefix_allocate(struct iaprefix **iaprefix,
const char *file, int line);
isc_result_t iaprefix_reference(struct iaprefix **iaprefix,
struct iaprefix *src,
const char *file, int line);
isc_result_t iaprefix_dereference(struct iaprefix **iaprefix,
const char *file, int line);
isc_result_t ia_make_key(struct data_string *key, u_int32_t iaid,
const char *duid, unsigned int duid_len,
const char *file, int line);
isc_result_t ia_na_allocate(struct ia_na **ia_na, u_int32_t iaid,
isc_result_t ia_allocate(struct ia_xx **ia, u_int32_t iaid,
const char *duid, unsigned int duid_len,
const char *file, int line);
isc_result_t ia_na_reference(struct ia_na **ia_na, struct ia_na *src,
isc_result_t ia_reference(struct ia_xx **ia, struct ia_xx *src,
const char *file, int line);
isc_result_t ia_na_dereference(struct ia_na **ia_na,
isc_result_t ia_dereference(struct ia_xx **ia,
const char *file, int line);
isc_result_t ia_na_add_iaaddr(struct ia_na *ia_na, struct iaaddr *iaaddr,
isc_result_t ia_add_iaaddr(struct ia_xx *ia, struct iaaddr *iaaddr,
const char *file, int line);
void ia_na_remove_iaaddr(struct ia_na *ia_na, struct iaaddr *iaaddr,
void ia_remove_iaaddr(struct ia_xx *ia, struct iaaddr *iaaddr,
const char *file, int line);
isc_boolean_t ia_na_equal(const struct ia_na *a, const struct ia_na *b);
isc_boolean_t ia_equal(const struct ia_xx *a, const struct ia_xx *b);
isc_result_t ia_pd_allocate(struct ia_pd **ia_pd, u_int32_t iaid,
const char *duid, unsigned int duid_len,
const char *file, int line);
isc_result_t ia_pd_reference(struct ia_pd **ia_pd, struct ia_pd *src,
const char *file, int line);
isc_result_t ia_pd_dereference(struct ia_pd **ia_pd,
const char *file, int line);
isc_result_t ia_pd_add_iaprefix(struct ia_pd *ia_pd, struct iaprefix *iaprefix,
const char *file, int line);
void ia_pd_remove_iaprefix(struct ia_pd *ia_pd, struct iaprefix *iaprefix,
const char *file, int line);
isc_boolean_t ia_pd_equal(const struct ia_pd *a, const struct ia_pd *b);
isc_result_t ipv6_pool_allocate(struct ipv6_pool **pool,
const struct in6_addr *start_addr, int bits,
isc_result_t ipv6_pool_allocate(struct ipv6_pool **pool, u_int16_t type,
const struct in6_addr *start_addr,
int bits, int units,
const char *file, int line);
isc_result_t ipv6_pool_reference(struct ipv6_pool **pool,
struct ipv6_pool *src,
const char *file, int line);
isc_result_t ipv6_pool_dereference(struct ipv6_pool **pool,
const char *file, int line);
isc_result_t ipv6_ppool_allocate(struct ipv6_ppool **ppool,
const struct in6_addr *start_pref,
u_int8_t pool_plen, u_int8_t alloc_plen,
const char *file, int line);
isc_result_t ipv6_ppool_reference(struct ipv6_ppool **ppool,
struct ipv6_ppool *src,
const char *file, int line);
isc_result_t ipv6_ppool_dereference(struct ipv6_ppool **ppool,
const char *file, int line);
isc_result_t create_lease6(struct ipv6_pool *pool,
struct iaaddr **addr,
unsigned int *attempts,
@@ -3350,46 +3273,29 @@ isc_result_t release_lease6(struct ipv6_pool *pool, struct iaaddr *addr);
isc_result_t decline_lease6(struct ipv6_pool *pool, struct iaaddr *addr);
isc_boolean_t lease6_exists(const struct ipv6_pool *pool,
const struct in6_addr *addr);
isc_result_t mark_address_unavailble(struct ipv6_pool *pool,
isc_result_t mark_lease_unavailble(struct ipv6_pool *pool,
const struct in6_addr *addr);
isc_result_t create_prefix6(struct ipv6_ppool *ppool,
struct iaprefix **pref,
isc_result_t create_prefix6(struct ipv6_pool *pool,
struct iaaddr **pref,
unsigned int *attempts,
const struct data_string *uid,
time_t soft_lifetime_end_time);
isc_result_t add_prefix6(struct ipv6_ppool *ppool,
struct iaprefix *pref,
time_t valid_lifetime_end_time);
isc_result_t renew_prefix6(struct ipv6_ppool *ppool, struct iaprefix *pref);
isc_result_t expire_prefix6(struct iaprefix **pref,
struct ipv6_ppool *ppool, time_t now);
isc_result_t release_prefix6(struct ipv6_ppool *ppool, struct iaprefix *pref);
isc_boolean_t prefix6_exists(const struct ipv6_ppool *ppool,
isc_boolean_t prefix6_exists(const struct ipv6_pool *pool,
const struct in6_addr *pref, u_int8_t plen);
isc_result_t add_ipv6_pool(struct ipv6_pool *pool);
isc_result_t find_ipv6_pool(struct ipv6_pool **pool, int temp,
isc_result_t find_ipv6_pool(struct ipv6_pool **pool, u_int16_t type,
const struct in6_addr *addr);
isc_boolean_t ipv6_addr_in_pool(const struct in6_addr *addr,
isc_boolean_t ipv6_in_pool(const struct in6_addr *addr,
const struct ipv6_pool *pool);
isc_result_t add_ipv6_ppool(struct ipv6_ppool *ppool);
isc_result_t find_ipv6_ppool(struct ipv6_ppool **pool,
const struct in6_addr *pref);
isc_boolean_t ipv6_prefix_in_ppool(const struct in6_addr *pref,
const struct ipv6_ppool *ppool);
isc_result_t renew_leases(struct ia_na *ia_na);
isc_result_t release_leases(struct ia_na *ia_na);
isc_result_t decline_leases(struct ia_na *ia_na);
isc_result_t renew_leases(struct ia_xx *ia);
isc_result_t release_leases(struct ia_xx *ia);
isc_result_t decline_leases(struct ia_xx *ia);
void schedule_lease_timeout(struct ipv6_pool *pool);
void schedule_all_ipv6_lease_timeouts();
isc_result_t renew_prefixes(struct ia_pd *ia_pd);
isc_result_t release_prefixes(struct ia_pd *ia_pd);
void schedule_prefix_timeout(struct ipv6_ppool *ppool);
void schedule_all_ipv6_prefix_timeouts();
void mark_hosts_unavailable(void);
void mark_phosts_unavailable(void);
void mark_interfaces_unavailable(void);

View File

@@ -590,12 +590,12 @@ int parse_statement (cfile, group, type, host_decl, declaration)
case POOL:
next_token (&val, (unsigned *)0, cfile);
if (type != SUBNET_DECL && type != SHARED_NET_DECL) {
parse_warn (cfile, "pool declared outside of network");
skip_to_semi(cfile);
} else if (type == POOL_DECL) {
if (type == POOL_DECL) {
parse_warn (cfile, "pool declared within pool.");
skip_to_semi(cfile);
} else if (type != SUBNET_DECL && type != SHARED_NET_DECL) {
parse_warn (cfile, "pool declared outside of network");
skip_to_semi(cfile);
} else
parse_pool_statement (cfile, group, type);
@@ -629,7 +629,7 @@ int parse_statement (cfile, group, type, host_decl, declaration)
next_token(NULL, NULL, cfile);
if ((type != SUBNET_DECL) || (group->subnet == NULL)) {
parse_warn (cfile,
"prefix6 definitions may not be scoped.");
"prefix6 declaration not allowed here.");
skip_to_semi(cfile);
return declaration;
}
@@ -3637,8 +3637,10 @@ void parse_address_range (cfile, group, type, inpool, lpchain)
#ifdef DHCPv6
static void
add_ipv6_pool_to_shared_network(struct shared_network *share,
u_int16_t type,
struct iaddr *lo_addr,
int bits) {
int bits,
int units) {
struct ipv6_pool *pool;
struct in6_addr tmp_in6_addr;
int num_pools;
@@ -3653,8 +3655,8 @@ add_ipv6_pool_to_shared_network(struct shared_network *share,
}
memcpy(&tmp_in6_addr, lo_addr->iabuf, sizeof(tmp_in6_addr));
pool = NULL;
if (ipv6_pool_allocate(&pool, &tmp_in6_addr,
bits, MDL) != ISC_R_SUCCESS) {
if (ipv6_pool_allocate(&pool, type, &tmp_in6_addr,
bits, units, MDL) != ISC_R_SUCCESS) {
log_fatal("Out of memory");
}
@@ -3765,7 +3767,8 @@ parse_address_range6(struct parse *cfile, struct group *group) {
return;
}
add_ipv6_pool_to_shared_network(share, &lo, bits);
add_ipv6_pool_to_shared_network(share, D6O_IA_NA, &lo,
bits, 128);
} else if (token == TEMPORARY) {
/*
@@ -3778,9 +3781,9 @@ parse_address_range6(struct parse *cfile, struct group *group) {
skip_to_semi(cfile);
return;
}
bits |= POOL_IS_FOR_TEMP;
add_ipv6_pool_to_shared_network(share, &lo, bits);
add_ipv6_pool_to_shared_network(share, D6O_IA_TA, &lo,
bits, 128);
} else {
/*
* No '/', so we are looking for the end address of
@@ -3799,9 +3802,9 @@ parse_address_range6(struct parse *cfile, struct group *group) {
}
for (p=nets; p != NULL; p=p->next) {
add_ipv6_pool_to_shared_network(share,
add_ipv6_pool_to_shared_network(share, D6O_IA_NA,
&p->cidrnet.lo_addr,
p->cidrnet.bits);
p->cidrnet.bits, 128);
}
free_iaddrcidrnetlist(&nets);
@@ -3816,75 +3819,6 @@ parse_address_range6(struct parse *cfile, struct group *group) {
}
}
static void
add_ipv6_ppool_to_shared_network(struct shared_network *share,
struct iaddr *start_addr,
int pool_bits,
int alloc_bits) {
struct ipv6_ppool *ppool;
struct in6_addr tmp_in6_addr;
int num_ppools;
struct ipv6_ppool **tmp;
/*
* Create our prefix pool.
*/
if (start_addr->len != sizeof(tmp_in6_addr)) {
log_fatal("Internal error: Attempt to add non-IPv6 prefix.");
}
memcpy(&tmp_in6_addr, start_addr->iabuf, sizeof(tmp_in6_addr));
ppool = NULL;
if (ipv6_ppool_allocate(&ppool, &tmp_in6_addr,
(u_int8_t) pool_bits, (u_int8_t) alloc_bits,
MDL) != ISC_R_SUCCESS) {
log_fatal("Out of memory");
}
/*
* Add to our IPv6 prefix pool set.
*/
if (add_ipv6_ppool(ppool) != ISC_R_SUCCESS) {
log_fatal ("Out of memory");
}
/*
* Link our prefix pool to our shared_network.
*/
ppool->shared_network = NULL;
shared_network_reference(&ppool->shared_network, share, MDL);
/*
* Increase our array size for ipv6_ppools in the shared_network.
*/
if (share->ipv6_ppools == NULL) {
num_ppools = 0;
} else {
num_ppools = 0;
while (share->ipv6_ppools[num_ppools] != NULL) {
num_ppools++;
}
}
tmp = dmalloc(sizeof(struct ipv6_ppool *) * (num_ppools + 2), MDL);
if (tmp == NULL) {
log_fatal("Out of memory");
}
if (num_ppools > 0) {
memcpy(tmp, share->ipv6_ppools,
sizeof(struct ipv6_ppool *) * num_ppools);
}
if (share->ipv6_ppools != NULL) {
dfree(share->ipv6_ppools, MDL);
}
share->ipv6_ppools = tmp;
/*
* Record this prefix pool in our array of prefix pools
* for this shared network.
*/
ipv6_ppool_reference(&share->ipv6_ppools[num_ppools], ppool, MDL);
share->ipv6_ppools[num_ppools+1] = NULL;
}
/* prefix6-declaration :== ip-address6 ip-address6 SLASH number SEMI */
void
@@ -3973,7 +3907,7 @@ parse_prefix6(struct parse *cfile, struct group *group) {
parse_warn(cfile, "impossible mask length");
continue;
}
add_ipv6_ppool_to_shared_network(share,
add_ipv6_pool_to_shared_network(share, D6O_IA_PD,
&p->cidrnet.lo_addr,
p->cidrnet.bits, bits);
}
@@ -4141,9 +4075,9 @@ parse_ia_na_declaration(struct parse *cfile) {
skip_to_semi(cfile);
#else /* defined(DHCPv6) */
enum dhcp_token token;
struct ia_na *ia;
struct ia_xx *ia;
const char *val;
struct ia_na *old_ia;
struct ia_xx *old_ia;
unsigned int len;
u_int32_t iaid;
struct iaddr iaddr;
@@ -4179,7 +4113,7 @@ parse_ia_na_declaration(struct parse *cfile) {
memcpy(&iaid, val, 4);
ia = NULL;
if (ia_na_allocate(&ia, iaid, val+4, len-4, MDL) != ISC_R_SUCCESS) {
if (ia_allocate(&ia, iaid, val+4, len-4, MDL) != ISC_R_SUCCESS) {
log_fatal("Out of memory.");
}
ia->ia_type = D6O_IA_NA;
@@ -4379,6 +4313,7 @@ parse_ia_na_declaration(struct parse *cfile) {
log_fatal("Out of memory.");
}
memcpy(&iaaddr->addr, iaddr.iabuf, sizeof(iaaddr->addr));
iaaddr->plen = 0;
iaaddr->state = state;
if (iaaddr->state == FTS_RELEASED)
iaaddr->hard_lifetime_end_time = end_time;
@@ -4389,10 +4324,11 @@ parse_ia_na_declaration(struct parse *cfile) {
}
/* add to our various structures */
ia_na_add_iaaddr(ia, iaaddr, MDL);
ia_na_reference(&iaaddr->ia_na, ia, MDL);
ia_add_iaaddr(ia, iaaddr, MDL);
ia_reference(&iaaddr->ia, ia, MDL);
pool = NULL;
if (find_ipv6_pool(&pool, 0, &iaaddr->addr) != ISC_R_SUCCESS) {
if (find_ipv6_pool(&pool, D6O_IA_NA,
&iaaddr->addr) != ISC_R_SUCCESS) {
inet_ntop(AF_INET6, &iaaddr->addr,
addr_buf, sizeof(addr_buf));
parse_warn(cfile, "no pool found for address %s",
@@ -4408,24 +4344,24 @@ parse_ia_na_declaration(struct parse *cfile) {
* If we have an existing record for this IA_NA, remove it.
*/
old_ia = NULL;
if (ia_na_hash_lookup(&old_ia, ia_na_active,
if (ia_hash_lookup(&old_ia, ia_na_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, MDL)) {
ia_na_hash_delete(ia_na_active,
ia_hash_delete(ia_na_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, MDL);
ia_na_dereference(&old_ia, MDL);
ia_dereference(&old_ia, MDL);
}
/*
* If we have addresses, add this, otherwise don't bother.
*/
if (ia->num_iaaddr > 0) {
ia_na_hash_add(ia_na_active,
ia_hash_add(ia_na_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, ia, MDL);
}
ia_na_dereference(&ia, MDL);
ia_dereference(&ia, MDL);
#endif /* defined(DHCPv6) */
}
@@ -4436,9 +4372,9 @@ parse_ia_ta_declaration(struct parse *cfile) {
skip_to_semi(cfile);
#else /* defined(DHCPv6) */
enum dhcp_token token;
struct ia_na *ia;
struct ia_xx *ia;
const char *val;
struct ia_na *old_ia;
struct ia_xx *old_ia;
unsigned int len;
u_int32_t iaid;
struct iaddr iaddr;
@@ -4474,7 +4410,7 @@ parse_ia_ta_declaration(struct parse *cfile) {
memcpy(&iaid, val, 4);
ia = NULL;
if (ia_na_allocate(&ia, iaid, val+4, len-4, MDL) != ISC_R_SUCCESS) {
if (ia_allocate(&ia, iaid, val+4, len-4, MDL) != ISC_R_SUCCESS) {
log_fatal("Out of memory.");
}
ia->ia_type = D6O_IA_TA;
@@ -4674,6 +4610,7 @@ parse_ia_ta_declaration(struct parse *cfile) {
log_fatal("Out of memory.");
}
memcpy(&iaaddr->addr, iaddr.iabuf, sizeof(iaaddr->addr));
iaaddr->plen = 0;
iaaddr->state = state;
if (iaaddr->state == FTS_RELEASED)
iaaddr->hard_lifetime_end_time = end_time;
@@ -4684,10 +4621,11 @@ parse_ia_ta_declaration(struct parse *cfile) {
}
/* add to our various structures */
ia_na_add_iaaddr(ia, iaaddr, MDL);
ia_na_reference(&iaaddr->ia_na, ia, MDL);
ia_add_iaaddr(ia, iaaddr, MDL);
ia_reference(&iaaddr->ia, ia, MDL);
pool = NULL;
if (find_ipv6_pool(&pool, 1, &iaaddr->addr) != ISC_R_SUCCESS) {
if (find_ipv6_pool(&pool, D6O_IA_TA,
&iaaddr->addr) != ISC_R_SUCCESS) {
inet_ntop(AF_INET6, &iaaddr->addr,
addr_buf, sizeof(addr_buf));
parse_warn(cfile, "no pool found for address %s",
@@ -4703,24 +4641,24 @@ parse_ia_ta_declaration(struct parse *cfile) {
* If we have an existing record for this IA_TA, remove it.
*/
old_ia = NULL;
if (ia_na_hash_lookup(&old_ia, ia_ta_active,
if (ia_hash_lookup(&old_ia, ia_ta_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, MDL)) {
ia_na_hash_delete(ia_ta_active,
ia_hash_delete(ia_ta_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, MDL);
ia_na_dereference(&old_ia, MDL);
ia_dereference(&old_ia, MDL);
}
/*
* If we have addresses, add this, otherwise don't bother.
*/
if (ia->num_iaaddr > 0) {
ia_na_hash_add(ia_ta_active,
ia_hash_add(ia_ta_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, ia, MDL);
}
ia_na_dereference(&ia, MDL);
ia_dereference(&ia, MDL);
#endif /* defined(DHCPv6) */
}
@@ -4731,17 +4669,17 @@ parse_ia_pd_declaration(struct parse *cfile) {
skip_to_semi(cfile);
#else /* defined(DHCPv6) */
enum dhcp_token token;
struct ia_pd *ia_pd;
struct ia_xx *ia;
const char *val;
struct ia_pd *old_ia_pd;
struct ia_xx *old_ia;
unsigned int len;
u_int32_t iaid;
struct iaddr iaddr;
u_int8_t plen;
binding_state_t state;
TIME end_time;
struct iaprefix *iapref;
struct ipv6_ppool *ppool;
struct iaaddr *iapref;
struct ipv6_pool *pool;
char addr_buf[sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255")];
isc_boolean_t newbinding;
struct binding_scope *scope=NULL;
@@ -4769,10 +4707,11 @@ parse_ia_pd_declaration(struct parse *cfile) {
}
memcpy(&iaid, val, 4);
ia_pd = NULL;
if (ia_pd_allocate(&ia_pd, iaid, val+4, len-4, MDL) != ISC_R_SUCCESS) {
ia = NULL;
if (ia_allocate(&ia, iaid, val+4, len-4, MDL) != ISC_R_SUCCESS) {
log_fatal("Out of memory.");
}
ia->ia_type = D6O_IA_PD;
token = next_token(&val, NULL, cfile);
if (token != LBRACE) {
@@ -4965,10 +4904,10 @@ parse_ia_pd_declaration(struct parse *cfile) {
}
iapref = NULL;
if (iaprefix_allocate(&iapref, MDL) != ISC_R_SUCCESS) {
if (iaaddr_allocate(&iapref, MDL) != ISC_R_SUCCESS) {
log_fatal("Out of memory.");
}
memcpy(&iapref->pref, iaddr.iabuf, sizeof(iapref->pref));
memcpy(&iapref->addr, iaddr.iabuf, sizeof(iapref->addr));
iapref->plen = plen;
iapref->state = state;
if (iapref->state == FTS_RELEASED)
@@ -4980,43 +4919,44 @@ parse_ia_pd_declaration(struct parse *cfile) {
}
/* add to our various structures */
ia_pd_add_iaprefix(ia_pd, iapref, MDL);
ia_pd_reference(&iapref->ia_pd, ia_pd, MDL);
ppool = NULL;
if (find_ipv6_ppool(&ppool, &iapref->pref) != ISC_R_SUCCESS) {
inet_ntop(AF_INET6, &iapref->pref,
ia_add_iaaddr(ia, iapref, MDL);
ia_reference(&iapref->ia, ia, MDL);
pool = NULL;
if (find_ipv6_pool(&pool, D6O_IA_PD,
&iapref->addr) != ISC_R_SUCCESS) {
inet_ntop(AF_INET6, &iapref->addr,
addr_buf, sizeof(addr_buf));
parse_warn(cfile, "no ppool found for address %s",
parse_warn(cfile, "no pool found for address %s",
addr_buf);
return;
}
add_prefix6(ppool, iapref, end_time);
ipv6_ppool_dereference(&ppool, MDL);
iaprefix_dereference(&iapref, MDL);
add_lease6(pool, iapref, end_time);
ipv6_pool_dereference(&pool, MDL);
iaaddr_dereference(&iapref, MDL);
}
/*
* If we have an existing record for this IA_PD, remove it.
*/
old_ia_pd = NULL;
if (ia_pd_hash_lookup(&old_ia_pd, ia_pd_active,
(unsigned char *)ia_pd->iaid_duid.data,
ia_pd->iaid_duid.len, MDL)) {
ia_pd_hash_delete(ia_pd_active,
(unsigned char *)ia_pd->iaid_duid.data,
ia_pd->iaid_duid.len, MDL);
ia_pd_dereference(&old_ia_pd, MDL);
old_ia = NULL;
if (ia_hash_lookup(&old_ia, ia_pd_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, MDL)) {
ia_hash_delete(ia_pd_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, MDL);
ia_dereference(&old_ia, MDL);
}
/*
* If we have prefixes, add this, otherwise don't bother.
*/
if (ia_pd->num_iaprefix > 0) {
ia_pd_hash_add(ia_pd_active,
(unsigned char *)ia_pd->iaid_duid.data,
ia_pd->iaid_duid.len, ia_pd, MDL);
if (ia->num_iaaddr > 0) {
ia_hash_add(ia_pd_active,
(unsigned char *)ia->iaid_duid.data,
ia->iaid_duid.len, ia, MDL);
}
ia_pd_dereference(&ia_pd, MDL);
ia_dereference(&ia, MDL);
#endif /* defined(DHCPv6) */
}

View File

@@ -500,7 +500,7 @@ int write_group (group)
* Write an IA and the options it has.
*/
int
write_ia(const struct ia_na *ia) {
write_ia(const struct ia_xx *ia) {
struct iaaddr *iaaddr;
struct binding *bnd;
int i;
@@ -529,14 +529,20 @@ write_ia(const struct ia_na *ia) {
if (s == NULL) {
goto error_exit;
}
if (ia->ia_type == D6O_IA_NA) {
switch (ia->ia_type) {
case D6O_IA_NA:
fprintf_ret = fprintf(db_file, "ia-na \"%s\" {\n", s);
} else if (ia->ia_type == D6O_IA_TA) {
break;
case D6O_IA_TA:
fprintf_ret = fprintf(db_file, "ia-ta \"%s\" {\n", s);
} else {
log_error("Unknown ia type %u at %s:%d",
(unsigned)ia->ia_type, MDL);
goto error_exit;
break;
case D6O_IA_PD:
fprintf_ret = fprintf(db_file, "ia-pd \"%s\" {\n", s);
break;
default:
log_error("Unknown ia type %u for \"%s\" at %s:%d",
(unsigned)ia->ia_type, s, MDL);
fprintf_ret = -1;
}
dfree(s, MDL);
if (fprintf_ret < 0) {
@@ -546,7 +552,13 @@ write_ia(const struct ia_na *ia) {
iaaddr = ia->iaaddr[i];
inet_ntop(AF_INET6, &iaaddr->addr, addr_buf, sizeof(addr_buf));
if (fprintf(db_file, " iaaddr %s {\n", addr_buf) < 0) {
if ((ia->ia_type != D6O_IA_PD) &&
(fprintf(db_file, " iaaddr %s {\n", addr_buf) < 0)) {
goto error_exit;
}
if ((ia->ia_type == D6O_IA_PD) &&
(fprintf(db_file, " iaprefix %s/%d {\n",
addr_buf, (int)iaaddr->plen) < 0)) {
goto error_exit;
}
if ((iaaddr->state <= 0) || (iaaddr->state > FTS_LAST)) {
@@ -607,115 +619,7 @@ write_ia(const struct ia_na *ia) {
return 1;
error_exit:
log_info("write_ia: unable to write ia-na");
lease_file_is_corrupt = 1;
return 0;
}
/*
* Write an IA_PD and the options it has.
*/
int
write_ia_pd(const struct ia_pd *ia_pd) {
struct iaprefix *iapref;
struct binding *bnd;
int i;
char addr_buf[sizeof("ffff:ffff:ffff:ffff:ffff:ffff.255.255.255.255")];
const char *binding_state;
const char *tval;
char *s;
int fprintf_ret;
/*
* If the lease file is corrupt, don't try to write any more
* leases until we've written a good lease file.
*/
if (lease_file_is_corrupt) {
if (!new_lease_file()) {
return 0;
}
}
if (counting) {
++count;
}
s = quotify_buf(ia_pd->iaid_duid.data, ia_pd->iaid_duid.len, MDL);
if (s == NULL) {
goto error_exit;
}
fprintf_ret = fprintf(db_file, "ia-pd \"%s\" {\n", s);
dfree(s, MDL);
if (fprintf_ret < 0) {
goto error_exit;
}
for (i=0; i<ia_pd->num_iaprefix; i++) {
iapref = ia_pd->iaprefix[i];
inet_ntop(AF_INET6, &iapref->pref, addr_buf, sizeof(addr_buf));
if (fprintf(db_file, " iaprefix %s/%d {\n",
addr_buf, (int)iapref->plen) < 0) {
goto error_exit;
}
if ((iapref->state <= 0) || (iapref->state > FTS_LAST)) {
log_fatal("Unknown iaprefix state %d at %s:%d",
iapref->state, MDL);
}
binding_state = binding_state_names[iapref->state-1];
if (fprintf(db_file, " binding state %s;\n",
binding_state) < 0) {
goto error_exit;
}
/* Note that from here on out, the \n is prepended to the
* next write, rather than appended to the current write.
*/
if ((iapref->state == FTS_ACTIVE) ||
(iapref->state == FTS_ABANDONED)) {
tval = print_time(iapref->hard_lifetime_end_time);
} else {
tval = print_time(iapref->soft_lifetime_end_time);
}
if (tval == NULL) {
goto error_exit;
}
if (fprintf(db_file, " ends %s", tval) < 0) {
goto error_exit;
}
/* Write out any binding scopes: note that 'ends' above does
* not have \n on the end! We want that.
*/
if (iapref->scope != NULL)
bnd = iapref->scope->bindings;
else
bnd = NULL;
for (; bnd != NULL ; bnd = bnd->next) {
if (bnd->value == NULL)
continue;
/* We don't do a regular error_exit because the
* lease db is not corrupt in this case.
*/
if (write_binding_scope(db_file, bnd,
"\n ") != ISC_R_SUCCESS)
goto error_exit;
}
if (fprintf(db_file, "\n }\n") < 0)
goto error_exit;
}
if (fprintf(db_file, "}\n\n") < 0)
goto error_exit;
fflush(db_file);
return 1;
error_exit:
log_info("write_ia_pd: unable to write ia-pd");
log_info("write_ia: unable to write ia");
lease_file_is_corrupt = 1;
return 0;
}

View File

@@ -565,8 +565,8 @@ ddns_updates(struct packet *packet, struct lease *lease, struct lease *old,
memset (&ddns_dhcid, 0, sizeof ddns_dhcid);
if (lease6 != NULL)
result = get_dhcid(&ddns_dhcid, 2,
lease6->ia_na->iaid_duid.data,
lease6->ia_na->iaid_duid.len);
lease6->ia->iaid_duid.data,
lease6->ia->iaid_duid.len);
else if ((lease != NULL) && (lease->uid != NULL) &&
(lease->uid_len != 0))
result = get_dhcid (&ddns_dhcid,

View File

@@ -655,13 +655,13 @@ main(int argc, char **argv) {
#ifdef DHCPv6
/* set up DHCPv6 hashes */
if (!ia_na_new_hash(&ia_na_active, DEFAULT_HASH_SIZE, MDL)) {
if (!ia_new_hash(&ia_na_active, DEFAULT_HASH_SIZE, MDL)) {
log_fatal("Out of memory creating hash for active IA_NA.");
}
if (!ia_na_new_hash(&ia_ta_active, DEFAULT_HASH_SIZE, MDL)) {
if (!ia_new_hash(&ia_ta_active, DEFAULT_HASH_SIZE, MDL)) {
log_fatal("Out of memory creating hash for active IA_TA.");
}
if (!ia_pd_new_hash(&ia_pd_active, DEFAULT_HASH_SIZE, MDL)) {
if (!ia_new_hash(&ia_pd_active, DEFAULT_HASH_SIZE, MDL)) {
log_fatal("Out of memory creating hash for active IA_PD.");
}
#endif /* DHCPv6 */

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff