|
@@ -235,6 +235,9 @@ static int i40e_add_del_fdir_udpv4(struct i40e_vsi *vsi,
|
|
|
"Filter deleted for PCTYPE %d loc = %d\n",
|
|
|
fd_data->pctype, fd_data->fd_id);
|
|
|
}
|
|
|
+ if (err)
|
|
|
+ kfree(raw_packet);
|
|
|
+
|
|
|
return err ? -EOPNOTSUPP : 0;
|
|
|
}
|
|
|
|
|
@@ -312,6 +315,9 @@ static int i40e_add_del_fdir_tcpv4(struct i40e_vsi *vsi,
|
|
|
fd_data->pctype, fd_data->fd_id);
|
|
|
}
|
|
|
|
|
|
+ if (err)
|
|
|
+ kfree(raw_packet);
|
|
|
+
|
|
|
return err ? -EOPNOTSUPP : 0;
|
|
|
}
|
|
|
|
|
@@ -387,6 +393,9 @@ static int i40e_add_del_fdir_ipv4(struct i40e_vsi *vsi,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ if (err)
|
|
|
+ kfree(raw_packet);
|
|
|
+
|
|
|
return err ? -EOPNOTSUPP : 0;
|
|
|
}
|
|
|
|
|
@@ -526,11 +535,7 @@ static void i40e_unmap_and_free_tx_resource(struct i40e_ring *ring,
|
|
|
struct i40e_tx_buffer *tx_buffer)
|
|
|
{
|
|
|
if (tx_buffer->skb) {
|
|
|
- if (tx_buffer->tx_flags & I40E_TX_FLAGS_FD_SB)
|
|
|
- kfree(tx_buffer->raw_buf);
|
|
|
- else
|
|
|
- dev_kfree_skb_any(tx_buffer->skb);
|
|
|
-
|
|
|
+ dev_kfree_skb_any(tx_buffer->skb);
|
|
|
if (dma_unmap_len(tx_buffer, len))
|
|
|
dma_unmap_single(ring->dev,
|
|
|
dma_unmap_addr(tx_buffer, dma),
|
|
@@ -542,6 +547,10 @@ static void i40e_unmap_and_free_tx_resource(struct i40e_ring *ring,
|
|
|
dma_unmap_len(tx_buffer, len),
|
|
|
DMA_TO_DEVICE);
|
|
|
}
|
|
|
+
|
|
|
+ if (tx_buffer->tx_flags & I40E_TX_FLAGS_FD_SB)
|
|
|
+ kfree(tx_buffer->raw_buf);
|
|
|
+
|
|
|
tx_buffer->next_to_watch = NULL;
|
|
|
tx_buffer->skb = NULL;
|
|
|
dma_unmap_len_set(tx_buffer, len, 0);
|