1. 12 10月, 2013 1 次提交
    • L
      iio: Extend the event config interface · b4e3ac0a
      Lars-Peter Clausen 提交于
      The event configuration interface of the IIO framework has not been getting the
      same attention as other parts. As a result it has not seen the same improvements
      as e.g. the channel interface has seen with the introduction of the channel spec
      struct. Currently all the event config callbacks take a u64 (the so called event
      code) to pass all the different information about for which event the callback
      is invoked. The callback function then has to extract the information it is
      interested in using some macros with rather long names. Most information encoded
      in the event code comes straight from the iio_chan_spec struct the event was
      registered for. Since we always have a handle to the channel spec when we call
      the event callbacks the first step is to add the channel spec as a parameter to
      the event callbacks. The two remaining things encoded in the event code are the
      type and direction of the event. Instead of passing them in one parameter, add
      one parameter for each of them and remove the eventcode from the event
      callbacks. The patch also adds a new iio_event_info parameter to the
      {read,write}_event_value callbacks. This makes it possible, similar to the
      iio_chan_info_enum for channels, to specify additional properties other than
      just the value for an event. Furthermore the new interface will allow to
      register shared events. This is e.g. useful if a device allows configuring a
      threshold event, but the threshold setting is the same for all channels.
      
      To implement this the patch adds a new iio_event_spec struct which is similar to
      the iio_chan_spec struct. It as two field to specify the type and the direction
      of the event. Furthermore it has a mask field for each one of the different
      iio_shared_by types. These mask fields holds which kind of attributes should be
      registered for the event. Creation of the attributes follows the same rules as
      the for the channel attributes. E.g. for the separate_mask there will be a
      attribute for each channel with this event, for the shared_by_type there will
      only be one attribute per channel type. The iio_chan_spec struct gets two new
      fields, 'event_spec' and 'num_event_specs', which is used to specify which the
      events for this channel. These two fields are going to replace the channel's
      event_mask field.
      
      For now both the old and the new event config interface coexist, but over the
      few patches all drivers will be converted from the old to the new interface.
      Once that is done all code for supporting the old interface will be removed.
      Signed-off-by: NLars-Peter Clausen <lars@metafoo.de>
      Signed-off-by: NJonathan Cameron <jic23@kernel.org>
      b4e3ac0a
  2. 16 9月, 2013 3 次提交
  3. 15 9月, 2013 1 次提交
    • P
      iio: Add INT_TIME (integration time) channel info attribute · 899d90bd
      Peter Meerwald 提交于
      Integration time is in seconds; it controls the measurement
      time and influences the gain of a sensor.
      
      There are two typical ways that scaling is implemented in a device:
      1) input amplifier,
      2) reference to the ADC is changed.
      These both result in the accuracy of the ADC varying (by applying its
      sampling over a more relevant range).
      
      Integration time is a way of dealing with noise inherent in the analog
      sensor itself.  In the case of a light sensor, a mixture of photon noise
      and device specific noise.  Photon noise is dealt with by either improving
      the efficiency of the sensor, (more photons actually captured) which is not
      easily varied dynamically, or by integrating the measurement over a longer
      time period.  Note that this can also be thought of as an averaging of a
      number of individual samples and is infact sometimes implemented this way.
      Altering integration time implies that the duration of a measurement changes,
      a fact the device's user may be interested in.
      
      Hence it makes sense to distinguish between integration time and simple
      scale. In some devices both types of control are present and whilst they
      will have similar effects on the amplitude of the reading, their effect
      on the noise of the measurements will differ considerably.
      
      Used by adjd_s311, tsl4531, tcs3472
      The following drivers have similar controls (and could be adapted):
      * tsl2563 (integration time is controlled via CALIBSCALE among other things)
      * tsl2583 (has integration_time device_attr, but driver doesn't use channels yet)
      * tsl2x7x (has integration_time attr)
      Signed-off-by: NPeter Meerwald <pmeerw@pmeerw.net>
      Cc: Jon Brenner <jon.brenner@ams.com>
      Signed-off-by: NJonathan Cameron <jic23@kernel.org>
      899d90bd
  4. 01 9月, 2013 1 次提交
  5. 18 8月, 2013 1 次提交
  6. 04 8月, 2013 2 次提交
  7. 03 7月, 2013 1 次提交
  8. 18 3月, 2013 2 次提交
  9. 21 11月, 2012 1 次提交
  10. 10 11月, 2012 1 次提交
  11. 19 10月, 2012 1 次提交
  12. 18 9月, 2012 1 次提交
  13. 07 9月, 2012 1 次提交
  14. 04 9月, 2012 3 次提交
  15. 28 8月, 2012 1 次提交
  16. 10 7月, 2012 1 次提交
    • L
      iio: Add callback to check whether a scan mask is valid · 939546d1
      Lars-Peter Clausen 提交于
      This is useful for cases where the number of valid scan masks grows
      exponentially, but it is rather easy to check whether a mask is valid or not
      programmatically.
      
      An example of such a case is a device with multiple ADCs where each ADC has a
      upstream MUX, which allows to select from a number of physical channels.
      
        +-------+   +-------+
        |       |   |       | --- Channel 1
        | ADC 1 |---| MUX 1 | ---   ...
        |       |   |       | --- Channel M
        +-------+   +-------+
      
           .            .            .
           .            .            .
           .            .            .
      
        +-------+   +-------+
        |       |   |       | --- Channel M * N + 1
        | ADC N |---| MUX N | ---       ...
        |       |   |       | --- Channel M * N + M
        +-------+   +-------+
      
      The number of necessary scan masks for this case is (M+1)**N - 1, on the other
      hand it is easy to check whether subsets for each ADC of the scanmask have only
      one bit set.
      Signed-off-by: NLars-Peter Clausen <lars@metafoo.de>
      Signed-off-by: NJonathan Cameron <jic23@kernel.org>
      939546d1
  17. 19 6月, 2012 1 次提交
  18. 13 6月, 2012 4 次提交
  19. 05 6月, 2012 2 次提交
  20. 15 5月, 2012 2 次提交
  21. 30 4月, 2012 3 次提交
  22. 26 4月, 2012 1 次提交
  23. 25 4月, 2012 3 次提交
  24. 19 4月, 2012 2 次提交