On 01/31/2014 03:23 AM, Maxime Ripard wrote:
> Make the existing users of devm_spi_register_master use the
> devm_spi_alloc_master function to avoid leaking memory.

> diff --git a/drivers/spi/spi-tegra114.c b/drivers/spi/spi-tegra114.c

> @@ -1087,14 +1085,13 @@ static int tegra_spi_probe(struct platform_device 
> *pdev)
>       if (ret < 0) {
>               dev_err(&pdev->dev, "Failed to register ISR for IRQ %d\n",
>                                       tspi->irq);
> -             goto exit_free_master;
> +             return ret;
>       }
>  
>       tspi->clk = devm_clk_get(&pdev->dev, "spi");
>       if (IS_ERR(tspi->clk)) {
>               dev_err(&pdev->dev, "can not get clock\n");
> -             ret = PTR_ERR(tspi->clk);
> -             goto exit_free_irq;
> +             return PTR_ERR(tspi->clk);
>       }
>  
>       tspi->max_buf_size = SPI_FIFO_DEPTH << 2;
> @@ -1152,8 +1149,6 @@ exit_rx_dma_free:
>       tegra_spi_deinit_dma_param(tspi, true);
>  exit_free_irq:
>       free_irq(spi_irq, tspi);
> -exit_free_master:
> -     spi_master_put(master);
>       return ret;

Doesn't that s/goto exit_free_irq/return/ leak spi_irq? It's only OK to
replace goto free_master with a direct return.

The other two Tegra drivers don't seem to have this problem.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to