devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: "Vesa Jääskeläinen" <dachaac-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
To: Lars-Peter Clausen <lars-Qo5EllUWu/uELgA04lAiVw@public.gmane.org>,
	linux-iio-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	"devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org"
	<devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>
Subject: Re: IIO device indexing issue
Date: Wed, 4 Nov 2015 20:53:06 +0200	[thread overview]
Message-ID: <563A5412.4030102@gmail.com> (raw)
In-Reply-To: <5639D22D.3050901-Qo5EllUWu/uELgA04lAiVw@public.gmane.org>

On 04/11/15 11:38, Lars-Peter Clausen wrote:
> On 11/02/2015 07:47 PM, Vesa Jääskeläinen wrote:
>> Hi,
>>
>> When we were using kernel 3.2 and with that board files we just got IIO
>> devices with static order so that we knew exactly what iio:device0 is.
>>
>> Now with device tree that order is not so static anymore especially when
>> using device overlays (have not yet tried that thou). If there would be
>> deferred probe for the device then if we have multiple iio:device's then
>> those could in theory be in any order.
>>
>> In example libiio uses iio device index to open the IIO device. So the
>> problem is to know what iio:device is what.
>>
>> If we look files under /sys/bus/iio/iio:deviceX. They do not reveal what
>> device this is (especially if there are multiple device of same type). There
>> does not seem to be a way to give custom name for the iio device from device
>> tree that could have been used as a cue.
>>
>> Device tree aliases kinda sounded a good idea to try. Eg. define adc0 alias
>> and then link it to actual device node in tree.
>>
>> Aliases could be found under /proc/device-tree/aliases. Looking at it shows
>> what device tree node it is. However there does not seem to be actual link
>> from any /proc/device-tree entries to kernel drivers exposed under sysfs.
>> And even the path components in device tree are not in same format as in
>> sysfs. So there is no 1:1 mapping possible here.
>>
>> IIO devices in /sys/bus/iio/iio:deviceX seem to be symlinks to actual
>> devices under /sys/devices and from there is physical path to the device and
>> under that the IIO device with the same name as is under /sys/bus/iio.
>>
>> So in theory we could make a mapping configuration file that specifies
>> logical name for iio device and then physical parent path for the device and
>> then find under it iio:device* files to determine what is the iio device
>> index for this physical device. Then open IIO device with that index in
>> example with libiio. Sounds a bit complex?
>>
>> So did we miss something on how this should be defined/accessed or is there
>> a slight issue here on how to identify iio devices?
>>
>> Don't know how device tree overlays affect this if we first load device tree
>> overlay with some configuration and then unload it and load another one with
>> different configuration.
> Hi,
>
> Yes, excellent analysis. This is a real issue. As you said there is no
> guarantee that the IIO device numbers are stable, they are assigned in the
> order the devices are registered. If the device are registered in a
> different order for whatever reason the numbers will change. You can use
> readlink on the IIO device in /sys/bus/iio/devices to get its position in
> the global device topology and be able to tell what the parent device is,
> but this path might not be completely stable either though. E.g. if your
> device is on a I2C bus and the number of the I2C bus is dynamically assigned
> it might change when the probe order changes.
>
> Alias seem to be one way to solve this issue. The big question remains is
> how to communicate the alias to userspace. For other device classes the
> alias index is used as the device index e.g. a device with alias i2c0 ends
> up being the i2c adapter with index 0. But with IIO where we support a wide
> range of different devices that does not really work. E.g. what to do if you
> have adc0 and dac0 as aliases for different devices. So you'd need a
> different way to expose the alias.
>
> Some bindings also use the "label" property to assign a unique name to node.
> But again the same issue how to expose that information to applications.
>
To continue from this "label" property idea I was wondering if we would 
add it as new optional(?) file node for IIO devices.

One could then specify it like:

tscadc: tscadc@44e0d000 {
     compatible = "ti,am3359-tscadc";
...
     am335x_adc: adc {
         compatible = "ti,am3359-adc";
...
         label = "Port A";
     };
};

And this would generate file /sys/bus/iio/iio:deviceX/label with 
contents of "Port A".

Then during the application startup it would just need to scan all 
devices under /sys/bus/iio and determine what labelled device it wants 
to use.

It would be up to device's developer to determine what labels to use in 
their designs. This would not break ABI and would be just an extension 
for it.

One could also auto-assign label "am335x_adc" in this case too. But if 
you include existing arch device tree then changing label in top level 
is kinda a bit annoying as you would then need to duplicate all 
properties with another label and disable arch device tree's settings. 
Could cause also conflict if there are references elsewhere to existing 
arch nodes.

Having following in device's device tree file would allow one to 
override label or just only specify that.

#include "am33xx.dtsi"

&tscadc {
     status = "okay";

     adc {
         ti,adc-channels = <4 5 6 7>;

         label = "Port A";
     };
};

I think this "label" model would be simple to understand.

Whether this needs to be implemented as per device driver feature or 
could be implemented as generic IIO functionality I do not know.

Thanks,
Vesa Jääskeläinen

--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

  parent reply	other threads:[~2015-11-04 18:53 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <5637AFC5.7080007@gmail.com>
     [not found] ` <5637AFC5.7080007-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-11-04  9:38   ` IIO device indexing issue Lars-Peter Clausen
     [not found]     ` <5639D22D.3050901-Qo5EllUWu/uELgA04lAiVw@public.gmane.org>
2015-11-04 18:53       ` Vesa Jääskeläinen [this message]
     [not found]         ` <563A5412.4030102-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-11-05  1:25           ` Phil Reid
     [not found]             ` <563AB014.4030401-qgqNFa1JUf/o2iN0hyhwsIdd74u8MsAO@public.gmane.org>
2015-11-05  5:24               ` Phil Reid
2015-11-05 19:13           ` Jonathan Cameron
     [not found]             ` <563BAA65.3020609-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2015-11-06  9:49               ` Markus Pargmann
2015-11-07  9:03                 ` Vesa Jääskeläinen
     [not found]                   ` <563DBE5E.6060307-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2015-11-09 10:33                     ` Markus Pargmann

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=563A5412.4030102@gmail.com \
    --to=dachaac-re5jqeeqqe8avxtiumwx3w@public.gmane.org \
    --cc=devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=lars-Qo5EllUWu/uELgA04lAiVw@public.gmane.org \
    --cc=linux-iio-u79uwXL29TY76Z2rM5mHXA@public.gmane.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).