@@ -174,10 +174,6 @@ static void wx_dma_sync_frag(struct wx_ring *rx_ring,
174174 skb_frag_off (frag ),
175175 skb_frag_size (frag ),
176176 DMA_FROM_DEVICE );
177-
178- /* If the page was released, just unmap it. */
179- if (unlikely (WX_CB (skb )-> page_released ))
180- page_pool_put_full_page (rx_ring -> page_pool , rx_buffer -> page , false);
181177}
182178
183179static struct wx_rx_buffer * wx_get_rx_buffer (struct wx_ring * rx_ring ,
@@ -227,10 +223,6 @@ static void wx_put_rx_buffer(struct wx_ring *rx_ring,
227223 struct sk_buff * skb ,
228224 int rx_buffer_pgcnt )
229225{
230- if (!IS_ERR (skb ) && WX_CB (skb )-> dma == rx_buffer -> dma )
231- /* the page has been released from the ring */
232- WX_CB (skb )-> page_released = true;
233-
234226 /* clear contents of rx_buffer */
235227 rx_buffer -> page = NULL ;
236228 rx_buffer -> skb = NULL ;
@@ -315,7 +307,7 @@ static bool wx_alloc_mapped_page(struct wx_ring *rx_ring,
315307 return false;
316308 dma = page_pool_get_dma_addr (page );
317309
318- bi -> page_dma = dma ;
310+ bi -> dma = dma ;
319311 bi -> page = page ;
320312 bi -> page_offset = 0 ;
321313
@@ -352,7 +344,7 @@ void wx_alloc_rx_buffers(struct wx_ring *rx_ring, u16 cleaned_count)
352344 DMA_FROM_DEVICE );
353345
354346 rx_desc -> read .pkt_addr =
355- cpu_to_le64 (bi -> page_dma + bi -> page_offset );
347+ cpu_to_le64 (bi -> dma + bi -> page_offset );
356348
357349 rx_desc ++ ;
358350 bi ++ ;
@@ -365,6 +357,8 @@ void wx_alloc_rx_buffers(struct wx_ring *rx_ring, u16 cleaned_count)
365357
366358 /* clear the status bits for the next_to_use descriptor */
367359 rx_desc -> wb .upper .status_error = 0 ;
360+ /* clear the length for the next_to_use descriptor */
361+ rx_desc -> wb .upper .length = 0 ;
368362
369363 cleaned_count -- ;
370364 } while (cleaned_count );
@@ -2423,9 +2417,6 @@ static void wx_clean_rx_ring(struct wx_ring *rx_ring)
24232417 if (rx_buffer -> skb ) {
24242418 struct sk_buff * skb = rx_buffer -> skb ;
24252419
2426- if (WX_CB (skb )-> page_released )
2427- page_pool_put_full_page (rx_ring -> page_pool , rx_buffer -> page , false);
2428-
24292420 dev_kfree_skb (skb );
24302421 }
24312422
@@ -2449,6 +2440,9 @@ static void wx_clean_rx_ring(struct wx_ring *rx_ring)
24492440 }
24502441 }
24512442
2443+ /* Zero out the descriptor ring */
2444+ memset (rx_ring -> desc , 0 , rx_ring -> size );
2445+
24522446 rx_ring -> next_to_alloc = 0 ;
24532447 rx_ring -> next_to_clean = 0 ;
24542448 rx_ring -> next_to_use = 0 ;
0 commit comments