Received: by 2002:a05:7412:b101:b0:e2:908c:2ebd with SMTP id az1csp2529889rdb; Wed, 15 Nov 2023 03:38:14 -0800 (PST) X-Google-Smtp-Source: AGHT+IHuvdbPqmHO+3rsLDsL7kjEYOPTqDNKqUGcZp6C6IJm/C4Wb+3Qj3OqPcNuw48yMcQJD6FT X-Received: by 2002:a05:6a21:999a:b0:186:1332:a930 with SMTP id ve26-20020a056a21999a00b001861332a930mr11470090pzb.38.1700048293938; Wed, 15 Nov 2023 03:38:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1700048293; cv=none; d=google.com; s=arc-20160816; b=FIgfu6zHsn5JZ/seSbvzNj4Eglgq4HH/jB8jA94nWvaEcWdIby3d/84xXoavCJqhPN Fg9uBTqIKXg+21VCmkGaFOyEgBJCRuf23BYbsJyfPk3mfY2E3E1JdzgNkaNGjLugwX5z EOd917veuqPLiGmaEmq5GDLFXTdcKcOBayp4aoHFbJPhKko9sYOnS2PKjwS/ihdWyG6L B2h0DzN1/rtgCAed6pXopzE0fvWQo33wHOi1Ttpd1IwEowBmObefgmz6mfqRmDSJcCHY 53/rT4fFvhx8Kose9kRzZdegjYmy/YZ64Jkmm7ODz92BDIjoq5F/fNstgwRu5KaLMbxG SpDA== 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=DJKW1aOG/+HkNb6dyChAZVD8xJ3zFF+enobr56lcTcU=; fh=gITdw7bURVsgu1WFDWW+etvmcoJ0xK8NnUcjcEVG9Bk=; b=Ju2zMLQM0O+HfRp07IrJAsCf7faNX6YYkeviABXIv7GQa+vwWm+NFP11ymHDivPsax uy4V4OEhpjne/q8U3ST9uFTjGpX/2NSbh80+rGYFO312Wjxo851/Y/gFb/qCQQJ5eEHW rzcGvD/UsnWzs799E4ki+ssn+NLsrpJNbv4DUwnJGp0WNMsRIRIRnQB9AZyzz4kf11IF tLmssYFBBfJQCHxd8qpA5sPm15MxSU8Vnqd4JbrH8Qttla2yIOIhfWUSpxrnm8LXEYiK MP3CVXGsbclC47ZsaPzgploRlF0+SW3+/p4LfFGe+JFiW2akaOVfP73REKm7HGgVy46P FDUA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=C1btWkMT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from fry.vger.email (fry.vger.email. [23.128.96.38]) by mx.google.com with ESMTPS id s14-20020a056a00178e00b006c0fe926fc9si10538245pfg.173.2023.11.15.03.38.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 15 Nov 2023 03:38:13 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) client-ip=23.128.96.38; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=C1btWkMT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.38 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id B9F1B801C193; Wed, 15 Nov 2023 03:38:10 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1343584AbjKOLiC (ORCPT + 99 others); Wed, 15 Nov 2023 06:38:02 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56508 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234923AbjKOLiB (ORCPT ); Wed, 15 Nov 2023 06:38:01 -0500 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 495CEE9 for ; Wed, 15 Nov 2023 03:37:58 -0800 (PST) Received: by smtp.kernel.org (Postfix) with ESMTPSA id B9DD4C433C8; Wed, 15 Nov 2023 11:37:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1700048277; bh=Pu4tFAOY3zxIIjiLvSPYrBxg0B7lYHQiyaQQXyNG4sI=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=C1btWkMToN5RfkwTirTgfoqjtovEzIAC5G2W5FcV2dedEYaiyQ2+PauqC3i8TOS5S mJL27GvEUxF5C1zsi+aLhlvYd700Kjs0bVRRk5lH2f28a8jjP+wZgsgEj9D3o4Wc/a 8IwElx5j3f+X7TItvpfL5cvWbmk1bXzGdXEmHZMF+uAlOKDFFlAuD/SQeiS0PgK7qW UYgx37uoGlshojY/ScnopSxpX5c2EqJ7wRvDN4owObZuxpw33NheSHuuIMt74fw4tK FpZG3THZ6pakM9X/s7ITUsYQxninvteLr/7cp3Cd6RlmRrr/TBUELLAKZ5TJoutbbU GOlxAwRpSMPsA== Message-ID: <5080372b-1f48-4cbc-a6c4-8689c28983cb@kernel.org> Date: Wed, 15 Nov 2023 13:37:51 +0200 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 3/6] usb: cdns3-ti: add suspend/resume procedures for J7200 Content-Language: en-US To: =?UTF-8?Q?Th=C3=A9o_Lebrun?= , Greg Kroah-Hartman , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Peter Chen , Pawel Laszczak , Nishanth Menon , Vignesh Raghavendra , Tero Kristo Cc: linux-usb@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org References: <20231113-j7200-usb-suspend-v1-0-ad1ee714835c@bootlin.com> <20231113-j7200-usb-suspend-v1-3-ad1ee714835c@bootlin.com> From: Roger Quadros In-Reply-To: <20231113-j7200-usb-suspend-v1-3-ad1ee714835c@bootlin.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.3 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Wed, 15 Nov 2023 03:38:10 -0800 (PST) On 13/11/2023 16:26, Théo Lebrun wrote: > Hardware initialisation is only done at probe. The J7200 USB controller > is reset at resume because of power-domains toggling off & on. We > therefore (1) toggle PM runtime at suspend/resume & (2) reconfigure the > hardware at resume. at probe we are doing a pm_runtime_get() and never doing a put thus preventing any runtime PM. > > Reuse the newly extracted cdns_ti_init_hw() function that contains the > register write sequence. > > We guard this behavior based on compatible to avoid modifying the > current behavior on other platforms. If the controller does not reset > we do not want to touch PM runtime & do not want to redo reg writes. > > Signed-off-by: Théo Lebrun > --- > drivers/usb/cdns3/cdns3-ti.c | 48 +++++++++++++++++++++++++++++++++++++++++++- > 1 file changed, 47 insertions(+), 1 deletion(-) > > diff --git a/drivers/usb/cdns3/cdns3-ti.c b/drivers/usb/cdns3/cdns3-ti.c > index c331bcd2faeb..50b38c4b9c87 100644 > --- a/drivers/usb/cdns3/cdns3-ti.c > +++ b/drivers/usb/cdns3/cdns3-ti.c > @@ -197,6 +197,50 @@ static int cdns_ti_probe(struct platform_device *pdev) > return error; > } > > +#ifdef CONFIG_PM > + > +static int cdns_ti_suspend(struct device *dev) > +{ > + struct cdns_ti *data = dev_get_drvdata(dev); > + > + if (!of_device_is_compatible(dev_of_node(dev), "ti,j7200-usb")) > + return 0; > + > + pm_runtime_put_sync(data->dev); > + > + return 0; You might want to check suspend/resume ops in cdns3-plat and do something similar here. > +} > + > +static int cdns_ti_resume(struct device *dev) > +{ > + struct cdns_ti *data = dev_get_drvdata(dev); > + int ret; > + > + if (!of_device_is_compatible(dev_of_node(dev), "ti,j7200-usb")) > + return 0; > + > + ret = pm_runtime_get_sync(dev); > + if (ret < 0) { > + dev_err(dev, "pm_runtime_get_sync failed: %d\n", ret); > + goto err; > + } > + > + cdns_ti_init_hw(data); > + > + return 0; > + > +err: > + pm_runtime_put_sync(data->dev); > + pm_runtime_disable(data->dev); > + return ret; > +} > + > +static const struct dev_pm_ops cdns_ti_pm_ops = { > + SET_SYSTEM_SLEEP_PM_OPS(cdns_ti_suspend, cdns_ti_resume) > +}; > + > +#endif /* CONFIG_PM */ > + > static int cdns_ti_remove_core(struct device *dev, void *c) > { > struct platform_device *pdev = to_platform_device(dev); > @@ -218,6 +262,7 @@ static void cdns_ti_remove(struct platform_device *pdev) > } > > static const struct of_device_id cdns_ti_of_match[] = { > + { .compatible = "ti,j7200-usb", }, > { .compatible = "ti,j721e-usb", }, > { .compatible = "ti,am64-usb", }, > {}, > @@ -228,8 +273,9 @@ static struct platform_driver cdns_ti_driver = { > .probe = cdns_ti_probe, > .remove_new = cdns_ti_remove, > .driver = { > - .name = "cdns3-ti", > + .name = "cdns3-ti", > .of_match_table = cdns_ti_of_match, > + .pm = pm_ptr(&cdns_ti_pm_ops), > }, > }; > > -- cheers, -roger