Skip to content

Commit

Permalink
openvswitch: Update the CT state key only after nf_conntrack_in().
Browse files Browse the repository at this point in the history
Only a successful nf_conntrack_in() call can effect a connection state
change, so it suffices to update the key only after the
nf_conntrack_in() returns.

This change is needed for the later NAT patches.

Signed-off-by: Jarno Rajahalme <jarno@ovn.org>
Acked-by: Joe Stringer <joe@ovn.org>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
  • Loading branch information
Jarno Rajahalme authored and Pablo Neira Ayuso committed Mar 14, 2016
1 parent 9f13ded commit 394e910
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions net/openvswitch/conntrack.c
Original file line number Diff line number Diff line change
Expand Up @@ -382,7 +382,8 @@ static bool skb_nfct_cached(const struct net *net, const struct sk_buff *skb,
}

/* Pass 'skb' through conntrack in 'net', using zone configured in 'info', if
* not done already. Update key with new CT state.
* not done already. Update key with new CT state after passing the packet
* through conntrack.
* Note that if the packet is deemed invalid by conntrack, skb->nfct will be
* set to NULL and 0 will be returned.
*/
Expand Down Expand Up @@ -411,14 +412,14 @@ static int __ovs_ct_lookup(struct net *net, struct sw_flow_key *key,
skb) != NF_ACCEPT)
return -ENOENT;

ovs_ct_update_key(skb, info, key, true);

if (ovs_ct_helper(skb, info->family) != NF_ACCEPT) {
WARN_ONCE(1, "helper rejected packet");
return -EINVAL;
}
}

ovs_ct_update_key(skb, info, key, true);

return 0;
}

Expand Down

0 comments on commit 394e910

Please sign in to comment.