[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1175278774.3760.44.camel@mulgrave.il.steeleye.com>
Date: Fri, 30 Mar 2007 13:19:34 -0500
From: James Bottomley <James.Bottomley@...elEye.com>
To: Tejun Heo <htejun@...il.com>
Cc: gregkh@...e.de, hugh@...itas.com, cornelia.huck@...ibm.com,
dmitry.torokhov@...il.com, oneukum@...e.de, maneesh@...ibm.com,
rpurdie@...ys.net, Jeff Garzik <jgarzik@...ox.com>,
lkml <linux-kernel@...r.kernel.org>,
"linux-ide@...r.kernel.org" <linux-ide@...r.kernel.org>,
SCSI Mailing List <linux-scsi@...r.kernel.org>
Subject: Re: [RFD driver-core] Lifetime problems of the current driver model
On Fri, 2007-03-30 at 22:38 +0900, Tejun Heo wrote:
> My plan was to make sysfs more independent from struct device/kobject.
> e.g. Something like the following.
That's sort of what I was reaching for too ... it just looks to me that
all the sysfs glue is in kobject, so they make a good candidate for the
pure sysfs objects. Whatever we do, there has to be breakable cross
linking between the driver's tree and the sysfs representation ... of
course, nasty things like ksets get in the way of considering the
objects as separate, sigh.
> * kobject_get() on attr/symlink creation
> * open() doesn't need extra kobject reference
> * deleting a node makes it release the kobject reference and the kobject
> pointer is nullified.
To do this, you'll have to move at least the dentry out of the kobject,
I think.
> This way the sysfs reference counting can be put completely out of
> picture without impacting the rest of code. Handling symlink and
> suicidal attributes might need some extra attention but I think they can
> be done.
True ... but you'll also have to implement something within sysfs to do
refcounting ... it needs to know how long to keep its nodes around.
> In the long term, I think sysfs should be independent from driver model
> and kobject such that an entity which wants to use sysfs but is not a
> device doesn't have to dance with kobject just to use sysfs.
I agree ... the question is just how to do it.
I'd favour trying to separate kobject and struct device for this ...
move all the sysfs stuff into kobject and device only stuff into struct
device ... but that would get us into disentangling the ksets, which, on
balance, isn't going to be fun ...
James
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists