cxgbe/t4_tom: Fix CLIP entry refcounting on the passive side. Every
IPv6 connection being handled by the TOE should have a reference on its CLIP entry. Sponsored by: Chelsio Communications
This commit is contained in:
parent
2318a84733
commit
109b9048f8
@ -402,7 +402,7 @@ t4_connect(struct toedev *tod, struct socket *so, struct rtentry *rt,
|
||||
if ((inp->inp_vflag & INP_IPV6) == 0)
|
||||
DONT_OFFLOAD_ACTIVE_OPEN(ENOTSUP);
|
||||
|
||||
toep->ce = hold_lip(td, &inp->in6p_laddr);
|
||||
toep->ce = hold_lip(td, &inp->in6p_laddr, NULL);
|
||||
if (toep->ce == NULL)
|
||||
DONT_OFFLOAD_ACTIVE_OPEN(ENOENT);
|
||||
|
||||
|
@ -209,7 +209,7 @@ alloc_lctx(struct adapter *sc, struct inpcb *inp, struct vi_info *vi)
|
||||
!IN6_ARE_ADDR_EQUAL(&in6addr_any, &inp->in6p_laddr)) {
|
||||
struct tom_data *td = sc->tom_softc;
|
||||
|
||||
lctx->ce = hold_lip(td, &inp->in6p_laddr);
|
||||
lctx->ce = hold_lip(td, &inp->in6p_laddr, NULL);
|
||||
if (lctx->ce == NULL) {
|
||||
free(lctx, M_CXGBE);
|
||||
return (NULL);
|
||||
@ -1584,6 +1584,8 @@ reset:
|
||||
INP_WLOCK_ASSERT(new_inp);
|
||||
MPASS(so->so_vnet == lctx->vnet);
|
||||
toep->vnet = lctx->vnet;
|
||||
if (inc.inc_flags & INC_ISIPV6)
|
||||
toep->ce = hold_lip(sc->tom_softc, &inc.inc6_laddr, lctx->ce);
|
||||
|
||||
/*
|
||||
* This is for the unlikely case where the syncache entry that we added
|
||||
|
@ -730,12 +730,12 @@ search_lip(struct tom_data *td, struct in6_addr *lip)
|
||||
}
|
||||
|
||||
struct clip_entry *
|
||||
hold_lip(struct tom_data *td, struct in6_addr *lip)
|
||||
hold_lip(struct tom_data *td, struct in6_addr *lip, struct clip_entry *ce)
|
||||
{
|
||||
struct clip_entry *ce;
|
||||
|
||||
mtx_lock(&td->clip_table_lock);
|
||||
ce = search_lip(td, lip);
|
||||
if (ce == NULL)
|
||||
ce = search_lip(td, lip);
|
||||
if (ce != NULL)
|
||||
ce->refcount++;
|
||||
mtx_unlock(&td->clip_table_lock);
|
||||
|
@ -321,7 +321,8 @@ uint64_t calc_opt0(struct socket *, struct vi_info *, struct l2t_entry *,
|
||||
uint64_t select_ntuple(struct vi_info *, struct l2t_entry *);
|
||||
void set_tcpddp_ulp_mode(struct toepcb *);
|
||||
int negative_advice(int);
|
||||
struct clip_entry *hold_lip(struct tom_data *, struct in6_addr *);
|
||||
struct clip_entry *hold_lip(struct tom_data *, struct in6_addr *,
|
||||
struct clip_entry *);
|
||||
void release_lip(struct tom_data *, struct clip_entry *);
|
||||
|
||||
/* t4_connect.c */
|
||||
|
Loading…
x
Reference in New Issue
Block a user