Commit ccccb493 authored by Yinjun Zhang's avatar Yinjun Zhang Committed by David S. Miller

nfp: allow TSO packets with metadata prepended in NFDK path

Packets with metadata prepended can be correctly handled in
firmware when TSO is enabled, now remove the error path and
related comments. Since there's no existing firmware that
uses prepended metadata, no need to add compatibility check
here.
Signed-off-by: default avatarYinjun Zhang <yinjun.zhang@corigine.com>
Reviewed-by: default avatarLouis Peens <louis.peens@corigine.com>
Signed-off-by: default avatarSimon Horman <simon.horman@corigine.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 7e40e16e
...@@ -56,17 +56,6 @@ nfp_nfdk_tx_tso(struct nfp_net_r_vector *r_vec, struct nfp_nfdk_tx_buf *txbuf, ...@@ -56,17 +56,6 @@ nfp_nfdk_tx_tso(struct nfp_net_r_vector *r_vec, struct nfp_nfdk_tx_buf *txbuf,
segs = skb_shinfo(skb)->gso_segs; segs = skb_shinfo(skb)->gso_segs;
mss = skb_shinfo(skb)->gso_size & NFDK_DESC_TX_MSS_MASK; mss = skb_shinfo(skb)->gso_size & NFDK_DESC_TX_MSS_MASK;
/* Note: TSO of the packet with metadata prepended to skb is not
* supported yet, in which case l3/l4_offset and lso_hdrlen need
* be correctly handled here.
* Concern:
* The driver doesn't have md_bytes easily available at this point.
* The PCI.IN PD ME won't have md_bytes bytes to add to lso_hdrlen,
* so it needs the full length there. The app MEs might prefer
* l3_offset and l4_offset relative to the start of packet data,
* but could probably cope with it being relative to the CTM buf
* data offset.
*/
txd.l3_offset = l3_offset; txd.l3_offset = l3_offset;
txd.l4_offset = l4_offset; txd.l4_offset = l4_offset;
txd.lso_meta_res = 0; txd.lso_meta_res = 0;
...@@ -190,12 +179,6 @@ static int nfp_nfdk_prep_port_id(struct sk_buff *skb) ...@@ -190,12 +179,6 @@ static int nfp_nfdk_prep_port_id(struct sk_buff *skb)
if (unlikely(md_dst->type != METADATA_HW_PORT_MUX)) if (unlikely(md_dst->type != METADATA_HW_PORT_MUX))
return 0; return 0;
/* Note: Unsupported case when TSO a skb with metedata prepended.
* See the comments in `nfp_nfdk_tx_tso` for details.
*/
if (unlikely(md_dst && skb_is_gso(skb)))
return -EOPNOTSUPP;
if (unlikely(skb_cow_head(skb, sizeof(md_dst->u.port_info.port_id)))) if (unlikely(skb_cow_head(skb, sizeof(md_dst->u.port_info.port_id))))
return -ENOMEM; return -ENOMEM;
......
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