mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-14 15:54:15 +08:00
igc: Replace IGC_TX_FLAGS_XDP flag by an enum
Up to this point, Tx buffers are associated with either a skb or a xdpf, and the IGC_TX_FLAGS_XDP flag was enough to distinguish between these two case. However, with upcoming patches that will add AF_XDP zero-copy support, a third case will be introduced so this flag-based approach won't fit well. In preparation to land AF_XDP zero-copy support, replace the IGC_TX_FLAGS_XDP flag by an enum which will be extended once zero-copy support is introduced to the driver. Signed-off-by: Andre Guedes <andre.guedes@intel.com> Signed-off-by: Vedang Patel <vedang.patel@intel.com> Signed-off-by: Jithu Joseph <jithu.joseph@intel.com> Reviewed-by: Maciej Fijalkowski <maciej.fijalkowski@intel.com> Tested-by: Dvora Fuxbrumer <dvorax.fuxbrumer@linux.intel.com> Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
This commit is contained in:
parent
6123429516
commit
859b4dfa41
@ -390,8 +390,6 @@ enum igc_tx_flags {
|
|||||||
/* olinfo flags */
|
/* olinfo flags */
|
||||||
IGC_TX_FLAGS_IPV4 = 0x10,
|
IGC_TX_FLAGS_IPV4 = 0x10,
|
||||||
IGC_TX_FLAGS_CSUM = 0x20,
|
IGC_TX_FLAGS_CSUM = 0x20,
|
||||||
|
|
||||||
IGC_TX_FLAGS_XDP = 0x100,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
enum igc_boards {
|
enum igc_boards {
|
||||||
@ -408,12 +406,18 @@ enum igc_boards {
|
|||||||
#define TXD_USE_COUNT(S) DIV_ROUND_UP((S), IGC_MAX_DATA_PER_TXD)
|
#define TXD_USE_COUNT(S) DIV_ROUND_UP((S), IGC_MAX_DATA_PER_TXD)
|
||||||
#define DESC_NEEDED (MAX_SKB_FRAGS + 4)
|
#define DESC_NEEDED (MAX_SKB_FRAGS + 4)
|
||||||
|
|
||||||
|
enum igc_tx_buffer_type {
|
||||||
|
IGC_TX_BUFFER_TYPE_SKB,
|
||||||
|
IGC_TX_BUFFER_TYPE_XDP,
|
||||||
|
};
|
||||||
|
|
||||||
/* wrapper around a pointer to a socket buffer,
|
/* wrapper around a pointer to a socket buffer,
|
||||||
* so a DMA handle can be stored along with the buffer
|
* so a DMA handle can be stored along with the buffer
|
||||||
*/
|
*/
|
||||||
struct igc_tx_buffer {
|
struct igc_tx_buffer {
|
||||||
union igc_adv_tx_desc *next_to_watch;
|
union igc_adv_tx_desc *next_to_watch;
|
||||||
unsigned long time_stamp;
|
unsigned long time_stamp;
|
||||||
|
enum igc_tx_buffer_type type;
|
||||||
union {
|
union {
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
struct xdp_frame *xdpf;
|
struct xdp_frame *xdpf;
|
||||||
|
@ -191,10 +191,17 @@ static void igc_clean_tx_ring(struct igc_ring *tx_ring)
|
|||||||
while (i != tx_ring->next_to_use) {
|
while (i != tx_ring->next_to_use) {
|
||||||
union igc_adv_tx_desc *eop_desc, *tx_desc;
|
union igc_adv_tx_desc *eop_desc, *tx_desc;
|
||||||
|
|
||||||
if (tx_buffer->tx_flags & IGC_TX_FLAGS_XDP)
|
switch (tx_buffer->type) {
|
||||||
|
case IGC_TX_BUFFER_TYPE_XDP:
|
||||||
xdp_return_frame(tx_buffer->xdpf);
|
xdp_return_frame(tx_buffer->xdpf);
|
||||||
else
|
break;
|
||||||
|
case IGC_TX_BUFFER_TYPE_SKB:
|
||||||
dev_kfree_skb_any(tx_buffer->skb);
|
dev_kfree_skb_any(tx_buffer->skb);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
netdev_warn_once(tx_ring->netdev, "Unknown Tx buffer type\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
igc_unmap_tx_buffer(tx_ring->dev, tx_buffer);
|
igc_unmap_tx_buffer(tx_ring->dev, tx_buffer);
|
||||||
|
|
||||||
@ -1360,6 +1367,7 @@ static netdev_tx_t igc_xmit_frame_ring(struct sk_buff *skb,
|
|||||||
|
|
||||||
/* record the location of the first descriptor for this packet */
|
/* record the location of the first descriptor for this packet */
|
||||||
first = &tx_ring->tx_buffer_info[tx_ring->next_to_use];
|
first = &tx_ring->tx_buffer_info[tx_ring->next_to_use];
|
||||||
|
first->type = IGC_TX_BUFFER_TYPE_SKB;
|
||||||
first->skb = skb;
|
first->skb = skb;
|
||||||
first->bytecount = skb->len;
|
first->bytecount = skb->len;
|
||||||
first->gso_segs = 1;
|
first->gso_segs = 1;
|
||||||
@ -1943,8 +1951,8 @@ static int igc_xdp_init_tx_buffer(struct igc_tx_buffer *buffer,
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
buffer->type = IGC_TX_BUFFER_TYPE_XDP;
|
||||||
buffer->xdpf = xdpf;
|
buffer->xdpf = xdpf;
|
||||||
buffer->tx_flags = IGC_TX_FLAGS_XDP;
|
|
||||||
buffer->protocol = 0;
|
buffer->protocol = 0;
|
||||||
buffer->bytecount = xdpf->len;
|
buffer->bytecount = xdpf->len;
|
||||||
buffer->gso_segs = 1;
|
buffer->gso_segs = 1;
|
||||||
@ -2305,10 +2313,17 @@ static bool igc_clean_tx_irq(struct igc_q_vector *q_vector, int napi_budget)
|
|||||||
total_bytes += tx_buffer->bytecount;
|
total_bytes += tx_buffer->bytecount;
|
||||||
total_packets += tx_buffer->gso_segs;
|
total_packets += tx_buffer->gso_segs;
|
||||||
|
|
||||||
if (tx_buffer->tx_flags & IGC_TX_FLAGS_XDP)
|
switch (tx_buffer->type) {
|
||||||
|
case IGC_TX_BUFFER_TYPE_XDP:
|
||||||
xdp_return_frame(tx_buffer->xdpf);
|
xdp_return_frame(tx_buffer->xdpf);
|
||||||
else
|
break;
|
||||||
|
case IGC_TX_BUFFER_TYPE_SKB:
|
||||||
napi_consume_skb(tx_buffer->skb, napi_budget);
|
napi_consume_skb(tx_buffer->skb, napi_budget);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
netdev_warn_once(tx_ring->netdev, "Unknown Tx buffer type\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
igc_unmap_tx_buffer(tx_ring->dev, tx_buffer);
|
igc_unmap_tx_buffer(tx_ring->dev, tx_buffer);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user