> > In our use case the board can be on a machine, but data is analyzed on > > an other one. Again meta-information are fundamental for > > post-analysis of thousands on MB of samples; 2 days later we can't > > query devices to know which was their configuration. We can also use > > meta-information to pre-setup a device output offline, and then > > configure it immediately when is required. > > Agreed. That meta data could mostly be added by the userspace capture > app entirely out of band. It's there until changed. It wouldn't be > inconcievable to add the hooks and a buffer variant to do much the same > in iio. Yes, configuration data is there until changed but it can change really fast and we cannot stop the acquisition to wait user-space data collection. > >> 4) The reason for the weird 'fake' floating point (which I agree is ... > > > > You are right, mircovolt some times are insufficient, but we still... > > Userspace knowing device detail is typically a bad idea for kernel > drivers. You'll get some pushing back on that front! We want the kernel part to remain small and simple. User space has the name in the meta-data, so it will make sense of its stream. I think that drivers should only implement mechanisms to interact with device, very few policies. User-space must know what it is doing and which device it is controlling; intelligence should be in user-space not in kernel, we provide tools, user should know the tool before use it (an hammer can be dangerous if used in the wrong way, so you need to know what is an hammer and how use it ) > >> 6) On the precision control bit I'm a little unclear what you mean but > > Exactly, thus massively increasing your local storge (doubling it for > starters)? There are devices out there that can change over a much wider > range than that. We trade storage for simplicity. You can change resolution on the fly, but the stream will reman 2-bytes per sample. Not set in stone, but it's way simpler for fast development. > > I was meaning spinlock, semaphores and all this stuff. We'd like to > > avoid them in the low-level drivers, as the core should take care > > of all the complexities (as far as possible, obviously). > > The only stuff I think we don't protect in the core that you do is > things like scale factors. In our case perhaps live changes in these > make sense. Maybe in yours ... No. It's just serializing access (more on this later). [about trigger assignment] > >I think I need to do something like the sysfs > > > > trigger; otherwise, why is done in that way for the sysfs trigger? Am > > I wrong? >From your answer, I don't understand if in this case I need to do something like sysfs trigger in IIO. > The reason is there are plenty of setups where you want only one capture > trigger for all your devices. Why create more than one? A battery of the same boards need a single trigger implementation with different instances. With ZIO we allocate both buffer and trigger by instances; when the trigger/buffer change, then the old instance is destroyed and a new one is created. No waste of resources. > >> 13) Event's used to configure a trigger value? I'm not sure what you ... > > > > Isn't this what is done in the max1363 driver? When you configure > > threshold through sysfs, you write the value on device. Aren't you > > configuring a trigger threshold? (I don't know the max1363 > > specification but from the code I suppose you set a register value for > > the threshold event) > > No. You are configuring an event threshold. They are not 'normally' > used as triggers because it has never yet made sense to do so. It is not clear and I don't know device details, just read the driver. But I always abstract a trigger as something that when an event occur, then do something; so, why throw an event if you do "nothing" when it occurs? > >> 14) There is nothing to stop developers declaring chan ... > >> .... > >> If it is very much device specific (and very few things > >> actually are) then there is nothing to stop it being added. > > > > We like to centralize all the sysfs stuff, common attributes and > > specific ones. For our drivers we chose not to require low-level > > developers to write the full sysfs interface. > > Indeed. Nor do we. Only things you have to write are the odd corners > that aren't currently supported by the core. But, as I understand, for the odd corners you need to write the complete sysfs interface for your specific attributes: show, store, register, remove ... > > Boards have many configuration registers and I want to export them to > > the host system through sysfs. To avoid unexpected result I want to > > serialize the register access. Thus the request to handle concurrency > > issues in the core framework. > Agreed, where such issues make sense. Often they don't so you have just > slowed down the access to the device for now purpose. That's why we do > it when necessary in the drivers. Usually configuring means accessing device registers. And this must be serialized, that's the most common case. Sure sometimes our locking slows down without a need but are you really configuring the same device at the same time from two different cores and must do it immediately? Maybe it's different use cases, again. But after all, tasklets and works are serialized, and the slowdown isn't a problem. > > We plan to offer a buffer for each channel and one for interleaving. > > When the acquisition is interleaved, the channel-set is a single > > channel. User-space knows about this and can demux data if it > > wants. (Note, it is not implemented yet. But it is our idea at this point > Is this fully described to userspace? If not you are going to run into > a lot of review feedback that your framework isn't general. People > really don't like userspace code having to match against a specific > driver. A lot of our effort has been around avoiding this requirement. Yes, that's what is being evaluated. With our usual overhead, not good for your use cases (I wouldn't drive an accelerometer with the zio overhead, especially on small systems). Thanks again. -- Federico Vaga -- To unsubscribe from this list: send the line "unsubscribe linux-iio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html