From nobody Thu May 15 18:17:50 2025 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4Zyz331YdFz5wj2N; Thu, 15 May 2025 18:17:51 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R11" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4Zyz324R88z3Fgr; Thu, 15 May 2025 18:17:50 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1747333070; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=NWEKZYNfTHBpi0PLmenunEqfy6jBNO9WGjfYRKThVeE=; b=Ro6XGyLM97ob28Y152crHdGQLrvtlQqjA/rZ8zrJbHOV4QPmFgdRYutMrutIqKVNWL4pQm P/nkfBjae+7o5qOHuaOZ4ereNwOC+lRSjwWoUdjEj9jwi8kCfygGAhmMXiyr1PEmroTz+o GABjz4TMlxmJR4A0STui0t3ttVOA8GZUcgAKsAu6BYYy7Zj8SwfQZM17etuZFjFFi68AzK NtSL9KK2ui7E63KLm4kj8S06++N1UGXIlCjWpa8iFTnHWEsUPg8LlzaoGjzLs33r8OB++4 pROI9pSGHAyLEvsvg6px3sNzwfLXGYRlM/6kSWUEKUR704MqCPICXa7ccyclTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1747333070; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=NWEKZYNfTHBpi0PLmenunEqfy6jBNO9WGjfYRKThVeE=; b=gHtn00s/oIB0DJQf37eGUCR6plQGiBMnTV//AaE4bXsaZCNY8fymheg7yBf2kHxLQra7wR MOlbiME7YG9GuNen8zwHhk/j5TxKfL22PRt0oU+qB5uZX0M7uSPZQGqs0ojGesXDWK4iju 2fdkVf2Y2mX01OsRf2mGavxeKrSocb5Gt4cMxB3r/av5Be7OFbGRJ6ZaKlaTM6gVkJxoaz 561XjYBErugxVJqFiDd6CZr9QzMaAhd9yO8yt6ae+Lmb4ga6kMAiVqee7r1juJsWM+fO7m LFKR/Ea2R/RFWBm0ti/N/sMaEoJsIG+e/xG+7zujeK9FjY9Jfci14YfpWo6lww== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1747333070; a=rsa-sha256; cv=none; b=CdET/z0Rlb3sZEkxNOCdcPL/2UsCQy3rRbz+JCP5znTp1S43gn1cekd5QB/NgjFPf8n0Qj 7yKrxuwKRGssDRX9Dviw1Si9hA3e8N+my/H9gcWYax95wXoJmyFBCq+Q9hTxVABsxjvEWJ d1FucaokbnFbbzRxkbh40QNn7XTBpllpZjGXL9ifwJWMrnP9TnV1AwMcgZQB8EUzHEoBxl hK/35l9NG+fcngzl63a4e7FNwrY72RnhW5j5mhFgONwh4BvEzl2czj7GzEoGqwl8yd65rm rcHzUdk57+2mOxkfxmSc8Za2ELhd5XPQEYu9KOgR8YsMaHJgQHHHhTZL5L2UVQ== ARC-Authentication-Results: i=1; mx1.freebsd.org; none Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4Zyz3242fLzD0q; Thu, 15 May 2025 18:17:50 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.18.1/8.18.1) with ESMTP id 54FIHo5v090230; Thu, 15 May 2025 18:17:50 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.18.1/8.18.1/Submit) id 54FIHoWf090227; Thu, 15 May 2025 18:17:50 GMT (envelope-from git) Date: Thu, 15 May 2025 18:17:50 GMT Message-Id: <202505151817.54FIHoWf090227@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org From: Vladimir Kondratyev Subject: git: 072e0b158004 - stable/14 - iichid(4): Wait for RESET command response while attaching List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-src-all@freebsd.org Sender: owner-dev-commits-src-all@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: wulf X-Git-Repository: src X-Git-Refname: refs/heads/stable/14 X-Git-Reftype: branch X-Git-Commit: 072e0b158004a2cc7870e81ba482805f7f60b7c3 Auto-Submitted: auto-generated The branch stable/14 has been updated by wulf: URL: https://cgit.FreeBSD.org/src/commit/?id=072e0b158004a2cc7870e81ba482805f7f60b7c3 commit 072e0b158004a2cc7870e81ba482805f7f60b7c3 Author: Vladimir Kondratyev AuthorDate: 2025-03-07 06:26:51 +0000 Commit: Vladimir Kondratyev CommitDate: 2025-05-15 18:12:19 +0000 iichid(4): Wait for RESET command response while attaching before starting of children initialization to ensure that parent device is fully functional. Sponsored by: Future Crew LLC MFC after: 2 month Differential Revision: https://reviews.freebsd.org/D48958 (cherry picked from commit daa098cc37b9db36281623c00558976aea4fa90e) --- sys/dev/iicbus/iichid.c | 55 ++++++++++++++++++++++++++++++++++++------------- 1 file changed, 41 insertions(+), 14 deletions(-) diff --git a/sys/dev/iicbus/iichid.c b/sys/dev/iicbus/iichid.c index 577b0952e107..0e4aa649ff48 100644 --- a/sys/dev/iicbus/iichid.c +++ b/sys/dev/iicbus/iichid.c @@ -98,6 +98,8 @@ enum { #define I2C_HID_POWER_ON 0x0 #define I2C_HID_POWER_OFF 0x1 +#define IICHID_RESET_TIMEOUT 5 /* seconds */ + /* * Since interrupt resource acquisition is not always possible (in case of GPIO * interrupts) iichid now supports a sampling_mode. @@ -156,6 +158,7 @@ enum iichid_powerstate_how { */ struct iichid_softc { device_t dev; + struct mtx mtx; bool probe_done; int probe_result; @@ -190,6 +193,7 @@ struct iichid_softc { bool open; /* iicbus lock */ bool suspend; /* iicbus lock */ bool power_on; /* iicbus lock */ + bool reset_acked; /* iichid mtx */ }; static device_probe_t iichid_probe; @@ -295,6 +299,12 @@ iichid_cmd_read(struct iichid_softc* sc, void *buf, iichid_size_t maxlen, { sc->addr, IIC_M_RD | IIC_M_NOSTART, le16toh(sc->desc.wMaxInputLength) - 2, sc->intr_buf }; actlen = 0; + if (!sc->reset_acked) { + mtx_lock(&sc->mtx); + sc->reset_acked = true; + wakeup(&sc->reset_acked); + mtx_unlock(&sc->mtx); + } #ifdef IICHID_SAMPLING } else if ((actlen <= 2 || actlen == 0xFFFF) && sc->sampling_rate_slow >= 0) { @@ -1136,21 +1146,9 @@ iichid_attach(device_t dev) device_printf(dev, "failed to power on: %d\n", error); return (ENXIO); } - /* - * Windows driver sleeps for 1ms between the SET_POWER and RESET - * commands. So we too as some devices may depend on this. - */ - pause("iichid", (hz + 999) / 1000); - - error = iichid_reset(sc); - if (error) { - device_printf(dev, "failed to reset hardware: %d\n", error); - error = ENXIO; - goto done; - } - sc->power_on = true; + mtx_init(&sc->mtx, device_get_nameunit(dev), NULL, MTX_DEF); sc->intr_bufsize = le16toh(sc->desc.wMaxInputLength) - 2; sc->intr_buf = malloc(sc->intr_bufsize, M_DEVBUF, M_WAITOK | M_ZERO); TASK_INIT(&sc->suspend_task, 0, iichid_suspend_task, sc); @@ -1209,12 +1207,40 @@ iichid_attach(device_t dev) &sc->sampling_hysteresis, 0, "number of missing samples before enabling of slow mode"); hid_add_dynamic_quirk(&sc->hw, HQ_IICHID_SAMPLING); +#endif /* IICHID_SAMPLING */ + + /* + * Windows driver sleeps for 1ms between the SET_POWER and RESET + * commands. So we too as some devices may depend on this. + */ + pause("iichid", (hz + 999) / 1000); + + error = iichid_reset(sc); + if (error) { + device_printf(dev, "failed to reset hardware: %d\n", error); + iichid_detach(dev); + error = ENXIO; + goto done; + } + /* Wait for RESET response */ +#ifdef IICHID_SAMPLING if (sc->sampling_rate_slow >= 0) { pause("iichid", (hz + 999) / 1000); (void)iichid_cmd_read(sc, sc->intr_buf, 0, NULL); - } + } else #endif /* IICHID_SAMPLING */ + { + mtx_lock(&sc->mtx); + if (!sc->reset_acked && !cold) { + error = mtx_sleep(&sc->reset_acked, &sc->mtx, 0, + "iichid_reset", hz * IICHID_RESET_TIMEOUT); + if (error != 0) + device_printf(sc->dev, + "Reset timeout expired\n"); + } + mtx_unlock(&sc->mtx); + } child = device_add_child(dev, "hidbus", -1); if (child == NULL) { @@ -1261,6 +1287,7 @@ iichid_detach(device_t dev) free(sc->dup_buf, M_DEVBUF); #endif free(sc->intr_buf, M_DEVBUF); + mtx_destroy(&sc->mtx); return (0); }