Commit 922aa9bc authored by Tao Liu's avatar Tao Liu Committed by David S. Miller

gve: Avoid freeing NULL pointer

Prevent possible crashes when cleaning up after unsuccessful
initializations.

Fixes: 893ce44d ("gve: Add basic driver framework for Compute Engine Virtual NIC")
Signed-off-by: default avatarTao Liu <xliutaox@google.com>
Signed-off-by: default avatarCatherine Sully <csully@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent d03477ee
...@@ -82,6 +82,9 @@ static int gve_alloc_counter_array(struct gve_priv *priv) ...@@ -82,6 +82,9 @@ static int gve_alloc_counter_array(struct gve_priv *priv)
static void gve_free_counter_array(struct gve_priv *priv) static void gve_free_counter_array(struct gve_priv *priv)
{ {
if (!priv->counter_array)
return;
dma_free_coherent(&priv->pdev->dev, dma_free_coherent(&priv->pdev->dev,
priv->num_event_counters * priv->num_event_counters *
sizeof(*priv->counter_array), sizeof(*priv->counter_array),
...@@ -142,6 +145,9 @@ static int gve_alloc_stats_report(struct gve_priv *priv) ...@@ -142,6 +145,9 @@ static int gve_alloc_stats_report(struct gve_priv *priv)
static void gve_free_stats_report(struct gve_priv *priv) static void gve_free_stats_report(struct gve_priv *priv)
{ {
if (!priv->stats_report)
return;
del_timer_sync(&priv->stats_report_timer); del_timer_sync(&priv->stats_report_timer);
dma_free_coherent(&priv->pdev->dev, priv->stats_report_len, dma_free_coherent(&priv->pdev->dev, priv->stats_report_len,
priv->stats_report, priv->stats_report_bus); priv->stats_report, priv->stats_report_bus);
...@@ -370,18 +376,19 @@ static void gve_free_notify_blocks(struct gve_priv *priv) ...@@ -370,18 +376,19 @@ static void gve_free_notify_blocks(struct gve_priv *priv)
{ {
int i; int i;
if (priv->msix_vectors) { if (!priv->msix_vectors)
/* Free the irqs */ return;
for (i = 0; i < priv->num_ntfy_blks; i++) {
struct gve_notify_block *block = &priv->ntfy_blocks[i];
int msix_idx = i;
irq_set_affinity_hint(priv->msix_vectors[msix_idx].vector, /* Free the irqs */
NULL); for (i = 0; i < priv->num_ntfy_blks; i++) {
free_irq(priv->msix_vectors[msix_idx].vector, block); struct gve_notify_block *block = &priv->ntfy_blocks[i];
} int msix_idx = i;
free_irq(priv->msix_vectors[priv->mgmt_msix_idx].vector, priv);
irq_set_affinity_hint(priv->msix_vectors[msix_idx].vector,
NULL);
free_irq(priv->msix_vectors[msix_idx].vector, block);
} }
free_irq(priv->msix_vectors[priv->mgmt_msix_idx].vector, priv);
dma_free_coherent(&priv->pdev->dev, dma_free_coherent(&priv->pdev->dev,
priv->num_ntfy_blks * sizeof(*priv->ntfy_blocks), priv->num_ntfy_blks * sizeof(*priv->ntfy_blocks),
priv->ntfy_blocks, priv->ntfy_block_bus); priv->ntfy_blocks, priv->ntfy_block_bus);
......
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