Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp5506128rwd; Wed, 24 May 2023 02:50:38 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ768Le7R6TvBR/sWvUXYjHV/9pEn/oaItnH/UuNjRVAjWbVmaoki2mhRBDj8LkkkgPksV8F X-Received: by 2002:a17:90a:c082:b0:255:d427:5f02 with SMTP id o2-20020a17090ac08200b00255d4275f02mr1916699pjs.8.1684921838307; Wed, 24 May 2023 02:50:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684921838; cv=none; d=google.com; s=arc-20160816; b=QPkLG6GTW01ju1nJ7R6pL9L82X8AilBcZeNdjwlSjtpUatsWHYSyT88QbcUPwAKYuS 0DuDOed7KfzX/9RzDG0Q4jRsLeq5Ks1MJp7jOHRnkp39Dm6HtMWiYrciyF/LCXkNXBVl gFJ1+/ubdyZY21MlgCwU89TDo6kjr95AOtvoBf6HPtRlLi6OKIYuMGkY/o+TrFndXBZW iszoDoVaA+L6Qytv3+FieSgYyD887o5VEpaAP9DVqUJ1oYqd8IXGmXUSH1Q3hOzWcwJD pGJg7b3MBQSodvhWKmFnnMJzIsNzk4fiZQfYB6GN/boQ+4E847ozhRu99wMr084fN81x kROg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=4pLQzhdTQR++HZOjXKcTxoQqae3p38sj8Sa6S72/ZRM=; b=DJ+bhtknUjQ71nkcS12p9zDz+nZFJ6CHoPRtSCjWRg+w3Bipt5urFgzDmMA5l832Db xqsEATgl3D5KnXCKPqPgzJo0SQ6Un6WUotpIoTkba3gjHr8vdEmjciRJZtKEr+oDnh+w SU80Er/RGTnn62P0NSS0tsS6OiB1WtwWI0CtQ0iGjeDIZ4JV+vr/cfizFD9mSKMbe9nW 56E/Tjax0H3NgH+XXvlkQa4I0th8ie6Ty8SjYQl+RdrM9YT/YzgIsbc6IwsCg8ZZJ0JQ tizka96zwSkjJH6EUuwYZI86xCbHdNI1BsjzDBc9Vt5/1gTOWXhxqY/Lh3XWJyJ7g2YS N1TA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=PRBBGLXq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id m30-20020a63711e000000b0052c9fa0034fsi8522265pgc.699.2023.05.24.02.50.24; Wed, 24 May 2023 02:50:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=PRBBGLXq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230129AbjEXJkk (ORCPT + 99 others); Wed, 24 May 2023 05:40:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56476 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229968AbjEXJkU (ORCPT ); Wed, 24 May 2023 05:40:20 -0400 Received: from madras.collabora.co.uk (madras.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e5ab]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AA7AFA7; Wed, 24 May 2023 02:40:19 -0700 (PDT) Received: from [IPV6:2001:b07:2ed:14ed:a962:cd4d:a84:1eab] (unknown [IPv6:2001:b07:2ed:14ed:a962:cd4d:a84:1eab]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: kholk11) by madras.collabora.co.uk (Postfix) with ESMTPSA id 1F1116602B7B; Wed, 24 May 2023 10:40:18 +0100 (BST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1684921218; bh=lTT1BvxYVvnMQy5ylxlxFNGt4Z3KFLQE348e4gdRdEc=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=PRBBGLXq46hXr0PXg26mlxLIk3P8lO8h8yoTGLAeIb0t+pPu7Xd5uoDMh29A6UeHv xTF8BpbJUfP2eu438ApWAx15Dj9YZ8lUFlDAV8LZGjX8lan3Msf4rnH79gXbzSjdp7 4G0bs3lMSyVXMU57chcebAaCRU+Cw9uu6kwPbIpd889JYVdmReXu+0airjhRLHsRox PJKFtTWxfVbRJEZz/b4OtIF1hVIKoeNl/exRU6fBPQZTdpZny1Vrviq9a2bezzOOHt p7nWCq5wjuTBIBKZtuIMVg0IV6QIHDfJ+3iuB1yBayF58T+mmmODtjWGx2FLSA++T2 qhhGF9Awo9d9Q== Message-ID: Date: Wed, 24 May 2023 11:40:15 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.10.1 Subject: Re: [PATCH] usb: common: usb-conn-gpio: Set last role to unknown before initial detection Content-Language: en-US To: Prashanth K , Greg Kroah-Hartman , Matthias Brugger Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org References: <1684918441-14794-1-git-send-email-quic_prashk@quicinc.com> From: AngeloGioacchino Del Regno In-Reply-To: <1684918441-14794-1-git-send-email-quic_prashk@quicinc.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Il 24/05/23 10:54, Prashanth K ha scritto: > Currently if we bootup a device without cable connected, then > usb-conn-gpio won't call set_role() since last_role is same as > current role. This happens because during probe last_role gets > initialised to zero. > > To avoid this, last_role is set to USB_ROLE_UNKNOWN before > performing the initial detection. > > Fixes: 4602f3bff266 ("usb: common: add USB GPIO based connection detection driver") > Signed-off-by: Prashanth K > --- > drivers/usb/common/usb-conn-gpio.c | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/drivers/usb/common/usb-conn-gpio.c b/drivers/usb/common/usb-conn-gpio.c > index e20874c..00af735 100644 > --- a/drivers/usb/common/usb-conn-gpio.c > +++ b/drivers/usb/common/usb-conn-gpio.c > @@ -27,6 +27,8 @@ > #define USB_CONN_IRQF \ > (IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING | IRQF_ONESHOT) > > +#define USB_ROLE_UNKNOWN -1 I would add USB_ROLE_UNKNOWN to `enum usb_role` instead. enum usb_role { USB_ROLE_UNKNOWN = -1, USB_ROLE_NONE, .... }; Regards, Angelo > + > struct usb_conn_info { > struct device *dev; > struct usb_role_switch *role_sw; > @@ -257,6 +259,9 @@ static int usb_conn_probe(struct platform_device *pdev) > platform_set_drvdata(pdev, info); > device_set_wakeup_capable(&pdev->dev, true); > > + /* Set last role to unknown before performing the initial detection */ > + info->last_role = USB_ROLE_UNKNOWN; > + > /* Perform initial detection */ > usb_conn_queue_dwork(info, 0); >