Received: by 10.213.65.68 with SMTP id h4csp891169imn; Wed, 14 Mar 2018 03:24:01 -0700 (PDT) X-Google-Smtp-Source: AG47ELtyMjyiwqtndGXH4qcWHlYwL2D9+dJlqENTgfjNKXmc979GVcSiui95ZWSRxsM6wbPihuaX X-Received: by 2002:a17:902:44c:: with SMTP id 70-v6mr3629995ple.354.1521023040966; Wed, 14 Mar 2018 03:24:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521023040; cv=none; d=google.com; s=arc-20160816; b=LKCtDjjdfTS8AoLLb/Dqx9LNTdBZo9r+zqG4mQ1cJ6xfbLfpybMkQcKNQGuVm2RgHm 2TRRuBRNgRKBLEKccZetnOXDYJ4G6goiSVXP+wtMu46Zr69hHIjVwHiIkJ0eq7NvW35Q 7To53BvCXnUwKDVPw8V7FADdorLPooUVU0T/gY4bh4PSfqkJ6fEOUvR4/OnKc9RaQVAj 05glkoCwkhZ3ORYqXjP5uQfWVh2Oi/3xlIZI1e/rV6PdrwfvpUVjXWHWBUx4XblwNtth HiJXX7jKhyQ+rITiPwzef0543JQ/oNHRuQeJAM664Ca4VAJcskah1cgFqLo/r2wUdUKy ShZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:cc:to:subject :arc-authentication-results; bh=ZRr9AYHjAVYkKjGy7Sb1dLkkpij0f984Pl2C7QoPXrU=; b=xoyb6IlpOl1WtrOvOsKF9+vgeC81M++qqldmN7pLzbNvkdBMeRF4J2BsvBb1W4+dEf H1INjORH3ouICKpBNv4kKfCIPTEJvj4HXULpGqEjo/UMvvafojuAc2wknxjeu+CJGX5e 1H2hYbMV5sX1TB34q/riY/xn1y+Q5jMDQAyMf0h4aAZ9yKPL6BPx273AAYZtdvmO3XhN Xf7emqYdHZTJY/AMSC6hw/q9xCM5aoZmEG77tQ9yq8ovne6boez4W+Z7/Ir5AYwrxFHc k8d/OpD1NvuWsAqLTz1HcUQiWXME07Rh8wItv0GaOAHigPFDSfWEGtXBflBzGB9j9k1T vODQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q3-v6si1738972plb.221.2018.03.14.03.23.44; Wed, 14 Mar 2018 03:24:00 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751497AbeCNKWh (ORCPT + 99 others); Wed, 14 Mar 2018 06:22:37 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:50138 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750964AbeCNKWe (ORCPT ); Wed, 14 Mar 2018 06:22:34 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 4FC0E15AB; Wed, 14 Mar 2018 03:22:34 -0700 (PDT) Received: from [10.1.207.62] (usa-sjc-imap-foss1.foss.arm.com [10.72.51.249]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id AF2F33F53D; Wed, 14 Mar 2018 03:22:31 -0700 (PDT) Subject: Re: [PATCH v7 1/3] irqchip/gic-v3-its: add ability to save/restore ITS state To: "dbasehore ." Cc: Mark Rutland , linux-kernel , Soby Mathew , Sudeep Holla , devicetree@vger.kernel.org, robh+dt@kernel.org, Linux-pm mailing list , "Wysocki, Rafael J" , Thomas Gleixner , Brian Norris References: <20180301054820.42847-1-dbasehore@chromium.org> <20180301054820.42847-2-dbasehore@chromium.org> <20180301114144.nmwu4qtslvj7ogj5@lakrids.cambridge.arm.com> <0a74f87a-027a-df7d-ca2d-fc164ec9cdf7@arm.com> From: Marc Zyngier Organization: ARM Ltd Message-ID: <6a5b5723-85bb-e46f-f621-eab17a01f1f0@arm.com> Date: Wed, 14 Mar 2018 10:22:30 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/03/18 02:08, dbasehore . wrote: > On Thu, Mar 1, 2018 at 4:29 AM, Marc Zyngier wrote: >> Hi Mark, >> >> On 01/03/18 11:41, Mark Rutland wrote: >>> On Wed, Feb 28, 2018 at 09:48:18PM -0800, Derek Basehore wrote: >>>> Some platforms power off GIC logic in suspend, so we need to >>>> save/restore state. The distributor and redistributor registers need >>>> to be handled in platform code due to access permissions on those >>>> registers, but the ITS registers can be restored in the kernel. >>>> >>>> Signed-off-by: Derek Basehore >>> >>> How much state do we have to save/restore? >>> >>> Given we can apparently read all this state, couldn't we *always* save >>> the state, then upon resume detect if the state has been lost, restoring >>> it if so? >>> >>> That way, we don't need a property in FW tables for DT or ACPI. >> >> That's a good point. I guess that we could just compare the saved >> GITS_CTLR register and restore the full state only if the ITS comes back >> as disabled. >> >> I'm just a bit worried that it makes it an implicit convention between >> kernel an FW, which could change in funny ways. Importantly, the PSCI >> spec says states FW should restore *the whole state*. Obviously, it >> cannot to that on HW that doesn't allow you to read out the state, hence >> the DT flag that outlines the departure from the expected behaviour. >> >> I'm happy to go either way, but then I have the feeling that we should >> go back to quirking it on the actual implementation (GIC500 in this >> case) if we're to from the property. >> >>> >>> [...] >>> >>>> @@ -3261,6 +3363,9 @@ static int __init its_probe_one(struct resource *res, >>>> ctlr |= GITS_CTLR_ImDe; >>>> writel_relaxed(ctlr, its->base + GITS_CTLR); >>>> >>>> + if (fwnode_property_present(handle, "reset-on-suspend")) >>>> + its->flags |= ITS_FLAGS_SAVE_SUSPEND_STATE; >>> >>> Does this allow this property on an ACPI system? >>> >>> If we need this on ACPI, we need a spec update to handle this properly, >>> and shouldn't use device properties like this. >> >> Well spotted. I guess that dropping the property would fix that >> altogether, assuming we feel that the above is safe enough. >> >> Thoughts? > > I'm fine changing it to get rid of the devicetree property. > > What's the reason for quirking the behavior though? It's not that much > code + data and nothing else relies on the state of the ITS getting > disabled across suspend/resume. Even if something did, we'd have to > resolve it with this feature anyways. The reason we do this is to cope with GIC500 having the collection state in registers instead of memory. If we didn't have this extraordinary misfeature, FW could do a full save/restore of the ITS, and we wouldn't have to do anything (which is what the driver currently expects). A middle ground approach is to limit the feature to systems where GITS_TYPER.HCC is non-zero instead of limiting it to GIC500. Pretty easy to fix. This should have the same effect, as GIC500 is the only implementation I'm aware of with HCC!=0. Given that we're already at -rc5 and that I'd like to queue things for 4.17, I've made this change myself and queued patches 1 and 3 here[1]. Can you please have a look at let me know if that works for you? Thanks, M. [1] git://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms.git irq/irqchip-next -- Jazz is not dead. It just smells funny...