Received: by 2002:a05:7412:b995:b0:f9:9502:5bb8 with SMTP id it21csp6703082rdb; Tue, 2 Jan 2024 10:18:03 -0800 (PST) X-Google-Smtp-Source: AGHT+IEsVZ13MIIOmL2oydbViKXZaoBDaxUkZ7wn3n8ggzCAR8+2Wp2FCEuKuGBJLYXSvviw+NTz X-Received: by 2002:a17:90a:2b48:b0:28b:ec53:4019 with SMTP id y8-20020a17090a2b4800b0028bec534019mr22055528pjc.17.1704219483376; Tue, 02 Jan 2024 10:18:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1704219483; cv=none; d=google.com; s=arc-20160816; b=l9J0ot1a8yqWkRhNn4/733GW0IJkeMtq35mFCsIPqnurPa5IW8s4X4+8yRR+Li+2hP eVoytMMcsGcAosOfuuqOvjnGe5tBrZrZnEEQenimd1rcgxuOuYdR4TZQbvf6wlMOP8rV 0S4sk5eWnfa56argcg8on5/30mg06WxhBjK36eB3DBEuR8tWFxOXZY3r+rcvbKGmJdHl OVv+b420ffQv63X1wrApFThN5gefTPt9W871OZA+XbaNsdp0VMy6RjFbv/gCiCPe1Wj1 YttwWWaERbBvXvhEx+CbkBRvqJ55GC7a5yBJUjw79ZB7dNQKIzMT+2VOFI8YFx6SQVCg Utqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:autocrypt:from:references:cc :to:content-language:subject:user-agent:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:date:message-id :dkim-signature; bh=vokVJUHBqqgZii3C8tGP6hxXN4hNbUKKpSnGYxnExi0=; fh=IqKD9VQ4BaEAFP89tWWGyjCLvPJmpQqX+nRHH74J690=; b=w0nJSRERbBc+KjWfUJ9x4WHz+gxw6eTAf3j9/RUQk+nPPxEaGwtRXxyuGQ92Y5et2p dkKzMMqPq9X+H5LaU+BAmkEnw9QJQj5OQGnJ5NwRuH5kaMJK36EsU9omKiNgu7vwVdMa 71g57/ADS+Q/KeH9Qv7Ou4lvcF30lKjtIa8Rdh3NKL+8zZVj+ni4aBEEOx6snuc4jJkn UIFn3SO3BCOLMUAaHaifvH+T3hgeXf04DSkEPMtG7Q95Ovi10cJcSlBUlSOg+4xNw/cU w4Kk8p1v6diDr+C6PpThx3+Yh7hGwWK+SKKgJe/V8qgwcLkaE3dTfnmXTZFIeqjPn3Yy YT3Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=S+2u32qo; spf=pass (google.com: domain of linux-kernel+bounces-14698-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-14698-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id f5-20020a637545000000b005cd85b1eaf6si20129701pgn.398.2024.01.02.10.18.03 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Jan 2024 10:18:03 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-14698-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=S+2u32qo; spf=pass (google.com: domain of linux-kernel+bounces-14698-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-14698-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 057C52842F8 for ; Tue, 2 Jan 2024 18:18:03 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id BECFD156E3; Tue, 2 Jan 2024 18:17:56 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="S+2u32qo" X-Original-To: linux-kernel@vger.kernel.org Received: from mail-ej1-f42.google.com (mail-ej1-f42.google.com [209.85.218.42]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2AA17156D6 for ; Tue, 2 Jan 2024 18:17:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linaro.org Received: by mail-ej1-f42.google.com with SMTP id a640c23a62f3a-a27733ae1dfso440673466b.3 for ; Tue, 02 Jan 2024 10:17:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1704219472; x=1704824272; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:autocrypt:from:references:cc :to:content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=vokVJUHBqqgZii3C8tGP6hxXN4hNbUKKpSnGYxnExi0=; b=S+2u32qokC3Fcqz8q4EzZr6Eq1S97L0cCA6LDw9vIbIw194wLemtkTQmvGoFnMDrtO 9HSRpC0bAv71jI37SfDpk0YcAm30RJTHyugrZdZGEwoxVzoJFvZ25gSB+zQ5de2VvIY6 Ft1ObH3uaRZgrky7tKdGQC6qtZgQ4DsgBWMZmOSvKhvXJwQt2AgQ/2llkvJ84+OEOhfd 2avVmPVjxEcmgpgmjwUPQH5baOP4YjEVb+Svnit4hWnh4ZeJp3NOUlDX6MHZMYfJ+kho QXMp8ItlitMvM+30VJuEQvt35c6jxuVV2pHwS0cdXOYbkv/0JZDF0V//zYlGyPGyQkd0 C+aA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1704219472; x=1704824272; h=content-transfer-encoding:in-reply-to:autocrypt:from:references:cc :to:content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=vokVJUHBqqgZii3C8tGP6hxXN4hNbUKKpSnGYxnExi0=; b=MktYnfZAeToJ9Wh8uoWzXOuaX7Z4NQY1y1qr8kMzaJ6d/rd5WsNT1vaHiHsrqi2Z61 YKwCDAZugwv5uU8xFTOBuVUa58qeCII2h5cZZmFxdBxj6+EsArLPcQD+5j7d6NLZR4P1 dwJ+CPd1n3y+ddWmkMSaC6/sK5qDdW9SifJUQCPlIjf443dS8cSx+Yr2Q4wYSw8d7I3L pOhHeN9YCYmrjzJI5I54zTYhu3kEtTbnPlBHZOilhaq7VC0MDOQ/zABcbOjOqbVqkce/ Ynszgfps24juyhn3FZQDjHqUL+X7q32p2tYZI2M2LpAfhAKooDetTWcilnEwXsn3+k+c K6Bw== X-Gm-Message-State: AOJu0YyeRWUzk5XWvg3WvnrgQWFuJTwapO5hPf8JAVZDIuAo8hw91NJB u0wrDiMENO65xQyPyX5V4i20Gb2bqCT6MkffcoVkKhSHeSY= X-Received: by 2002:a17:907:72c3:b0:a23:4532:f168 with SMTP id du3-20020a17090772c300b00a234532f168mr5910693ejc.227.1704219472321; Tue, 02 Jan 2024 10:17:52 -0800 (PST) Received: from [192.168.199.125] (178235179036.dynamic-4-waw-k-1-3-0.vectranet.pl. [178.235.179.36]) by smtp.gmail.com with ESMTPSA id fp21-20020a1709069e1500b00a26ade46619sm11179166ejc.121.2024.01.02.10.17.51 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 02 Jan 2024 10:17:51 -0800 (PST) Message-ID: <7e31d489-de96-42f0-a72a-a581859e7131@linaro.org> Date: Tue, 2 Jan 2024 19:17:50 +0100 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 2/2] firmware/psci: Set pm_set_resume/suspend_via_firmware() on qcom Content-Language: en-US To: Sudeep Holla Cc: Mark Rutland , Lorenzo Pieralisi , Marijn Suijten , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Bjorn Andersson References: <20231227-topic-psci_fw_sus-v1-0-6910add70bf3@linaro.org> <20231227-topic-psci_fw_sus-v1-2-6910add70bf3@linaro.org> <20231228102801.fzaubcjq5thfwgxg@bogus> <20231228115053.zlypgc5uxxvghi4a@bogus> <376d3040-b9ed-4574-90d7-fb864d694e3c@linaro.org> <20231228124348.mmtceqeuean7ly6y@bogus> From: Konrad Dybcio Autocrypt: addr=konrad.dybcio@linaro.org; keydata= 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 izWDgYvmBE8= In-Reply-To: <20231228124348.mmtceqeuean7ly6y@bogus> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit On 28.12.2023 13:43, Sudeep Holla wrote: > On Thu, Dec 28, 2023 at 01:16:28PM +0100, Konrad Dybcio wrote: >> On 28.12.2023 12:50, Sudeep Holla wrote: >>> On Thu, Dec 28, 2023 at 12:47:51PM +0100, Konrad Dybcio wrote: >>>> On 28.12.2023 11:28, Sudeep Holla wrote: >>>>> On Wed, Dec 27, 2023 at 11:15:31PM +0100, Konrad Dybcio wrote: >>>>>> Most Qualcomm platforms implementing PSCI (ab)use CPU_SUSPEND for >>>>>> entering various stages of suspend, across the SoC. These range from a >>>>>> simple WFI to a full-fledged power collapse of the entire chip >>>>>> (mostly, anyway). >>>>>> >>>>>> Some device drivers are curious to know whether "the firmware" (which is >>>>>> often assumed to be ACPI) takes care of suspending or resuming the >>>>>> platform. Set the flag that reports this behavior on the aforementioned >>>>>> chips. >>>>>> >>>>>> Some newer Qualcomm chips ship with firmware that actually advertises >>>>>> PSCI SYSTEM_SUSPEND, so the compatible list should only grow slightly. >>>>>> >>>>> >>>>> NACK, just use suspend-to-idle if SYSTEM_SUSPEND is not advertised. It is >>>>> designed for such platforms especially on x86/ACPI which don't advertise >>>>> Sx states. I see no reason why that doesn't work on ARM platforms as well. >>>> >>>> Not sure if I got the message through well, but the bottom line is, on >>>> Qualcomm platforms the "idle" states aren't actually just "idle" (read: >>>> they're not like S0ix). All but the most shallow ones shut down quite a >>>> chunk of the entire SoC, with the lowest ones being essentially S3 with >>>> power being cut off from the entire chip, except for the memory rail. >>>> >>> >>> No I understood that and S2I is exactly what you need. >>> Have you checked if S2I already works as intended on these platforms ? >> Yes, simple CPU idling works OOTB and the SoC power collapse only works >> given the developer doesn't cut corners when bringing up the platform >> (read: works on some of the ones we support, trying hard to expand that >> group!) >> >>> What extra do you achieve with this hack by advertising fake S2R ? >> Uh.. unless I misunderstood something, I'm not advertising s2ram.. >> Quite the opposite, I'm making sure only s2idle is allowed. >> > > Right, I didn't notice that in suspend_valid_all(), it can be rename > suspend_valid_s2i or something. "All" indicates all state is valid. > > Anyways that is not the main point. IIUC S2I must still work if there is > at-least one CPU idle state other than WFI without these changes. Right ? Yes, and it does > > If all these changes is to support S2I wih WFI only, then we can look at > some generic solution as there were previous attempts to do something > similar on other platforms IIRC. No, I'm just interested in setting the resume/suspend_via_firmware() markers and the PSCI driver seems like a good place for it, be it on all platforms with SYSTEM_SUSPEND and Qualcomm which sneaked equivalent functionality into the CPU_SUSPEND call. Konrad