From: Wilken Gottwalt <wilken.gottwalt@posteo.net>
To: Li Zetao <lizetao1@huawei.com>
Cc: <jikos@kernel.org>, <bentiss@kernel.org>,
<michael.zaidman@gmail.com>, <gupt21@gmail.com>,
<djogorchock@gmail.com>, <rrameshbabu@nvidia.com>,
<bonbons@linux-vserver.org>, <roderick.colenbrander@sony.com>,
<david@readahead.eu>, <savicaleksa83@gmail.com>,
<me@jackdoan.com>, <jdelvare@suse.com>, <linux@roeck-us.net>,
<mail@mariuszachmann.de>, <jonas@protocubo.io>,
<mezin.alexander@gmail.com>, <linux-input@vger.kernel.org>,
<linux-i2c@vger.kernel.org>, <linux-hwmon@vger.kernel.org>
Subject: Re: [PATCH -next 15/19] hwmon: (corsair-psu) Use devm_hid_hw_start_and_open in corsairpsu_probe()
Date: Fri, 6 Sep 2024 04:03:38 +0000 [thread overview]
Message-ID: <20240906060338.0e1aecdc@posteo.net> (raw)
In-Reply-To: <20240904123607.3407364-16-lizetao1@huawei.com>
On Wed, 4 Sep 2024 20:36:03 +0800
Li Zetao <lizetao1@huawei.com> wrote:
> Currently, the corsair-psu module needs to maintain hid resources
> by itself. Consider using devm_hid_hw_start_and_open helper to ensure
> that hid resources are consistent with the device life cycle, and release
> hid resources before device is released. At the same time, it can avoid
> the goto-release encoding, drop the fail_and_close and fail_and_stop
> lables, and directly return the error code when an error occurs.
>
> Signed-off-by: Li Zetao <lizetao1@huawei.com>
> ---
> drivers/hwmon/corsair-psu.c | 24 +++++-------------------
> 1 file changed, 5 insertions(+), 19 deletions(-)
>
> diff --git a/drivers/hwmon/corsair-psu.c b/drivers/hwmon/corsair-psu.c
> index f8f22b8a67cd..b574ec9cd00f 100644
> --- a/drivers/hwmon/corsair-psu.c
> +++ b/drivers/hwmon/corsair-psu.c
> @@ -787,14 +787,10 @@ static int corsairpsu_probe(struct hid_device *hdev, const struct
> hid_device_id if (ret)
> return ret;
>
> - ret = hid_hw_start(hdev, HID_CONNECT_HIDRAW);
> + ret = devm_hid_hw_start_and_open(hdev, HID_CONNECT_HIDRAW);
> if (ret)
> return ret;
>
> - ret = hid_hw_open(hdev);
> - if (ret)
> - goto fail_and_stop;
> -
> priv->hdev = hdev;
> hid_set_drvdata(hdev, priv);
> mutex_init(&priv->lock);
> @@ -805,13 +801,13 @@ static int corsairpsu_probe(struct hid_device *hdev, const struct
> hid_device_id ret = corsairpsu_init(priv);
> if (ret < 0) {
> dev_err(&hdev->dev, "unable to initialize device (%d)\n", ret);
> - goto fail_and_stop;
> + return ret;
> }
>
> ret = corsairpsu_fwinfo(priv);
> if (ret < 0) {
> dev_err(&hdev->dev, "unable to query firmware (%d)\n", ret);
> - goto fail_and_stop;
> + return ret;
> }
>
> corsairpsu_get_criticals(priv);
> @@ -820,20 +816,12 @@ static int corsairpsu_probe(struct hid_device *hdev, const struct
> hid_device_id priv->hwmon_dev = hwmon_device_register_with_info(&hdev->dev, "corsairpsu", priv,
> &corsairpsu_chip_info, NULL);
>
> - if (IS_ERR(priv->hwmon_dev)) {
> - ret = PTR_ERR(priv->hwmon_dev);
> - goto fail_and_close;
> - }
> + if (IS_ERR(priv->hwmon_dev))
> + return PTR_ERR(priv->hwmon_dev);
>
> corsairpsu_debugfs_init(priv);
>
> return 0;
> -
> -fail_and_close:
> - hid_hw_close(hdev);
> -fail_and_stop:
> - hid_hw_stop(hdev);
> - return ret;
> }
>
> static void corsairpsu_remove(struct hid_device *hdev)
> @@ -842,8 +830,6 @@ static void corsairpsu_remove(struct hid_device *hdev)
>
> debugfs_remove_recursive(priv->debugfs);
> hwmon_device_unregister(priv->hwmon_dev);
> - hid_hw_close(hdev);
> - hid_hw_stop(hdev);
> }
>
> static int corsairpsu_raw_event(struct hid_device *hdev, struct hid_report *report, u8 *data,
So far looks fine to me.
Reviewed-by: Wilken Gottwalt <wilken.gottwalt@posteo.net>
greetings,
Wilken
next prev parent reply other threads:[~2024-09-06 4:03 UTC|newest]
Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-09-04 12:35 [PATCH -next 00/19] HID: convert to devm_hid_hw_start_and_open() Li Zetao
2024-09-04 12:35 ` [PATCH -next 01/19] HID: core: Use devm_add_action_or_reset helper to manage hid resources Li Zetao
2024-09-05 12:53 ` Benjamin Tissoires
2024-09-05 15:41 ` Li Zetao
2024-09-04 12:35 ` [PATCH -next 02/19] HID: cp2112: Use devm_hid_hw_start_and_open in cp2112_probe() Li Zetao
2024-09-04 12:35 ` [PATCH -next 03/19] HID: ft260: Use devm_hid_hw_start_and_open in ft260_probe() Li Zetao
2024-09-04 12:35 ` [PATCH -next 04/19] HID: mcp2200: Use devm_hid_hw_start_and_open in mcp2200_probe() Li Zetao
2024-09-04 12:35 ` [PATCH -next 05/19] HID: mcp2221: Use devm_hid_hw_start_and_open in mcp2221_probe() Li Zetao
2024-09-04 12:35 ` [PATCH -next 06/19] HID: nintendo: Use devm_hid_hw_start_and_open in nintendo_hid_probe() Li Zetao
2024-09-04 12:35 ` [PATCH -next 07/19] HID: shield: Use devm_hid_hw_start_and_open in shield_probe() Li Zetao
2024-09-05 12:57 ` Benjamin Tissoires
2024-09-04 12:35 ` [PATCH -next 08/19] HID: hid-picolcd: Use devm_hid_hw_start_and_open in picolcd_probe() Li Zetao
2024-09-05 12:59 ` Benjamin Tissoires
2024-09-04 12:35 ` [PATCH -next 09/19] HID: playstation: Use devm_hid_hw_start_and_open in ps_probe() Li Zetao
2024-09-04 12:35 ` [PATCH -next 10/19] HID: hid-steam: Use devm_hid_hw_start_and_open in steam_probe() Li Zetao
2024-09-05 13:00 ` Benjamin Tissoires
2024-09-04 12:35 ` [PATCH -next 11/19] HID: wiimote: Use devm_hid_hw_start_and_open in wiimote_hid_probe() Li Zetao
2024-09-05 6:35 ` David Rheinsberg
2024-09-05 13:05 ` Benjamin Tissoires
2024-09-04 12:36 ` [PATCH -next 12/19] hwmon: (aquacomputer_d5next) Use devm_hid_hw_start_and_open in aqc_probe() Li Zetao
2024-09-04 12:36 ` [PATCH -next 13/19] hwmon: Use devm_hid_hw_start_and_open in rog_ryujin_probe() Li Zetao
2024-09-04 14:20 ` Guenter Roeck
2024-09-04 12:36 ` [PATCH -next 14/19] hwmon: (corsair-cpro) Use devm_hid_hw_start_and_open in ccp_probe() Li Zetao
2024-09-04 12:36 ` [PATCH -next 15/19] hwmon: (corsair-psu) Use devm_hid_hw_start_and_open in corsairpsu_probe() Li Zetao
2024-09-06 4:03 ` Wilken Gottwalt [this message]
2024-09-04 12:36 ` [PATCH -next 16/19] hwmon: (gigabyte_waterforce) Use devm_hid_hw_start_and_open in waterforce_probe() Li Zetao
2024-09-04 12:36 ` [PATCH -next 17/19] hwmon: (nzxt-kraken2) Use devm_hid_hw_start_and_open in kraken2_probe() Li Zetao
2024-09-04 14:17 ` Guenter Roeck
2024-09-04 12:36 ` [PATCH -next 18/19] hwmon: (nzxt-kraken3) Use devm_hid_hw_start_and_open in kraken3_probe() Li Zetao
2024-09-04 12:36 ` [PATCH -next 19/19] hwmon: (nzxt-smart2) Use devm_hid_hw_start_and_open in nzxt_smart2_hid_probe() Li Zetao
2024-09-04 14:14 ` Guenter Roeck
2024-09-05 15:39 ` Li Zetao
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=20240906060338.0e1aecdc@posteo.net \
--to=wilken.gottwalt@posteo.net \
--cc=bentiss@kernel.org \
--cc=bonbons@linux-vserver.org \
--cc=david@readahead.eu \
--cc=djogorchock@gmail.com \
--cc=gupt21@gmail.com \
--cc=jdelvare@suse.com \
--cc=jikos@kernel.org \
--cc=jonas@protocubo.io \
--cc=linux-hwmon@vger.kernel.org \
--cc=linux-i2c@vger.kernel.org \
--cc=linux-input@vger.kernel.org \
--cc=linux@roeck-us.net \
--cc=lizetao1@huawei.com \
--cc=mail@mariuszachmann.de \
--cc=me@jackdoan.com \
--cc=mezin.alexander@gmail.com \
--cc=michael.zaidman@gmail.com \
--cc=roderick.colenbrander@sony.com \
--cc=rrameshbabu@nvidia.com \
--cc=savicaleksa83@gmail.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;
as well as URLs for NNTP newsgroup(s).