Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp3865395rwb; Tue, 20 Sep 2022 05:59:51 -0700 (PDT) X-Google-Smtp-Source: AMsMyM56UbvvVupwZ/X2cdGEDFd/8d4oE4GwTIFIicS4/KkgC3lrm28KCkUPZGNJp1/xqU4hRHqf X-Received: by 2002:a05:6402:1e92:b0:451:dcf:641d with SMTP id f18-20020a0564021e9200b004510dcf641dmr20274626edf.335.1663678791493; Tue, 20 Sep 2022 05:59:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663678791; cv=none; d=google.com; s=arc-20160816; b=sHXiybI0JsMpTFU96jJC5mPF5Mdztf/idk85UG9FAhmwgHtXHJ0JLaBQ07TNrAVXoQ UxdJrHy4H87y/vB2Yfsh6DjKN1z7f+8yb3ahhkQD/mbIXC8+aR53gMNuHbyNeX2xAajR KHzQO2+b3OxsymY+KGCfqJmeiD0sSsx9H9WCDNJWiPYXQx1jaT2X8bmk8eaN+PavxCds wrd/hanP/B896pns4BOswCwOLq3jnHmbWBIFl32L1lh6MLXvjdCY3B/asQ/pUXN+kTPg TI1vbUgtL08H57lpuZPI1iwiTXHHiCHsNKEaORBGsbVmAu49NUH0TeVTsjEZp7XzUBSj h+dQ== 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=z5y+ZIvq8DtUrhIy9IiKDU0r+zSCt6JeG7CdR8WtrGk=; b=a+mCa+YYUjc/7GmmCm2vSZzBSr70FugbhLTz6bUnf59NxsH52n7rLDQuwVtehnwfun 3heJ4O4Lb81qU8bYKidKFtGKR3dC+eeHhrGJtAgOunH2kVfjTx0EGqTscgjSIMlgSbPr yMmxFtX8O2lJ44Xj3MIaOsn5W5fDwOFthr/HDhMstxvGAoQjCIVaxC1v2Fe35oluwmHq ylPyi55Gv5kyaVrkNRTFz9svMIybEgeWG5jqIls+LDZ7F8wrGL/cB2yDXMUvnoVPymlK /4VEuv0qie1qdA4sEr2jerMLQr0c6JPEkwvjtyoGx7gwgf8prbgAH0s6YsJ/WUTmqrZr uXJg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=KQrXjJj+; 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=NONE sp=NONE 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 ds14-20020a170907724e00b007317ef9dc93si1368394ejc.909.2022.09.20.05.59.25; Tue, 20 Sep 2022 05:59:51 -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=KQrXjJj+; 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=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231210AbiITMjk (ORCPT + 99 others); Tue, 20 Sep 2022 08:39:40 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59328 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231190AbiITMja (ORCPT ); Tue, 20 Sep 2022 08:39:30 -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 AD2437539A; Tue, 20 Sep 2022 05:39:26 -0700 (PDT) Received: from [192.168.1.100] (2-237-20-237.ip236.fastwebnet.it [2.237.20.237]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) (Authenticated sender: kholk11) by madras.collabora.co.uk (Postfix) with ESMTPSA id A69536601F6E; Tue, 20 Sep 2022 13:39:24 +0100 (BST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1663677565; bh=M8V14kKBz9Y4qj+qdqKf+M0F+261VAS+silgfIoh22c=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=KQrXjJj+1mIerapret9wmIZjsyR2pudGcqvjn3bagbc6CHFmWQcA0+n79FaYD9pr2 QBZK6F/UpzO2so9gVSTYES4XcISQVHKoif+Oe6F2fbdOdUNJIeK7lojGFQt3cpgZpD ZIFHP5bv4bq24c9SQMs3xQkv+cUiOlBqGr73/HyBjOEXayYltoiwq5AEXJNAMrZ6nW VsZG+RTilXzl1JN98y3RFUSV5sruzH9nFqMliQScAuiCfVwXmLq1AONd29D7sDl1oO mHycLJWXk7aFifUf7AHjuiV2qxWJl/B7WckQtcaZSm1bF0MF3cBuaqGfBkhVLGBsTd hiKGTI2BOmoTQ== Message-ID: Date: Tue, 20 Sep 2022 14:39:21 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.2.0 Subject: Re: [PATCH v3 1/3] clk: qcom: gdsc: Fix the handling of PWRSTS_RET support Content-Language: en-US To: Rajendra Nayak , agross@kernel.org, andersson@kernel.org, konrad.dybcio@somainline.org, mturquette@baylibre.com, sboyd@kernel.org, mka@chromium.org Cc: linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, johan+linaro@kernel.org, quic_kriskura@quicinc.com, dianders@chromium.org, linux-clk@vger.kernel.org References: <20220920111517.10407-1-quic_rjendra@quicinc.com> From: AngeloGioacchino Del Regno In-Reply-To: <20220920111517.10407-1-quic_rjendra@quicinc.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,SPF_HELO_NONE, SPF_PASS 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 20/09/22 13:15, Rajendra Nayak ha scritto: > GDSCs cannot be transitioned into a Retention state in SW. > When either the RETAIN_MEM bit, or both the RETAIN_MEM and > RETAIN_PERIPH bits are set, and the GDSC is left ON, the HW > takes care of retaining the memory/logic for the domain when > the parent domain transitions to power collapse/power off state. > > On some platforms where the parent domains lowest power state > itself is Retention, just leaving the GDSC in ON (without any > RETAIN_MEM/RETAIN_PERIPH bits being set) will also transition > it to Retention. > > The existing logic handling the PWRSTS_RET seems to set the > RETAIN_MEM/RETAIN_PERIPH bits if the cxcs offsets are specified > but then explicitly turns the GDSC OFF as part of _gdsc_disable(). > Fix that by leaving the GDSC in ON state. > > Signed-off-by: Rajendra Nayak > Cc: AngeloGioacchino Del Regno > --- > v3: > Updated changelog > > There are a few existing users of PWRSTS_RET and I am not > sure if they would be impacted with this change > > 1. mdss_gdsc in mmcc-msm8974.c, I am expecting that the > gdsc is actually transitioning to OFF and might be left > ON as part of this change, atleast till we hit system wide > low power state. > If we really leak more power because of this > change, the right thing to do would be to update .pwrsts for > mdss_gdsc to PWRSTS_OFF_ON instead of PWRSTS_RET_ON > I dont have a msm8974 hardware, so if anyone who has can report > any issues I can take a look further on how to fix it. I think that the safest option is to add a PWRSTS_RET_HW_CTRL flag (or similar), used for the specific cases of SC7180 and SC7280 (and possibly others) where the GDSC is automatically transitioned to a Retention state by HW control, with no required software (kernel driver) intervention. > > 2. gpu_gx_gdsc in gpucc-msm8998.c and > gpu_gx_gdsc in gpucc-sdm660.c > Both of these seem to add support for 3 power state > OFF, RET and ON, however I dont see any logic in gdsc > driver to handle 3 different power states. > So I am expecting that these are infact just transitioning > between ON and OFF and RET state is never really used. > The ideal fix for them would be to just update their resp. > .pwrsts to PWRSTS_OFF_ON only. static int gdsc_init(struct gdsc *sc) { ... if (on || (sc->pwrsts & PWRSTS_RET)) gdsc_force_mem_on(sc); else gdsc_clear_mem_on(sc); ... } On MSM8998 and SDM630/636/660, we're reaching that point with a GDSC that is left OFF from the bootloader, but we want (at least for 630/660) memretain without periph-retain: this is required to make the hypervisor happy. Regards, Angelo