[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20220926202239.16379-3-Enrik.Berkhan@inka.de>
Date: Mon, 26 Sep 2022 22:22:37 +0200
From: Enrik Berkhan <Enrik.Berkhan@...a.de>
To: linux-input@...r.kernel.org
Cc: linux-i2c@...r.kernel.org, linux-kernel@...r.kernel.org,
Rishi Gupta <gupt21@...il.com>,
Enrik Berkhan <Enrik.Berkhan@...a.de>
Subject: [PATCH v1 2/4] HID: mcp2221: enable HID I/O during GPIO probe
As soon as the GPIO driver part will be enabled in mcp2221_probe(), the
first HID reports will be exchanged with the chip because the GPIO
driver immediately calls mcp_gpio_get_direction(). HID I/O has to be
enabled explicitly during mcp2221_probe() to receive response reports.
Otherwise, all four mcp_gpio_get_direction() calls will run into the
four second timeout of mcp_send_report(), which will block the driver
for about 16s during startup.
Signed-off-by: Enrik Berkhan <Enrik.Berkhan@...a.de>
---
drivers/hid/hid-mcp2221.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/drivers/hid/hid-mcp2221.c b/drivers/hid/hid-mcp2221.c
index 0ca2a7b96825..5d8898f3f2e3 100644
--- a/drivers/hid/hid-mcp2221.c
+++ b/drivers/hid/hid-mcp2221.c
@@ -902,6 +902,9 @@ static int mcp2221_probe(struct hid_device *hdev,
mcp->gc->can_sleep = 1;
mcp->gc->parent = &hdev->dev;
+ /* Enable reception of HID reports during GPIO initialization */
+ hid_device_io_start(hdev);
+
ret = devm_gpiochip_add_data(&hdev->dev, mcp->gc, mcp);
if (ret)
goto err_gc;
--
2.34.1
Powered by blists - more mailing lists