Commit a9add194 authored by Ganesh Goudar's avatar Ganesh Goudar Committed by David S. Miller

cxgb4: use CLIP with LIP6 on T6 for TCAM filters

On T6, LIP compression is always enabled for IPv6 and uncompressed
IPv6 for LIP is not supported. So, for IPv6 TCAM filters on T6,
add LIP6 to CLIP on filter creation, and release the same on filter
deletion.
Signed-off-by: default avatarKumar Sanghvi <kumaras@chelsio.com>
Signed-off-by: default avatarGanesh Goudar <ganeshgr@chelsio.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent ef27e2cc
...@@ -694,7 +694,7 @@ void clear_filter(struct adapter *adap, struct filter_entry *f) ...@@ -694,7 +694,7 @@ void clear_filter(struct adapter *adap, struct filter_entry *f)
if (f->smt) if (f->smt)
cxgb4_smt_release(f->smt); cxgb4_smt_release(f->smt);
if (f->fs.hash && f->fs.type) if ((f->fs.hash || is_t6(adap->params.chip)) && f->fs.type)
cxgb4_clip_release(f->dev, (const u32 *)&f->fs.val.lip, 1); cxgb4_clip_release(f->dev, (const u32 *)&f->fs.val.lip, 1);
/* The zeroing of the filter rule below clears the filter valid, /* The zeroing of the filter rule below clears the filter valid,
...@@ -1291,6 +1291,16 @@ int __cxgb4_set_filter(struct net_device *dev, int filter_id, ...@@ -1291,6 +1291,16 @@ int __cxgb4_set_filter(struct net_device *dev, int filter_id,
if (f->valid) if (f->valid)
clear_filter(adapter, f); clear_filter(adapter, f);
if (is_t6(adapter->params.chip) && fs->type &&
ipv6_addr_type((const struct in6_addr *)fs->val.lip) !=
IPV6_ADDR_ANY) {
ret = cxgb4_clip_get(dev, (const u32 *)&fs->val.lip, 1);
if (ret) {
cxgb4_clear_ftid(&adapter->tids, filter_id, PF_INET6);
return ret;
}
}
/* Convert the filter specification into our internal format. /* Convert the filter specification into our internal format.
* We copy the PF/VF specification into the Outer VLAN field * We copy the PF/VF specification into the Outer VLAN field
* here so the rest of the code -- including the interface to * here so the rest of the code -- including the interface to
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment