diff options
Diffstat (limited to 'drivers/net/wireless/iwlegacy/3945-mac.c')
| -rw-r--r-- | drivers/net/wireless/iwlegacy/3945-mac.c | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/drivers/net/wireless/iwlegacy/3945-mac.c b/drivers/net/wireless/iwlegacy/3945-mac.c index 3630a41df50d..c353b5f19c8c 100644 --- a/drivers/net/wireless/iwlegacy/3945-mac.c +++ b/drivers/net/wireless/iwlegacy/3945-mac.c | |||
| @@ -475,6 +475,7 @@ il3945_tx_skb(struct il_priv *il, | |||
| 475 | dma_addr_t txcmd_phys; | 475 | dma_addr_t txcmd_phys; |
| 476 | int txq_id = skb_get_queue_mapping(skb); | 476 | int txq_id = skb_get_queue_mapping(skb); |
| 477 | u16 len, idx, hdr_len; | 477 | u16 len, idx, hdr_len; |
| 478 | u16 firstlen, secondlen; | ||
| 478 | u8 id; | 479 | u8 id; |
| 479 | u8 unicast; | 480 | u8 unicast; |
| 480 | u8 sta_id; | 481 | u8 sta_id; |
| @@ -589,21 +590,22 @@ il3945_tx_skb(struct il_priv *il, | |||
| 589 | len = | 590 | len = |
| 590 | sizeof(struct il3945_tx_cmd) + sizeof(struct il_cmd_header) + | 591 | sizeof(struct il3945_tx_cmd) + sizeof(struct il_cmd_header) + |
| 591 | hdr_len; | 592 | hdr_len; |
| 592 | len = (len + 3) & ~3; | 593 | firstlen = (len + 3) & ~3; |
| 593 | 594 | ||
| 594 | /* Physical address of this Tx command's header (not MAC header!), | 595 | /* Physical address of this Tx command's header (not MAC header!), |
| 595 | * within command buffer array. */ | 596 | * within command buffer array. */ |
| 596 | txcmd_phys = | 597 | txcmd_phys = |
| 597 | pci_map_single(il->pci_dev, &out_cmd->hdr, len, PCI_DMA_TODEVICE); | 598 | pci_map_single(il->pci_dev, &out_cmd->hdr, firstlen, |
| 599 | PCI_DMA_TODEVICE); | ||
| 598 | if (unlikely(pci_dma_mapping_error(il->pci_dev, txcmd_phys))) | 600 | if (unlikely(pci_dma_mapping_error(il->pci_dev, txcmd_phys))) |
| 599 | goto drop_unlock; | 601 | goto drop_unlock; |
| 600 | 602 | ||
| 601 | /* Set up TFD's 2nd entry to point directly to remainder of skb, | 603 | /* Set up TFD's 2nd entry to point directly to remainder of skb, |
| 602 | * if any (802.11 null frames have no payload). */ | 604 | * if any (802.11 null frames have no payload). */ |
| 603 | len = skb->len - hdr_len; | 605 | secondlen = skb->len - hdr_len; |
| 604 | if (len) { | 606 | if (secondlen > 0) { |
| 605 | phys_addr = | 607 | phys_addr = |
| 606 | pci_map_single(il->pci_dev, skb->data + hdr_len, len, | 608 | pci_map_single(il->pci_dev, skb->data + hdr_len, secondlen, |
| 607 | PCI_DMA_TODEVICE); | 609 | PCI_DMA_TODEVICE); |
| 608 | if (unlikely(pci_dma_mapping_error(il->pci_dev, phys_addr))) | 610 | if (unlikely(pci_dma_mapping_error(il->pci_dev, phys_addr))) |
| 609 | goto drop_unlock; | 611 | goto drop_unlock; |
| @@ -611,12 +613,12 @@ il3945_tx_skb(struct il_priv *il, | |||
| 611 | 613 | ||
| 612 | /* Add buffer containing Tx command and MAC(!) header to TFD's | 614 | /* Add buffer containing Tx command and MAC(!) header to TFD's |
| 613 | * first entry */ | 615 | * first entry */ |
| 614 | il->ops->txq_attach_buf_to_tfd(il, txq, txcmd_phys, len, 1, 0); | 616 | il->ops->txq_attach_buf_to_tfd(il, txq, txcmd_phys, firstlen, 1, 0); |
| 615 | dma_unmap_addr_set(out_meta, mapping, txcmd_phys); | 617 | dma_unmap_addr_set(out_meta, mapping, txcmd_phys); |
| 616 | dma_unmap_len_set(out_meta, len, len); | 618 | dma_unmap_len_set(out_meta, len, firstlen); |
| 617 | if (len) | 619 | if (secondlen > 0) |
| 618 | il->ops->txq_attach_buf_to_tfd(il, txq, phys_addr, len, 0, | 620 | il->ops->txq_attach_buf_to_tfd(il, txq, phys_addr, secondlen, 0, |
| 619 | U32_PAD(len)); | 621 | U32_PAD(secondlen)); |
| 620 | 622 | ||
| 621 | if (!ieee80211_has_morefrags(hdr->frame_control)) { | 623 | if (!ieee80211_has_morefrags(hdr->frame_control)) { |
| 622 | txq->need_update = 1; | 624 | txq->need_update = 1; |
