Re: [RFC][PATCH V3] axi: add AXI bus driver

From: Greg KH
Date: Mon Apr 11 2011 - 17:58:39 EST


On Mon, Apr 11, 2011 at 11:36:39PM +0200, RafaÅ MiÅecki wrote:
> 2011/4/11 Greg KH <greg@xxxxxxxxx>:
> > On Mon, Apr 11, 2011 at 11:19:13PM +0200, RafaÅ MiÅecki wrote:
> >> 2011/4/11 Greg KH <greg@xxxxxxxxx>:
> >> > On Mon, Apr 11, 2011 at 11:25:14PM +0200, RafaÅ MiÅecki wrote:
> >> >> +static void axi_release_core_dev(struct device *dev)
> >> >> +{
> >> >> + Â Â /* Silent lack-of-release warning */
> >> >> +}
> >> >
> >> > Ok, WTF!!!!
> >>
> >> Thank you for your kindly words. It's much more enjoyable to work on
> >> kernel that way. I definitely made that on purpose.
> >
> > I can't tell if you are kidding or not.
>
> That was 100% irony. I swear I don't enjoy publishing bad code and
> getting such a comment.

Ok, you forgot the ':)' then...

> > Please read the documentation for how to do this properly. ÂI find it
> > really hard to believe that you wrote that comment instead of putting in
> > the 2 lines of code required for this function.
> >
> > Especially as-it-is, your code does not work properly and leaks memory
> > badly. ÂWhy would you do that on purpose?
>
> I tried to read some documentation about this.
>
> 1) driver-mode/device.txt says only that:
> > Callback to free the device after all references have
> > gone away. This should be set by the allocator of the
> > device (i.e. the bus driver that discovered the device).
> I *really* do not know how my driver should "free" core on AXI bus.

The structure that you have created, added to the bus, is now ready to
have its memory freed. So free it.

This usually means something like:
struct my_obj = to_my_obj(dev);
kfree(my_obj);
in the release function.

> 2) LDD3 says:
> > The method is called when the last reference to the device is removed; it is called
> > from the embedded kobjectâs release method. All device structures registered with
> > the core must have a release method, or the kernel prints out scary complaints.
> Well, I do not register any structs for AXI core.

Yes you did, otherwise you would have never seen that callback warning
you that you needed a release function.

> 3) Example code from LDD3:
> static void ldd_bus_release(struct device *dev)
> {
> printk(KERN_DEBUG "lddbus release\n");
> }
> Yeah, that's what I did...

Wow that's old, sorry. See the kobject documentation for much more
detail about what you need here.

> 4) SSB in it's ssb_release_dev just calls kfree on struct that was
> allocated when registering drivers. *I do not* allocate such a struct,
> so I believe I do exactly the same memory leak as SSB does.

Well someone allocated it, right? Who did it? If it wasn't you, where
did that structure come from and why are you registering it on your bus?

> Can you spend 2 more minues in addition to commenting my ideas and
> help me with writing that 2 lines I missed? Where do I leak memory in
> my driver? Which struct should I kfree?

The structure that you wrap around 'struct device' for your bus.

hope this helps,

greg k-h
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/