diff options
-rw-r--r-- | drivers/net/igb/igb_main.c | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/drivers/net/igb/igb_main.c b/drivers/net/igb/igb_main.c index cb1acca9ac91..8f8b7ccc7db5 100644 --- a/drivers/net/igb/igb_main.c +++ b/drivers/net/igb/igb_main.c | |||
@@ -3245,9 +3245,9 @@ set_itr_now: | |||
3245 | #define IGB_TX_FLAGS_VLAN 0x00000002 | 3245 | #define IGB_TX_FLAGS_VLAN 0x00000002 |
3246 | #define IGB_TX_FLAGS_TSO 0x00000004 | 3246 | #define IGB_TX_FLAGS_TSO 0x00000004 |
3247 | #define IGB_TX_FLAGS_IPV4 0x00000008 | 3247 | #define IGB_TX_FLAGS_IPV4 0x00000008 |
3248 | #define IGB_TX_FLAGS_TSTAMP 0x00000010 | 3248 | #define IGB_TX_FLAGS_TSTAMP 0x00000010 |
3249 | #define IGB_TX_FLAGS_VLAN_MASK 0xffff0000 | 3249 | #define IGB_TX_FLAGS_VLAN_MASK 0xffff0000 |
3250 | #define IGB_TX_FLAGS_VLAN_SHIFT 16 | 3250 | #define IGB_TX_FLAGS_VLAN_SHIFT 16 |
3251 | 3251 | ||
3252 | static inline int igb_tso_adv(struct igb_ring *tx_ring, | 3252 | static inline int igb_tso_adv(struct igb_ring *tx_ring, |
3253 | struct sk_buff *skb, u32 tx_flags, u8 *hdr_len) | 3253 | struct sk_buff *skb, u32 tx_flags, u8 *hdr_len) |
@@ -3346,6 +3346,7 @@ static inline bool igb_tx_csum_adv(struct igb_ring *tx_ring, | |||
3346 | 3346 | ||
3347 | if (tx_flags & IGB_TX_FLAGS_VLAN) | 3347 | if (tx_flags & IGB_TX_FLAGS_VLAN) |
3348 | info |= (tx_flags & IGB_TX_FLAGS_VLAN_MASK); | 3348 | info |= (tx_flags & IGB_TX_FLAGS_VLAN_MASK); |
3349 | |||
3349 | info |= (skb_network_offset(skb) << E1000_ADVTXD_MACLEN_SHIFT); | 3350 | info |= (skb_network_offset(skb) << E1000_ADVTXD_MACLEN_SHIFT); |
3350 | if (skb->ip_summed == CHECKSUM_PARTIAL) | 3351 | if (skb->ip_summed == CHECKSUM_PARTIAL) |
3351 | info |= skb_network_header_len(skb); | 3352 | info |= skb_network_header_len(skb); |
@@ -3462,17 +3463,17 @@ static inline int igb_tx_map_adv(struct igb_ring *tx_ring, struct sk_buff *skb, | |||
3462 | tx_ring->buffer_info[i].skb = skb; | 3463 | tx_ring->buffer_info[i].skb = skb; |
3463 | tx_ring->buffer_info[first].next_to_watch = i; | 3464 | tx_ring->buffer_info[first].next_to_watch = i; |
3464 | 3465 | ||
3465 | return count + 1; | 3466 | return ++count; |
3466 | } | 3467 | } |
3467 | 3468 | ||
3468 | static inline void igb_tx_queue_adv(struct igb_ring *tx_ring, | 3469 | static inline void igb_tx_queue_adv(struct igb_ring *tx_ring, |
3469 | int tx_flags, int count, u32 paylen, | 3470 | int tx_flags, int count, u32 paylen, |
3470 | u8 hdr_len) | 3471 | u8 hdr_len) |
3471 | { | 3472 | { |
3472 | union e1000_adv_tx_desc *tx_desc = NULL; | 3473 | union e1000_adv_tx_desc *tx_desc; |
3473 | struct igb_buffer *buffer_info; | 3474 | struct igb_buffer *buffer_info; |
3474 | u32 olinfo_status = 0, cmd_type_len; | 3475 | u32 olinfo_status = 0, cmd_type_len; |
3475 | unsigned int i; | 3476 | unsigned int i = tx_ring->next_to_use; |
3476 | 3477 | ||
3477 | cmd_type_len = (E1000_ADVTXD_DTYP_DATA | E1000_ADVTXD_DCMD_IFCS | | 3478 | cmd_type_len = (E1000_ADVTXD_DTYP_DATA | E1000_ADVTXD_DCMD_IFCS | |
3478 | E1000_ADVTXD_DCMD_DEXT); | 3479 | E1000_ADVTXD_DCMD_DEXT); |
@@ -3505,18 +3506,18 @@ static inline void igb_tx_queue_adv(struct igb_ring *tx_ring, | |||
3505 | 3506 | ||
3506 | olinfo_status |= ((paylen - hdr_len) << E1000_ADVTXD_PAYLEN_SHIFT); | 3507 | olinfo_status |= ((paylen - hdr_len) << E1000_ADVTXD_PAYLEN_SHIFT); |
3507 | 3508 | ||
3508 | i = tx_ring->next_to_use; | 3509 | do { |
3509 | while (count--) { | ||
3510 | buffer_info = &tx_ring->buffer_info[i]; | 3510 | buffer_info = &tx_ring->buffer_info[i]; |
3511 | tx_desc = E1000_TX_DESC_ADV(*tx_ring, i); | 3511 | tx_desc = E1000_TX_DESC_ADV(*tx_ring, i); |
3512 | tx_desc->read.buffer_addr = cpu_to_le64(buffer_info->dma); | 3512 | tx_desc->read.buffer_addr = cpu_to_le64(buffer_info->dma); |
3513 | tx_desc->read.cmd_type_len = | 3513 | tx_desc->read.cmd_type_len = |
3514 | cpu_to_le32(cmd_type_len | buffer_info->length); | 3514 | cpu_to_le32(cmd_type_len | buffer_info->length); |
3515 | tx_desc->read.olinfo_status = cpu_to_le32(olinfo_status); | 3515 | tx_desc->read.olinfo_status = cpu_to_le32(olinfo_status); |
3516 | count--; | ||
3516 | i++; | 3517 | i++; |
3517 | if (i == tx_ring->count) | 3518 | if (i == tx_ring->count) |
3518 | i = 0; | 3519 | i = 0; |
3519 | } | 3520 | } while (count > 0); |
3520 | 3521 | ||
3521 | tx_desc->read.cmd_type_len |= cpu_to_le32(IGB_ADVTXD_DCMD); | 3522 | tx_desc->read.cmd_type_len |= cpu_to_le32(IGB_ADVTXD_DCMD); |
3522 | /* Force memory writes to complete before letting h/w | 3523 | /* Force memory writes to complete before letting h/w |
@@ -3568,8 +3569,7 @@ netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *skb, | |||
3568 | unsigned int first; | 3569 | unsigned int first; |
3569 | unsigned int tx_flags = 0; | 3570 | unsigned int tx_flags = 0; |
3570 | u8 hdr_len = 0; | 3571 | u8 hdr_len = 0; |
3571 | int count = 0; | 3572 | int tso = 0, count; |
3572 | int tso = 0; | ||
3573 | union skb_shared_tx *shtx = skb_tx(skb); | 3573 | union skb_shared_tx *shtx = skb_tx(skb); |
3574 | 3574 | ||
3575 | /* need: 1 descriptor per page, | 3575 | /* need: 1 descriptor per page, |
@@ -3587,7 +3587,7 @@ netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *skb, | |||
3587 | tx_flags |= IGB_TX_FLAGS_TSTAMP; | 3587 | tx_flags |= IGB_TX_FLAGS_TSTAMP; |
3588 | } | 3588 | } |
3589 | 3589 | ||
3590 | if (adapter->vlgrp && vlan_tx_tag_present(skb)) { | 3590 | if (vlan_tx_tag_present(skb) && adapter->vlgrp) { |
3591 | tx_flags |= IGB_TX_FLAGS_VLAN; | 3591 | tx_flags |= IGB_TX_FLAGS_VLAN; |
3592 | tx_flags |= (vlan_tx_tag_get(skb) << IGB_TX_FLAGS_VLAN_SHIFT); | 3592 | tx_flags |= (vlan_tx_tag_get(skb) << IGB_TX_FLAGS_VLAN_SHIFT); |
3593 | } | 3593 | } |
@@ -3598,6 +3598,7 @@ netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *skb, | |||
3598 | first = tx_ring->next_to_use; | 3598 | first = tx_ring->next_to_use; |
3599 | if (skb_is_gso(skb)) { | 3599 | if (skb_is_gso(skb)) { |
3600 | tso = igb_tso_adv(tx_ring, skb, tx_flags, &hdr_len); | 3600 | tso = igb_tso_adv(tx_ring, skb, tx_flags, &hdr_len); |
3601 | |||
3601 | if (tso < 0) { | 3602 | if (tso < 0) { |
3602 | dev_kfree_skb_any(skb); | 3603 | dev_kfree_skb_any(skb); |
3603 | return NETDEV_TX_OK; | 3604 | return NETDEV_TX_OK; |
@@ -3611,12 +3612,11 @@ netdev_tx_t igb_xmit_frame_ring_adv(struct sk_buff *skb, | |||
3611 | tx_flags |= IGB_TX_FLAGS_CSUM; | 3612 | tx_flags |= IGB_TX_FLAGS_CSUM; |
3612 | 3613 | ||
3613 | /* | 3614 | /* |
3614 | * count reflects descriptors mapped, if 0 then mapping error | 3615 | * count reflects descriptors mapped, if 0 or less then mapping error |
3615 | * has occured and we need to rewind the descriptor queue | 3616 | * has occured and we need to rewind the descriptor queue |
3616 | */ | 3617 | */ |
3617 | count = igb_tx_map_adv(tx_ring, skb, first); | 3618 | count = igb_tx_map_adv(tx_ring, skb, first); |
3618 | 3619 | if (count <= 0) { | |
3619 | if (!count) { | ||
3620 | dev_kfree_skb_any(skb); | 3620 | dev_kfree_skb_any(skb); |
3621 | tx_ring->buffer_info[first].time_stamp = 0; | 3621 | tx_ring->buffer_info[first].time_stamp = 0; |
3622 | tx_ring->next_to_use = first; | 3622 | tx_ring->next_to_use = first; |