From: Jonathan Cameron <jic23@kernel.org>
To: Sanjay Chitroda <sanjayembeddedse@gmail.com>
Cc: Christophe JAILLET <christophe.jaillet@wanadoo.fr>,
jikos@kernel.org, srinivas.pandruvada@linux.intel.com,
dlechner@baylibre.com, nuno.sa@analog.com, andy@kernel.org,
sakari.ailus@linux.intel.com, linux-input@vger.kernel.org,
linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v4 35/36] iio: pressure: hid-sensor-press: drop hid_sensor_remove_trigger() using devm API
Date: Tue, 26 May 2026 16:54:51 +0100 [thread overview]
Message-ID: <20260526165451.6a587221@jic23-huawei> (raw)
In-Reply-To: <39A229F0-436E-4AAC-82A4-9B04733E9EE3@gmail.com>
On Mon, 25 May 2026 22:35:50 +0530
Sanjay Chitroda <sanjayembeddedse@gmail.com> wrote:
> On 25 May 2026 3:39:11 pm IST, Christophe JAILLET <christophe.jaillet@wanadoo.fr> wrote:
> >Le 24/05/2026 à 21:29, Sanjay Chitroda a écrit :
> >> From: Sanjay Chitroda <sanjayembeddedse@gmail.com>
> >>
> >> Use devm_hid_sensor_setup_trigger() to automatically release resource
> >> during fail, unbind or removal of driver using devres framework.
> >>
> >> This simplify the setup, remove goto, avoid manual resource cleanup in
> >> teardown path.
> >>
> >> Signed-off-by: Sanjay Chitroda <sanjayembeddedse@gmail.com>
> >> ---
> >> drivers/iio/pressure/hid-sensor-press.c | 10 +++-------
> >> 1 file changed, 3 insertions(+), 7 deletions(-)
> >>
> >> diff --git a/drivers/iio/pressure/hid-sensor-press.c b/drivers/iio/pressure/hid-sensor-press.c
> >> index fee7dcb86801..8438498c9aeb 100644
> >> --- a/drivers/iio/pressure/hid-sensor-press.c
> >> +++ b/drivers/iio/pressure/hid-sensor-press.c
> >> @@ -291,8 +291,8 @@ static int hid_press_probe(struct platform_device *pdev)
> >> atomic_set(&press_state->common_attributes.data_ready, 0);
> >> - ret = hid_sensor_setup_trigger(indio_dev, name,
> >> - &press_state->common_attributes);
> >> + ret = devm_hid_sensor_setup_trigger(dev, indio_dev, name,
> >> + &press_state->common_attributes);
> >> if (ret) {
> >> dev_err(dev, "trigger setup failed\n");
> >> return ret;
> >> @@ -301,7 +301,7 @@ static int hid_press_probe(struct platform_device *pdev)
> >> ret = iio_device_register(indio_dev);
> >
> >Hi,
> >
> >Looks like devm_iio_device_register() would now make sense and simplify things even further.
> >
> >CJ
>
> Hi CJ,
>
> Yes, as mentioned in cover letter most of HID IIO drivers have potential and will converted to devm based driver gradually.
This is putting a lot of churn and many patches on a critical driver
(given this device is in a lot of laptops). As such I think it's fine
to do prep for devm in separate changes, but the final per driver change
should be one per driver to go fully devm rather than doing it in smaller
chunks. I obviously want to see this well tested, and don't want to have
to keep asking people to test 'the next' set of changes.
Jonathan
>
> Welcoming all suggestions and especially if someone can validate and have Tested-by tag.
>
> Thank, Sanjay
>
> >
> >> if (ret) {
> >> dev_err(dev, "device register failed\n");
> >> - goto error_remove_trigger;
> >> + return ret;
> >> }
> >> press_state->callbacks.send_event = press_proc_event;
> >> @@ -318,8 +318,6 @@ static int hid_press_probe(struct platform_device *pdev)
> >> error_iio_unreg:
> >> iio_device_unregister(indio_dev);
> >> -error_remove_trigger:
> >> - hid_sensor_remove_trigger(&press_state->common_attributes);
> >> return ret;
> >> }
> >> @@ -328,11 +326,9 @@ static void hid_press_remove(struct platform_device *pdev)
> >> {
> >> struct hid_sensor_hub_device *hsdev = dev_get_platdata(&pdev->dev);
> >> struct iio_dev *indio_dev = platform_get_drvdata(pdev);
> >> - struct press_state *press_state = iio_priv(indio_dev);
> >> sensor_hub_remove_callback(hsdev, HID_USAGE_SENSOR_PRESSURE);
> >> iio_device_unregister(indio_dev);
> >> - hid_sensor_remove_trigger(&press_state->common_attributes);
> >> }
> >> static const struct platform_device_id hid_press_ids[] = {
> >
next prev parent reply other threads:[~2026-05-26 15:55 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-24 19:29 [PATCH v4 30/36] iio: light: hid-sensor-als: drop hid_sensor_remove_trigger() using devm API Sanjay Chitroda
2026-05-24 19:29 ` [PATCH v4 31/36] iio: magnetometer: hid-sensor-magn-3d: " Sanjay Chitroda
2026-05-24 19:29 ` [PATCH v4 32/36] iio: orientation: hid-sensor-incl-3d: " Sanjay Chitroda
2026-05-24 19:29 ` [PATCH v4 33/36] iio: orientation: hid-sensor-rotation: " Sanjay Chitroda
2026-05-24 19:29 ` [PATCH v4 34/36] iio: position: hid-sensor-custom-intel-hinge: " Sanjay Chitroda
2026-05-24 19:29 ` [PATCH v4 35/36] iio: pressure: hid-sensor-press: " Sanjay Chitroda
2026-05-25 10:09 ` Christophe JAILLET
2026-05-25 17:05 ` Sanjay Chitroda
2026-05-26 15:54 ` Jonathan Cameron [this message]
2026-05-26 18:16 ` Sanjay Chitroda
2026-05-24 19:29 ` [PATCH v4 36/36] iio: temperature: hid-sensor-temperature: " Sanjay Chitroda
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=20260526165451.6a587221@jic23-huawei \
--to=jic23@kernel.org \
--cc=andy@kernel.org \
--cc=christophe.jaillet@wanadoo.fr \
--cc=dlechner@baylibre.com \
--cc=jikos@kernel.org \
--cc=linux-iio@vger.kernel.org \
--cc=linux-input@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=nuno.sa@analog.com \
--cc=sakari.ailus@linux.intel.com \
--cc=sanjayembeddedse@gmail.com \
--cc=srinivas.pandruvada@linux.intel.com \
/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