Received: by 10.223.185.116 with SMTP id b49csp8187869wrg; Thu, 1 Mar 2018 19:31:10 -0800 (PST) X-Google-Smtp-Source: AG47ELtOUAQlj/8ZIfdLxDSKwu3YUJW5NGA2LjvfQfa8BZobavvIt8m7FnxrdWXq3Il9o7whUUfQ X-Received: by 2002:a17:902:7f0b:: with SMTP id d11-v6mr4082518plm.350.1519961470648; Thu, 01 Mar 2018 19:31:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519961470; cv=none; d=google.com; s=arc-20160816; b=MYstWuTQAbyP6YArZTRkeG0+w8XOfaPCWG4o8nOifKrZC43TnwtAdmZqEIHmk68rCd j66nznvnMuP+8dSROe9RUT0tpK8Ty3su+ZaAi0QzrP5z9xN+kQazaWRDzJ7iLfsXFIs4 LJO/EuI4nxho7jniW5kVogQUfaD+HzP3U540quvVESVmAaL1AyHAeFrnT+6ZcwnlYrDZ ZFWqnOiGgxp6EKiVLr/1InlTT1RPlJKzmhB6dsiDMdLexYypZCxhIDMuYG0b1P8zXPPc a8rn5Dwwno+IuN1VcJ44FhlYAhxIUXDXNgGeSMwO8sJU3jCrc31GfI+1GdXhXdBAETDl WppA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature:dkim-signature :arc-authentication-results; bh=FcsS+BNB8OvB8glm7P0L6q05xmCf5avhyci++E8pObY=; b=h96hHeyhjjcy4x3fTsSE62L0/BMtXXxWGdddRIhYZRr2SNGcDMJhTQiuAPFQPVVxXh Sex66W4kx3kuBsqMuGAP73NUS8wJ4PKPuMh/cBY4hkhpdLH757oACZRT5UnUBrCW7+qK Bx4CZNqtTLo5FtEzXBjCIKHR9ivjDTFWfwrneMjKqSZ0oAsnKOlC4Egz1BzFYkn6wtT4 4Z2zRl1pCFJ2FLPYhGjYk/dSLf98nYfh55ZvaDHnovfFoiNvxIulJQ9c0fGyiS73RSZx C8gy54SZTKfjo7BVMyexACh0UzvSgrJEuCYUViUm5MlilqTj8/rTyT5utRifqaE7xfWV Zd4A== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@google.com header.s=20161025 header.b=ktMAaaSo; dkim=fail header.i=@chromium.org header.s=google header.b=NV191gEv; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i4si3407272pgr.266.2018.03.01.19.30.54; Thu, 01 Mar 2018 19:31:10 -0800 (PST) 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; dkim=fail header.i=@google.com header.s=20161025 header.b=ktMAaaSo; dkim=fail header.i=@chromium.org header.s=google header.b=NV191gEv; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1163953AbeCBCIg (ORCPT + 99 others); Thu, 1 Mar 2018 21:08:36 -0500 Received: from mail-wr0-f193.google.com ([209.85.128.193]:38817 "EHLO mail-wr0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1163696AbeCBCId (ORCPT ); Thu, 1 Mar 2018 21:08:33 -0500 Received: by mail-wr0-f193.google.com with SMTP id n7so8557668wrn.5 for ; Thu, 01 Mar 2018 18:08:33 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=FcsS+BNB8OvB8glm7P0L6q05xmCf5avhyci++E8pObY=; b=ktMAaaSon/c/tDKXYpKvlzfervhIAXk19iUiIeH2E1YYYYk1BsARadEsv8w/Yo+gqM wK96/wqmqyja8kmqs92fdeCL/7Rs+DcVisrXaRQakkosVzryDzKYxEq1YzLaCFmaMN/y 37dUrlaryJgPd1pRx6u5WrDSh3L8HyhiEZhdY3GhHMqMsnfYPR2Pq8HdRyC6h2oIHuaV MkMVRdkV8jyOYXzK8Go1gtjHNshgl/mfqcyrgukvkl7Z2R5odD4e7ROxZjsimb6DW61O qEYAHw4QyqPPPAR8WYetgyBWh6rRlqfmRHnk8bV6QRwvtiHb9FjEhbSNEmG5KfBABo2i gdgA== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=FcsS+BNB8OvB8glm7P0L6q05xmCf5avhyci++E8pObY=; b=NV191gEvYnkJN4uuqgpkcFQ1Oh0TJW5tkGIH+a/IODFez7PdQ9WLVUfT/bpqB1Mz8i B1LW4JnGHkOzECIlwlBkmCf6xHHKXuGBxWU4n2ATacC1Lnytk54hMppg0VwmZNNOjDSB zPNfLe/Xj0KyvOXv1BtYyNewyAMWjzr1Nf9m8= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:sender:in-reply-to:references:from :date:message-id:subject:to:cc; bh=FcsS+BNB8OvB8glm7P0L6q05xmCf5avhyci++E8pObY=; b=JrT5PdkKR+JEDtIi6MSNFaeGDC9qyEmG4H6rSmeGXxL1pG9Nsub7KhNIlfp8b5GS0v lKeFLUDAef4zietnfQijoAhRVun5broCejqYjsIyr6tMvaiU9Po3SV6esZFM54U17m3J 25lF11PN4f3N9Sv1bCxYx084yr3qZVdjQE3GZetLJ4lpb2vCrmW93rByeGNmYWdMtDcV Qq4rW39xfkwXFriuA7gjVeZ2sVq9c/948EN6JIQVyS3M6M5BtJrBYJClOuMyNtjfNAgz 0G/SmxAx625UP/hs0e7nXe23lIE1q7IGlex5j2NRT9JGBOzfeoqlWU5FeUaxpHJvtcBZ ++ZA== X-Gm-Message-State: APf1xPA/GbwrnAqW+YU0xFSF0mKk8MDhbhHPR0mjKPwK65dAlShueJgA RDccQ9p3DbX0XgtaiJ0aK7GPtcxWkH8e6TPRqXdHI68I X-Received: by 10.223.189.8 with SMTP id j8mr3796042wrh.20.1519956512488; Thu, 01 Mar 2018 18:08:32 -0800 (PST) MIME-Version: 1.0 Received: by 10.28.160.10 with HTTP; Thu, 1 Mar 2018 18:08:31 -0800 (PST) In-Reply-To: <0a74f87a-027a-df7d-ca2d-fc164ec9cdf7@arm.com> 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: "dbasehore ." Date: Thu, 1 Mar 2018 18:08:31 -0800 X-Google-Sender-Auth: STK8InTaVnMRxtWfXgaYL19H4CE Message-ID: Subject: Re: [PATCH v7 1/3] irqchip/gic-v3-its: add ability to save/restore ITS state To: Marc Zyngier 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 Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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. > > M. > -- > Jazz is not dead. It just smells funny...