Skip to content

Commit 11a14dc

Browse files
cmclachl-xilinxdavem330
authored andcommitted
sfc: Include XDP packet headroom in buffer step size.
Correct a mismatch between rx_page_buf_step and the actual step size used when filling buffer pages. This patch fixes the page overrun that occured when the MTU was set to anything bigger than 1692. Fixes: 3990a8f ("sfc: allocate channels for XDP tx queues") Signed-off-by: Charles McLachlan <[email protected]> Signed-off-by: Edward Cree <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 8700aff commit 11a14dc

File tree

1 file changed

+7
-7
lines changed
  • drivers/net/ethernet/sfc

1 file changed

+7
-7
lines changed

drivers/net/ethernet/sfc/rx.c

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -96,11 +96,12 @@ static inline void efx_sync_rx_buffer(struct efx_nic *efx,
9696

9797
void efx_rx_config_page_split(struct efx_nic *efx)
9898
{
99-
efx->rx_page_buf_step = ALIGN(efx->rx_dma_len + efx->rx_ip_align,
99+
efx->rx_page_buf_step = ALIGN(efx->rx_dma_len + efx->rx_ip_align +
100+
XDP_PACKET_HEADROOM,
100101
EFX_RX_BUF_ALIGNMENT);
101102
efx->rx_bufs_per_page = efx->rx_buffer_order ? 1 :
102103
((PAGE_SIZE - sizeof(struct efx_rx_page_state)) /
103-
(efx->rx_page_buf_step + XDP_PACKET_HEADROOM));
104+
efx->rx_page_buf_step);
104105
efx->rx_buffer_truesize = (PAGE_SIZE << efx->rx_buffer_order) /
105106
efx->rx_bufs_per_page;
106107
efx->rx_pages_per_batch = DIV_ROUND_UP(EFX_RX_PREFERRED_BATCH,
@@ -190,14 +191,13 @@ static int efx_init_rx_buffers(struct efx_rx_queue *rx_queue, bool atomic)
190191
page_offset = sizeof(struct efx_rx_page_state);
191192

192193
do {
193-
page_offset += XDP_PACKET_HEADROOM;
194-
dma_addr += XDP_PACKET_HEADROOM;
195-
196194
index = rx_queue->added_count & rx_queue->ptr_mask;
197195
rx_buf = efx_rx_buffer(rx_queue, index);
198-
rx_buf->dma_addr = dma_addr + efx->rx_ip_align;
196+
rx_buf->dma_addr = dma_addr + efx->rx_ip_align +
197+
XDP_PACKET_HEADROOM;
199198
rx_buf->page = page;
200-
rx_buf->page_offset = page_offset + efx->rx_ip_align;
199+
rx_buf->page_offset = page_offset + efx->rx_ip_align +
200+
XDP_PACKET_HEADROOM;
201201
rx_buf->len = efx->rx_dma_len;
202202
rx_buf->flags = 0;
203203
++rx_queue->added_count;

0 commit comments

Comments
 (0)