lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <YzNvSMoqZUCN+BkW@ishi>
Date:   Tue, 27 Sep 2022 17:46:48 -0400
From:   William Breathitt Gray <wbg@...nel.org>
To:     linux-iio@...r.kernel.org
Cc:     linux-kernel@...r.kernel.org, mranostay@...com,
        jpanis@...libre.com, gwendal@...omium.org, bleung@...omium.org,
        groeck@...omium.org, jic23@...nel.org, david@...hnology.com,
        robertcnelson@...il.com
Subject: Re: [PATCH v6 0/5] Add support for Counter array components

On Mon, Sep 26, 2022 at 11:16:33AM -0400, William Breathitt Gray wrote:
> Changes in v6:
>  - Rebase on latest counter-next branch
>  - Add ABI Documentation lines for capture_component_id and
>    polarity_component_id
> 
> The COUNTER_COMP_ARRAY Counter component type is introduced to enable
> support for Counter array components. With Counter array components,
> exposure for buffers on counter devices can be defined via new Counter
> array component macros. This should simplify code for driver authors who
> would otherwise need to define individual Counter components for each
> array element.
> 
> Eight Counter array component macros are introduced::
> 
>         DEFINE_COUNTER_ARRAY_U64(_name, _length)
>         DEFINE_COUNTER_ARRAY_CAPTURE(_name, _length)
>         DEFINE_COUNTER_ARRAY_POLARITY(_name, _enums, _length)
>         COUNTER_COMP_DEVICE_ARRAY_U64(_name, _read, _write, _array)
>         COUNTER_COMP_COUNT_ARRAY_U64(_name, _read, _write, _array)
>         COUNTER_COMP_SIGNAL_ARRAY_U64(_name, _read, _write, _array)
>         COUNTER_COMP_ARRAY_CAPTURE(_read, _write, _array)
>         COUNTER_COMP_ARRAY_POLARITY(_read, _write, _array)
> 
> Eight Counter array callbacks are introduced as well::
> 
>         int (*signal_array_u32_read)(struct counter_device *counter,
>                                      struct counter_signal *signal,
>                                      size_t idx, u32 *val);
>         int (*signal_array_u32_write)(struct counter_device *counter,
>                                       struct counter_signal *signal,
>                                       size_t idx, u32 val);
>         int (*device_array_u64_read)(struct counter_device *counter,
>                                      size_t idx, u64 *val);
>         int (*count_array_u64_read)(struct counter_device *counter,
>                                     struct counter_count *count,
>                                     size_t idx, u64 *val);
>         int (*signal_array_u64_read)(struct counter_device *counter,
>                                      struct counter_signal *signal,
>                                      size_t idx, u64 *val);
>         int (*device_array_u64_write)(struct counter_device *counter,
>                                       size_t idx, u64 val);
>         int (*count_array_u64_write)(struct counter_device *counter,
>                                      struct counter_count *count,
>                                      size_t idx, u64 val);
>         int (*signal_array_u64_write)(struct counter_device *counter,
>                                       struct counter_signal *signal,
>                                       size_t idx, u64 val);
> 
> Driver authors can handle reads/writes for an array component by
> receiving an element index via the `idx` parameter and processing the
> respective value via the `val` parameter.
> 
> For example, suppose a driver wants to expose a Count's read-only
> capture buffer of four elements using a callback
> `foobar_capture_read()`::
> 
>         DEFINE_COUNTER_ARRAY_CAPTURE(foobar_capture_array, 4);
>         COUNTER_COMP_ARRAY_CAPTURE(foobar_capture_read, NULL,
>                                    foobar_capture_array)
> 
> Respective sysfs attributes for each array element would appear for the
> respective Count:
> 
> * /sys/bus/counter/devices/counterX/countY/capture0
> * /sys/bus/counter/devices/counterX/countY/capture1
> * /sys/bus/counter/devices/counterX/countY/capture2
> * /sys/bus/counter/devices/counterX/countY/capture3
> 
> If a user tries to read _capture2_ for example, `idx` will be `2` when
> passed to the `foobar_capture_read()` callback, and thus the driver
> knows which array element to handle.
> 
> In addition, this patchset introduces the Signal polarity component,
> which represents the active level of a respective Signal. There are two
> possible states: positive (rising edge) and negative (falling edge). The
> 104-quad-8 driver is updated to expose its index_polarity functionality
> via this new polarity component.
> 
> Counter arrays for polarity elements can be defined in a similar
> manner as u64 elements::
> 
>         const enum counter_signal_polarity foobar_polarity_states[] = {
>                 COUNTER_SIGNAL_POLARITY_POSITIVE,
>                 COUNTER_SIGNAL_POLARITY_NEGATIVE,
>         };
>         DEFINE_COUNTER_ARRAY_POLARITY(foobar_polarity_array,
>                                       foobar_polarity_states, 4);
>         COUNTER_COMP_ARRAY_POLARITY(foobar_polarity_read,
>                                     foobar_polarity_write,
>                                     foobar_polarity_array)
> 
> The only component types supported for Counter arrays currently are
> COUNTER_COMP_U64 and COUNTER_COMP_SIGNAL_POLARITY.
> 
> William Breathitt Gray (5):
>   counter: Introduce the Signal polarity component
>   counter: 104-quad-8: Add Signal polarity component
>   counter: Introduce the Count capture component
>   counter: Consolidate Counter extension sysfs attribute creation
>   counter: Introduce the COUNTER_COMP_ARRAY component type
> 
>  Documentation/ABI/testing/sysfs-bus-counter |  21 ++
>  drivers/counter/104-quad-8.c                |  35 +++
>  drivers/counter/counter-chrdev.c            | 135 +++++++--
>  drivers/counter/counter-sysfs.c             | 304 ++++++++++++++++----
>  include/linux/counter.h                     | 147 ++++++++++
>  include/uapi/linux/counter.h                |   8 +
>  6 files changed, 583 insertions(+), 67 deletions(-)
> 
> 
> base-commit: 7d333188e1d048457572d3a7d0630cd7b91f902d
> -- 
> 2.37.3

Queued for counter-next.

William Breathitt Gray

Download attachment "signature.asc" of type "application/pgp-signature" (229 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ