diff options
| author | Felix Fietkau <nbd@openwrt.org> | 2015-04-14 06:07:56 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2015-04-14 14:57:10 -0400 |
| commit | 4b62dce450e2447146ff6924a1ce8ad1a6592107 (patch) | |
| tree | 118cff26acaebcfe3fdb2918b1dbc9e43f71c049 /drivers/net/ethernet/broadcom | |
| parent | eb64e2923a886441c7b322f138b36029f3fa6a36 (diff) | |
bgmac: set received skb headroom to NET_SKB_PAD
A packet buffer offset of 30 bytes is inefficient, because the first 2
bytes end up in a different cacheline.
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/broadcom')
| -rw-r--r-- | drivers/net/ethernet/broadcom/bgmac.c | 14 | ||||
| -rw-r--r-- | drivers/net/ethernet/broadcom/bgmac.h | 4 |
2 files changed, 11 insertions, 7 deletions
diff --git a/drivers/net/ethernet/broadcom/bgmac.c b/drivers/net/ethernet/broadcom/bgmac.c index 9c3b2ff33e63..424a68ce5aa0 100644 --- a/drivers/net/ethernet/broadcom/bgmac.c +++ b/drivers/net/ethernet/broadcom/bgmac.c | |||
| @@ -346,13 +346,13 @@ static int bgmac_dma_rx_skb_for_slot(struct bgmac *bgmac, | |||
| 346 | return -ENOMEM; | 346 | return -ENOMEM; |
| 347 | 347 | ||
| 348 | /* Poison - if everything goes fine, hardware will overwrite it */ | 348 | /* Poison - if everything goes fine, hardware will overwrite it */ |
| 349 | rx = buf; | 349 | rx = buf + BGMAC_RX_BUF_OFFSET; |
| 350 | rx->len = cpu_to_le16(0xdead); | 350 | rx->len = cpu_to_le16(0xdead); |
| 351 | rx->flags = cpu_to_le16(0xbeef); | 351 | rx->flags = cpu_to_le16(0xbeef); |
| 352 | 352 | ||
| 353 | /* Map skb for the DMA */ | 353 | /* Map skb for the DMA */ |
| 354 | dma_addr = dma_map_single(dma_dev, buf, BGMAC_RX_BUF_SIZE, | 354 | dma_addr = dma_map_single(dma_dev, buf + BGMAC_RX_BUF_OFFSET, |
| 355 | DMA_FROM_DEVICE); | 355 | BGMAC_RX_BUF_SIZE, DMA_FROM_DEVICE); |
| 356 | if (dma_mapping_error(dma_dev, dma_addr)) { | 356 | if (dma_mapping_error(dma_dev, dma_addr)) { |
| 357 | bgmac_err(bgmac, "DMA mapping error\n"); | 357 | bgmac_err(bgmac, "DMA mapping error\n"); |
| 358 | put_page(virt_to_head_page(buf)); | 358 | put_page(virt_to_head_page(buf)); |
| @@ -403,7 +403,7 @@ static int bgmac_dma_rx_read(struct bgmac *bgmac, struct bgmac_dma_ring *ring, | |||
| 403 | while (ring->start != ring->end) { | 403 | while (ring->start != ring->end) { |
| 404 | struct device *dma_dev = bgmac->core->dma_dev; | 404 | struct device *dma_dev = bgmac->core->dma_dev; |
| 405 | struct bgmac_slot_info *slot = &ring->slots[ring->start]; | 405 | struct bgmac_slot_info *slot = &ring->slots[ring->start]; |
| 406 | struct bgmac_rx_header *rx = slot->buf; | 406 | struct bgmac_rx_header *rx = slot->buf + BGMAC_RX_BUF_OFFSET; |
| 407 | struct sk_buff *skb; | 407 | struct sk_buff *skb; |
| 408 | void *buf = slot->buf; | 408 | void *buf = slot->buf; |
| 409 | u16 len, flags; | 409 | u16 len, flags; |
| @@ -454,8 +454,10 @@ static int bgmac_dma_rx_read(struct bgmac *bgmac, struct bgmac_dma_ring *ring, | |||
| 454 | BGMAC_RX_BUF_SIZE, DMA_FROM_DEVICE); | 454 | BGMAC_RX_BUF_SIZE, DMA_FROM_DEVICE); |
| 455 | 455 | ||
| 456 | skb = build_skb(buf, BGMAC_RX_ALLOC_SIZE); | 456 | skb = build_skb(buf, BGMAC_RX_ALLOC_SIZE); |
| 457 | skb_put(skb, BGMAC_RX_FRAME_OFFSET + len); | 457 | skb_put(skb, BGMAC_RX_FRAME_OFFSET + |
| 458 | skb_pull(skb, BGMAC_RX_FRAME_OFFSET); | 458 | BGMAC_RX_BUF_OFFSET + len); |
| 459 | skb_pull(skb, BGMAC_RX_FRAME_OFFSET + | ||
| 460 | BGMAC_RX_BUF_OFFSET); | ||
| 459 | 461 | ||
| 460 | skb_checksum_none_assert(skb); | 462 | skb_checksum_none_assert(skb); |
| 461 | skb->protocol = eth_type_trans(skb, bgmac->net_dev); | 463 | skb->protocol = eth_type_trans(skb, bgmac->net_dev); |
diff --git a/drivers/net/ethernet/broadcom/bgmac.h b/drivers/net/ethernet/broadcom/bgmac.h index abd50d128e6c..3db0d5211c5d 100644 --- a/drivers/net/ethernet/broadcom/bgmac.h +++ b/drivers/net/ethernet/broadcom/bgmac.h | |||
| @@ -360,9 +360,11 @@ | |||
| 360 | 360 | ||
| 361 | #define BGMAC_RX_HEADER_LEN 28 /* Last 24 bytes are unused. Well... */ | 361 | #define BGMAC_RX_HEADER_LEN 28 /* Last 24 bytes are unused. Well... */ |
| 362 | #define BGMAC_RX_FRAME_OFFSET 30 /* There are 2 unused bytes between header and real data */ | 362 | #define BGMAC_RX_FRAME_OFFSET 30 /* There are 2 unused bytes between header and real data */ |
| 363 | #define BGMAC_RX_BUF_OFFSET (NET_SKB_PAD + NET_IP_ALIGN - \ | ||
| 364 | BGMAC_RX_FRAME_OFFSET) | ||
| 363 | #define BGMAC_RX_MAX_FRAME_SIZE 1536 /* Copied from b44/tg3 */ | 365 | #define BGMAC_RX_MAX_FRAME_SIZE 1536 /* Copied from b44/tg3 */ |
| 364 | #define BGMAC_RX_BUF_SIZE (BGMAC_RX_FRAME_OFFSET + BGMAC_RX_MAX_FRAME_SIZE) | 366 | #define BGMAC_RX_BUF_SIZE (BGMAC_RX_FRAME_OFFSET + BGMAC_RX_MAX_FRAME_SIZE) |
| 365 | #define BGMAC_RX_ALLOC_SIZE (SKB_DATA_ALIGN(BGMAC_RX_BUF_SIZE) + \ | 367 | #define BGMAC_RX_ALLOC_SIZE (SKB_DATA_ALIGN(BGMAC_RX_BUF_SIZE + BGMAC_RX_BUF_OFFSET) + \ |
| 366 | SKB_DATA_ALIGN(sizeof(struct skb_shared_info))) | 368 | SKB_DATA_ALIGN(sizeof(struct skb_shared_info))) |
| 367 | 369 | ||
| 368 | #define BGMAC_BFL_ENETROBO 0x0010 /* has ephy roboswitch spi */ | 370 | #define BGMAC_BFL_ENETROBO 0x0010 /* has ephy roboswitch spi */ |
