Commit fa383f6b authored by Lorenzo Bianconi's avatar Lorenzo Bianconi Committed by David S. Miller

net: mvneta: move header prefetch in mvneta_swbm_rx_frame

Move data buffer prefetch in mvneta_swbm_rx_frame after
dma_sync_single_range_for_cpu
Signed-off-by: default avatarIlias Apalodimas <ilias.apalodimas@linaro.org>
Signed-off-by: default avatarJesper Dangaard Brouer <brouer@redhat.com>
Signed-off-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 0db51da7
...@@ -2025,6 +2025,9 @@ mvneta_swbm_rx_frame(struct mvneta_port *pp, ...@@ -2025,6 +2025,9 @@ mvneta_swbm_rx_frame(struct mvneta_port *pp,
rx_desc->buf_phys_addr, rx_desc->buf_phys_addr,
len, dma_dir); len, dma_dir);
/* Prefetch header */
prefetch(data);
xdp->data_hard_start = data; xdp->data_hard_start = data;
xdp->data = data + MVNETA_SKB_HEADROOM + MVNETA_MH_SIZE; xdp->data = data + MVNETA_SKB_HEADROOM + MVNETA_MH_SIZE;
xdp->data_end = xdp->data + data_len; xdp->data_end = xdp->data + data_len;
...@@ -2122,14 +2125,10 @@ static int mvneta_rx_swbm(struct napi_struct *napi, ...@@ -2122,14 +2125,10 @@ static int mvneta_rx_swbm(struct napi_struct *napi,
while (rx_proc < budget && rx_proc < rx_todo) { while (rx_proc < budget && rx_proc < rx_todo) {
struct mvneta_rx_desc *rx_desc = mvneta_rxq_next_desc_get(rxq); struct mvneta_rx_desc *rx_desc = mvneta_rxq_next_desc_get(rxq);
u32 rx_status, index; u32 rx_status, index;
unsigned char *data;
struct page *page; struct page *page;
index = rx_desc - rxq->descs; index = rx_desc - rxq->descs;
page = (struct page *)rxq->buf_virt_addr[index]; page = (struct page *)rxq->buf_virt_addr[index];
data = page_address(page);
/* Prefetch header */
prefetch(data);
rx_status = rx_desc->status; rx_status = rx_desc->status;
rx_proc++; rx_proc++;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment