From: Andy Shevchenko <andriy.shevchenko@intel.com>
To: "Jean-François Lessard" <jefflessard3@gmail.com>
Cc: Andy Shevchenko <andy@kernel.org>,
Geert Uytterhoeven <geert@linux-m68k.org>,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH 4/5] auxdisplay: linedisp: support attribute attachment to auxdisplay devices
Date: Tue, 2 Sep 2025 13:18:24 +0300 [thread overview]
Message-ID: <aLbEcN44RT58ywzq@smile.fi.intel.com> (raw)
In-Reply-To: <20250901020033.60196-5-jefflessard3@gmail.com>
On Sun, Aug 31, 2025 at 10:00:28PM -0400, Jean-François Lessard wrote:
> Enable linedisp library integration into existing kernel devices (like LED
> class) to provide a uniform 7-segment userspace API without creating
> separate child devices, meeting the consistent interface while maintaining
> coherent device hierarchies.
>
> This allows uniform 7-segment API across all drivers while solving device
> proliferation and fragmented userspace interfaces.
>
> The provided attributes appear in two locations depending on usage:
You wanted to say "...in one of the two possible..."?
Otherwise it looks like undesired side effect of the change.
> 1. On linedisp.N child devices (legacy linedisp_register())
> 2. On the parent auxdisplay device (new linedisp_attach())
> Functionality is identical in both modes.
>
> Existing consumers of linedisp_register() are unaffected. The new API
> enables drivers like TM16XX to integrate 7-segment display functionality
> seamlessly within their LED class device hierarchy.
...
> +struct linedisp_attachment {
> + struct list_head list;
> + struct device *device;
> + struct linedisp *linedisp;
> + bool owns_device; /* true for child device mode, false for attached mode */
I would rename this to
bool attached; // with inverted logic
or
bool mode; // with "default" (false) mode to be actually legacy one
(so in both cases I think we want false for the legacy mode).
> +};
...
> +static DEFINE_SPINLOCK(linedisp_attachments_lock);
Why spin lock and not mutex?
...
> +/**
> + * linedisp_attach - attach a character line display
> + * @linedisp: pointer to character line display structure
> + * @dev: pointer of the device to attach to
> + * @num_chars: the number of characters that can be displayed
> + * @ops: character line display operations
> + *
Can you add a description here, please? Important note that it should be freed
by the respective API afterwards.
> + * Return: zero on success, else a negative error code.
> + */
...
> + /* add attribute groups to target device */
> + err = device_add_groups(dev, linedisp_groups);
> + if (err)
> + goto out_del_attach;
> +
> + /* display a default message */
> + err = linedisp_display(linedisp, LINEDISP_INIT_TEXT, -1);
> + if (err)
> + goto out_rem_groups;
Can this be racy with user space? Once we publish attributes, the new
message can be already issued and here it puts another message.
OTOH this is done before device_add(), so the attributes are not visible
until the device is added.
...
> +void linedisp_detach(struct device *dev)
> +{
> + struct linedisp *linedisp = delete_attachment(dev, false);
> +
> + if (!linedisp)
> + return;
Please, rewrite as
struct linedisp *linedisp;
linedisp = delete_attachment(dev, false);
if (!linedisp)
return;
> + timer_delete_sync(&linedisp->timer);
> +
> + device_remove_groups(dev, linedisp_groups);
> +
> + kfree(linedisp->map);
> + kfree(linedisp->message);
> + kfree(linedisp->buf);
> +}
--
With Best Regards,
Andy Shevchenko
next prev parent reply other threads:[~2025-09-02 10:18 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-01 2:00 [PATCH 0/5] auxdisplay: linedisp: support attribute attachment to auxdisplay devices Jean-François Lessard
2025-09-01 2:00 ` [PATCH 1/5] auxdisplay: linedisp: encapsulate container_of usage within to_linedisp Jean-François Lessard
2025-09-01 2:00 ` [PATCH 2/5] auxdisplay: linedisp: display static message when length <= display size Jean-François Lessard
2025-09-02 10:03 ` Andy Shevchenko
2025-09-02 17:12 ` Jean-François Lessard
2025-09-01 2:00 ` [PATCH 3/5] auxdisplay: linedisp: add num_chars sysfs attribute Jean-François Lessard
2025-09-02 10:04 ` Andy Shevchenko
2025-09-02 17:15 ` Jean-François Lessard
2025-09-01 2:00 ` [PATCH 4/5] auxdisplay: linedisp: support attribute attachment to auxdisplay devices Jean-François Lessard
2025-09-02 10:18 ` Andy Shevchenko [this message]
2025-09-02 17:37 ` Jean-François Lessard
2025-09-03 10:18 ` Andy Shevchenko
2025-09-03 11:31 ` Jean-François Lessard
2025-09-01 2:00 ` [PATCH 5/5] docs: ABI: auxdisplay: document linedisp library sysfs attributes Jean-François Lessard
2025-09-02 10:59 ` Andy Shevchenko
2025-09-02 17:42 ` Jean-François Lessard
2025-09-02 11:00 ` [PATCH 0/5] auxdisplay: linedisp: support attribute attachment to auxdisplay devices Andy Shevchenko
2025-09-02 17:44 ` Jean-François Lessard
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=aLbEcN44RT58ywzq@smile.fi.intel.com \
--to=andriy.shevchenko@intel.com \
--cc=andy@kernel.org \
--cc=geert@linux-m68k.org \
--cc=jefflessard3@gmail.com \
--cc=linux-kernel@vger.kernel.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).