Re: [PATCH] RFC: Attributes in /sys/cdev

From: Jonathan Corbet
Date: Mon Sep 22 2003 - 16:16:38 EST


Forgive my insistence here...I'm trying to figure out what LDD3 is going to
say on this subject. If we get it right, hopefully that will head off a
lot of questions in the future...

> > If I embed a struct cdev within my own
> > device structure, how do I know when I can safely free said device
> > structure? Will there be a release method that gets exposed at the driver
> > level, or am I missing something obvious again?
>
> Umm... Any kobject has ->release() method, obviously.

Actually, as I read it, each kobject has a kobj_type pointer, and in *that*
structure is a release() method. I had found it...:)

The struct cdev which I, as a driver author, can embed within my own
structure has a kobject in it. If it's an embedded cdev, its ktype pointer
will be aimed at ktype_cdev_default, which sets up cdev_default_release()
as its release function.

If I understand things correctly, as long as references to the embedded
struct cdev remain, I cannot free the driver-specific structure in which
the struct cdev is embedded. So, somehow, I need to know when that struct
cdev's release() method is called. I could do that by changing its ktype
field to my own special type, and remembering to call cdev_purge() in my
own release function. Somehow, however, that doesn't feel like the right
approach. It seems to me like we need a release() method in struct cdev
that is called from the struct cdev's own release() method - at least, in
the non-dynamic case. No? What am I missing here?

Thanks,

jon

Jonathan Corbet
Executive editor, LWN.net
corbet@xxxxxxx
-
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/