diff options
| author | Randall Stewart <rrs@FreeBSD.org> | 2007-06-15 03:16:48 +0000 |
|---|---|---|
| committer | Randall Stewart <rrs@FreeBSD.org> | 2007-06-15 03:16:48 +0000 |
| commit | 22a67197090abd0ad3fd79c433337d42896fb31f (patch) | |
| tree | 8ed6f0307bb3d2c3f44e89a4e53ef2d270a3a82a | |
| parent | 5632c9822aa98448156f531fc76b3fb8cfbcee76 (diff) | |
Notes
| -rw-r--r-- | sys/netinet/sctp_asconf.c | 5 | ||||
| -rw-r--r-- | sys/netinet/sctp_pcb.c | 2 | ||||
| -rw-r--r-- | sys/netinet/sctp_pcb.h | 1 |
3 files changed, 7 insertions, 1 deletions
diff --git a/sys/netinet/sctp_asconf.c b/sys/netinet/sctp_asconf.c index 1b542579e408..df8c290ebd71 100644 --- a/sys/netinet/sctp_asconf.c +++ b/sys/netinet/sctp_asconf.c @@ -1704,6 +1704,11 @@ sctp_iterator_stcb(struct sctp_inpcb *inp, struct sctp_tcb *stcb, void *ptr, LIST_FOREACH(l, &asc->list_of_work, sctp_nxt_addr) { ifa = l->ifa; type = l->action; + + /* address's vrf_id must be the vrf_id of the assoc */ + if (ifa->vrf_id != stcb->asoc.vrf_id) { + continue; + } /* Same checks again for assoc */ if (ifa->address.sa.sa_family == AF_INET6) { /* invalid if we're not a v6 endpoint */ diff --git a/sys/netinet/sctp_pcb.c b/sys/netinet/sctp_pcb.c index 0160aeada839..4d23f24f0be5 100644 --- a/sys/netinet/sctp_pcb.c +++ b/sys/netinet/sctp_pcb.c @@ -414,7 +414,7 @@ sctp_add_addr_to_vrf(uint32_t vrf_id, void *ifn, uint32_t ifn_index, memset(sctp_ifap, 0, sizeof(struct sctp_ifa)); sctp_ifap->ifn_p = sctp_ifnp; atomic_add_int(&sctp_ifnp->refcount, 1); - + sctp_ifap->vrf_id = vrf_id; sctp_ifap->ifa = ifa; memcpy(&sctp_ifap->address, addr, addr->sa_len); sctp_ifap->localifa_flags = SCTP_ADDR_VALID | SCTP_ADDR_DEFER_USE; diff --git a/sys/netinet/sctp_pcb.h b/sys/netinet/sctp_pcb.h index 638def074e7d..2921459b7134 100644 --- a/sys/netinet/sctp_pcb.h +++ b/sys/netinet/sctp_pcb.h @@ -109,6 +109,7 @@ struct sctp_ifa { uint32_t refcount; /* number of folks refering to this */ uint32_t flags; uint32_t localifa_flags; + uint32_t vrf_id; /* vrf_id of this addr (for deleting) */ uint8_t src_is_loop; uint8_t src_is_priv; uint8_t src_is_glob; |
