Re: [PATCH 0/3] spi: core: Introduce devm_spi_alloc_master

From: Maxime Ripard
Date: Fri Jan 31 2014 - 17:40:19 EST


On Fri, Jan 31, 2014 at 12:12:15PM +0000, Mark Brown wrote:
> On Fri, Jan 31, 2014 at 11:23:09AM +0100, Maxime Ripard wrote:
>
> > This patchset introduces a devm_spi_alloc_master to the spi core. While most of
> > the drivers have a spi_master_put call in the probe, a lot of them using the
> > devm_spi_register_master function are missing it in the remove function,
> > leading to leaked resources.
>
> This seems confusing - the idea here is that if we've handed the device
> off to the managed function then the managed function deals with
> destroying it. Note that spi_alloc_master() says that the put is only
> required after errors adding the device (which would be the expected
> behaviour if you look at other APIs). Looking at the code I think there
> is an issue here but I'm not at all clear that this is the best fix.

Ah, right, spi_master_put doesn't free the memory either...

I guess we have a few choices here, either:
- Add a devm_kzalloc to spi_alloc_master, since most of the drivers
I've been looking at fail to free the memory, this would be the
least intrusive solution. We'd still have to remove all the kfree
calls in the driver that rightfully free the memory.
- Make devm_unregister_master also call kfree on the master
- Add a kfree to my devm_put_master so that the memory is reclaimed,
which isn't the case for now.

I don't have a strong preference here, maybe for the third one, since
it makes obvious that it's managed and you don't have to do anything
about it, while the other do not.

Maxime

--
Maxime Ripard, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com

Attachment: signature.asc
Description: Digital signature