On a train so will reply in more detail later. Maxime Ripard <maxime.ripard@xxxxxxxxxxxxxxxxxx> wrote: >Hi Jonathan, > >Now that the work on the AT91 adc driver using software triggers looks >well on its way to the kernel, I begin to work on hardware triggers for >it. > >Few questions raise though. > >First, it seems that when using hardware triggers, we have to use the >iio ring buffers. There are patches against staging that allow a fake buffer that routes data to input or similar but it looks much the same from the driver. > >So the first implementation that comes to my mind is this one : > - The probe function actually sets up the driver, the triggers, the >buffer, etc. Creates infrastructure etc. > - Each time an interrupt is raised, the handler either fill the buffer >with the values of the activated channels or store it in a temporary >variable just like I'm doing right now for the software triggers. Interupt drives a trigger. That then calls the pollfunc which does the read into the buffer. Note the trigger is associated with the device in userspace so can be provided by any device or indeed fake device. > - When a user reads the sysfs file, either read from the buffer or >from the temporary variable. Yes. > >But : > - Is it the right way to do so with iio ? Not quite as explained... I will take a look at the datasheets later and try and point you at something similar in tree. > - Is there a way for the user to select at runtime if he wants only >software trigger or hardware trigger (if they are enabled in the >kernel) ? Yup. Don't enable the buffer. I need to put in a single scan buffer for in kernel interface anyway so may make sense for you to use that on long run. > - What is the role of this pollfunc defined in the iio_dev struct ? Equivalent of threaded interupt to be run on a data ready or capture now interupt. > >Also, the ADC has 4 external trigger sources, which are selected >through >a register. 3 of them are muxed pins, so the pins available varies from >one board to another. Is there a way for the user at runtime to select >the source he wants ? Yes create lots of triggers. > >Finally, this ADC supports two resolutions : 8 and 10 bit. For now, >only >10 bit resolution is supported, but the user might want to use 8 bit. >Is >there a way to do so ? Never seen a use case for sysfs users. Can in theory control it for buffered data but I think the core support is missing. Sca3000 used to do it. > >Thanks, >Maxime > >-- >Maxime Ripard, Free Electrons >Kernel, drivers, real-time and embedded Linux >development, consulting, training and support. >http://free-electrons.com -- Sent from my Android phone with K-9 Mail. Please excuse my brevity. -- 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