From: greg@kroah.com (Greg KH)
To: kernelnewbies@lists.kernelnewbies.org
Subject: Attr Groups in sysfs.
Date: Mon, 18 Apr 2011 09:08:58 -0700 [thread overview]
Message-ID: <20110418160858.GA23968@kroah.com> (raw)
In-Reply-To: <BANLkTi=Nt5wZ4ZXv2Y5efEDDD4_7EBybxw@mail.gmail.com>
On Mon, Apr 18, 2011 at 04:29:57PM +0200, Gasparini Andrea wrote:
> Hi,
>
> On Mon, Apr 18, 2011 at 4:14 PM, Greg KH <greg@kroah.com> wrote:
> >> I'm missing only the myattr_group name... anyone has a clue of how can
> >> I access this?
> >
> > You can't.
>
> ok.
>
> >> And adding to my kobject this way:
> >> ? ? retval = sysfs_create_group(mykobj, &my_attr_group_0);
> >
> > Ick, no, please don't do that, you want the group to be created before
> > the device shows up to userspace, otherwise you just raced with
> > userspace and bad things will happen.
>
> Understand, you're completely right.
> I'll try to refactor in a different way to avoid race.
>
> > Why are you using a struct kobject directly and not a struct device
> > instead? ?Please don't use kobjects unless you are doing something very
> > strange, and even then, please reconsider.
> >
> > Care to explain what you are using sysfs for?
>
> Sure, It's quite complicated, in fact ;)
> I'm doing an "extension" for a video device, in terms of a module that
> handle some addictional logic that do some sort of stats about the
> stream passed through it.
> For example, I've a certain number of areas inside a frame, given in
> form of (x,y,width,heigth) that behave to the same device, so I'd like
> to call them: mydev/region_{0,1,2...}/{x,y,width,height}
>
> That's why I'd like to have the "region_0" name, so I can distinguish
> between the right attribute group.
That's fine, but again, don't use a kobject, use the normal struct
device you already have in your driver for this device.
But wait, don't nest attributes that deep, an attribute group should
only be one level deep on a device, otherwise you are thinking it is a
real device that lives there, and userspace tools might have a hard time
finding the data.
Or, create a new "device" called region_*, attach it to a bus for your
device, and then use the attribute group for that device.
Yeah, it's a bit complex, but you are trying to get sysfs and the driver
model to do things it was not designed for, so you will have to write
more code than you might have thought.
Have you looked at the media device framework that the v4l layer now
provides you? That might have enough functionality for what you are
wanting to do here.
And of course, you need to document your sysfs files properly with
entries in Documentation/ABI/
Good luck,
greg k-h
prev parent reply other threads:[~2011-04-18 16:08 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-04-18 9:45 Attr Groups in sysfs Gasparini Andrea
2011-04-18 14:14 ` Greg KH
2011-04-18 14:29 ` Gasparini Andrea
2011-04-18 16:08 ` Greg KH [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20110418160858.GA23968@kroah.com \
--to=greg@kroah.com \
--cc=kernelnewbies@lists.kernelnewbies.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).