|
@@ -2911,9 +2911,10 @@ static int e1000_tx_map(struct e1000_adapter *adapter,
|
|
|
|
|
|
frag = &skb_shinfo(skb)->frags[f];
|
|
frag = &skb_shinfo(skb)->frags[f];
|
|
len = frag->size;
|
|
len = frag->size;
|
|
- offset = frag->page_offset;
|
|
|
|
|
|
+ offset = 0;
|
|
|
|
|
|
while (len) {
|
|
while (len) {
|
|
|
|
+ unsigned long bufend;
|
|
i++;
|
|
i++;
|
|
if (unlikely(i == tx_ring->count))
|
|
if (unlikely(i == tx_ring->count))
|
|
i = 0;
|
|
i = 0;
|
|
@@ -2927,18 +2928,19 @@ static int e1000_tx_map(struct e1000_adapter *adapter,
|
|
/* Workaround for potential 82544 hang in PCI-X.
|
|
/* Workaround for potential 82544 hang in PCI-X.
|
|
* Avoid terminating buffers within evenly-aligned
|
|
* Avoid terminating buffers within evenly-aligned
|
|
* dwords. */
|
|
* dwords. */
|
|
|
|
+ bufend = (unsigned long)
|
|
|
|
+ page_to_phys(skb_frag_page(frag));
|
|
|
|
+ bufend += offset + size - 1;
|
|
if (unlikely(adapter->pcix_82544 &&
|
|
if (unlikely(adapter->pcix_82544 &&
|
|
- !((unsigned long)(page_to_phys(frag->page) + offset
|
|
|
|
- + size - 1) & 4) &&
|
|
|
|
- size > 4))
|
|
|
|
|
|
+ !(bufend & 4) &&
|
|
|
|
+ size > 4))
|
|
size -= 4;
|
|
size -= 4;
|
|
|
|
|
|
buffer_info->length = size;
|
|
buffer_info->length = size;
|
|
buffer_info->time_stamp = jiffies;
|
|
buffer_info->time_stamp = jiffies;
|
|
buffer_info->mapped_as_page = true;
|
|
buffer_info->mapped_as_page = true;
|
|
- buffer_info->dma = dma_map_page(&pdev->dev, frag->page,
|
|
|
|
- offset, size,
|
|
|
|
- DMA_TO_DEVICE);
|
|
|
|
|
|
+ buffer_info->dma = skb_frag_dma_map(&pdev->dev, frag,
|
|
|
|
+ offset, size, DMA_TO_DEVICE);
|
|
if (dma_mapping_error(&pdev->dev, buffer_info->dma))
|
|
if (dma_mapping_error(&pdev->dev, buffer_info->dma))
|
|
goto dma_error;
|
|
goto dma_error;
|
|
buffer_info->next_to_watch = i;
|
|
buffer_info->next_to_watch = i;
|