Commit 3df18416 authored by Ankit Garg's avatar Ankit Garg Committed by Jakub Kicinski

gve: Modify rx_buf_alloc_fail counter centrally and closer to failure

Previously, each caller of gve_rx_alloc_buffer had to increase counter
 and as a result one caller was not tracking those failure. Increasing
 counters at a common location now so callers don't have to duplicate
 code or miss counter management.
Signed-off-by: default avatarAnkit Garg <nktgrg@google.com>
Link: https://lore.kernel.org/r/20240124205435.1021490-1-nktgrg@google.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 5535fcc5
...@@ -105,7 +105,8 @@ static void gve_setup_rx_buffer(struct gve_rx_slot_page_info *page_info, ...@@ -105,7 +105,8 @@ static void gve_setup_rx_buffer(struct gve_rx_slot_page_info *page_info,
static int gve_rx_alloc_buffer(struct gve_priv *priv, struct device *dev, static int gve_rx_alloc_buffer(struct gve_priv *priv, struct device *dev,
struct gve_rx_slot_page_info *page_info, struct gve_rx_slot_page_info *page_info,
union gve_rx_data_slot *data_slot) union gve_rx_data_slot *data_slot,
struct gve_rx_ring *rx)
{ {
struct page *page; struct page *page;
dma_addr_t dma; dma_addr_t dma;
...@@ -113,8 +114,12 @@ static int gve_rx_alloc_buffer(struct gve_priv *priv, struct device *dev, ...@@ -113,8 +114,12 @@ static int gve_rx_alloc_buffer(struct gve_priv *priv, struct device *dev,
err = gve_alloc_page(priv, dev, &page, &dma, DMA_FROM_DEVICE, err = gve_alloc_page(priv, dev, &page, &dma, DMA_FROM_DEVICE,
GFP_ATOMIC); GFP_ATOMIC);
if (err) if (err) {
u64_stats_update_begin(&rx->statss);
rx->rx_buf_alloc_fail++;
u64_stats_update_end(&rx->statss);
return err; return err;
}
gve_setup_rx_buffer(page_info, dma, page, &data_slot->addr); gve_setup_rx_buffer(page_info, dma, page, &data_slot->addr);
return 0; return 0;
...@@ -156,8 +161,9 @@ static int gve_rx_prefill_pages(struct gve_rx_ring *rx, ...@@ -156,8 +161,9 @@ static int gve_rx_prefill_pages(struct gve_rx_ring *rx,
&rx->data.data_ring[i].qpl_offset); &rx->data.data_ring[i].qpl_offset);
continue; continue;
} }
err = gve_rx_alloc_buffer(priv, &priv->pdev->dev, &rx->data.page_info[i], err = gve_rx_alloc_buffer(priv, &priv->pdev->dev,
&rx->data.data_ring[i]); &rx->data.page_info[i],
&rx->data.data_ring[i], rx);
if (err) if (err)
goto alloc_err_rda; goto alloc_err_rda;
} }
...@@ -936,10 +942,7 @@ static bool gve_rx_refill_buffers(struct gve_priv *priv, struct gve_rx_ring *rx) ...@@ -936,10 +942,7 @@ static bool gve_rx_refill_buffers(struct gve_priv *priv, struct gve_rx_ring *rx)
gve_rx_free_buffer(dev, page_info, data_slot); gve_rx_free_buffer(dev, page_info, data_slot);
page_info->page = NULL; page_info->page = NULL;
if (gve_rx_alloc_buffer(priv, dev, page_info, if (gve_rx_alloc_buffer(priv, dev, page_info,
data_slot)) { data_slot, rx)) {
u64_stats_update_begin(&rx->statss);
rx->rx_buf_alloc_fail++;
u64_stats_update_end(&rx->statss);
break; break;
} }
} }
......
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