Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp489824ybz; Wed, 15 Apr 2020 12:36:21 -0700 (PDT) X-Google-Smtp-Source: APiQypIuKY03+Eo5Vtqbft4tULIjPL3CN48Ejir2xNQSWfzVAEUdZxLZLCUT5YMS9Zj2J59PwAOt X-Received: by 2002:a05:6402:31b6:: with SMTP id dj22mr14790392edb.258.1586979381780; Wed, 15 Apr 2020 12:36:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586979381; cv=none; d=google.com; s=arc-20160816; b=pQ075UND6agTeHi4oWgpiK+YSnM5jLM8BdEFvwqCc3wghml1Wkk28Xa0j8cHSPoqz8 ceTB7FE//3I5SgFUnfEwLw9sROVN5fqlA23ftzNM9dOXiExYdXpavlglrgStlFSwKUsw /r9QDtzIBcCAIbypJNYVWBFtKEVdVrSgW8G9sMNxTEGPX5bNWyPSNUv9RfLjNXJh8yt2 FmOi8PCFQU2rB+3Z2B1jtUdgbd04k3qvn1Li/eZ+j7wuWs5dcqMgpRKZtDHAb7rPaVSS 1cmwdpmIgQLZxAFk4bUa6C674sAgSwX9RgmEeCk0uZwmOLpRYMOrG7kmZwsCQvthh12b ifgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:reply-to:message-id :subject:cc:to:from:date; bh=UD0ohAyO0uMfY2Xg5YGwCXSR5LDvv03FlmASbvrLfuo=; b=nCUo/74R3z1ORaFhAHrp+BCHTV2LVKacPuBpwWgatpHKUgz12dLP/OpgNtROwkaaPk d05dVGf/D/qVo/NVLbZeDHFPtVsZhrR1gHSNMI7MUdNkZOPy6UblKy/3QUgxfQUzIr+V 5/aY/wIlzlGESXpLhOiq1LrAlaYUXWwQQ6AhiK4B+5Ze8YTVxaWcwl5R6BHw3Aeterfb dTBH8M9oFSIiXrWdoHi/gbt16GJgLF6HtkgKmaEo1MravWWa2g0hDFbYPWJlNsbUHjHS ZO+J2GI5CboKPpcsMZ/A5+XMM6gS1B0ck5k9tD2RPZzKJddR0Ant/gnwmRbLaFHU30PA w2EA== 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 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y4si10817348edy.398.2020.04.15.12.35.55; Wed, 15 Apr 2020 12:36:21 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2438317AbgDNK0H (ORCPT + 99 others); Tue, 14 Apr 2020 06:26:07 -0400 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:60126 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2438286AbgDNKVV (ORCPT ); Tue, 14 Apr 2020 06:21:21 -0400 Received: from pps.filterd (m0098396.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 03EA35YJ060749; Tue, 14 Apr 2020 06:20:22 -0400 Received: from pps.reinject (localhost [127.0.0.1]) by mx0a-001b2d01.pphosted.com with ESMTP id 30cwm05pdd-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 14 Apr 2020 06:20:22 -0400 Received: from m0098396.ppops.net (m0098396.ppops.net [127.0.0.1]) by pps.reinject (8.16.0.36/8.16.0.36) with SMTP id 03EA3etk063999; Tue, 14 Apr 2020 06:20:21 -0400 Received: from ppma02wdc.us.ibm.com (aa.5b.37a9.ip4.static.sl-reverse.com [169.55.91.170]) by mx0a-001b2d01.pphosted.com with ESMTP id 30cwm05pcw-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 14 Apr 2020 06:20:21 -0400 Received: from pps.filterd (ppma02wdc.us.ibm.com [127.0.0.1]) by ppma02wdc.us.ibm.com (8.16.0.27/8.16.0.27) with SMTP id 03EAFWfA003461; Tue, 14 Apr 2020 10:20:20 GMT Received: from b03cxnp07029.gho.boulder.ibm.com (b03cxnp07029.gho.boulder.ibm.com [9.17.130.16]) by ppma02wdc.us.ibm.com with ESMTP id 30b5h67qs2-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 14 Apr 2020 10:20:20 +0000 Received: from b03ledav006.gho.boulder.ibm.com (b03ledav006.gho.boulder.ibm.com [9.17.130.237]) by b03cxnp07029.gho.boulder.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 03EAKJ8n52101384 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 14 Apr 2020 10:20:19 GMT Received: from b03ledav006.gho.boulder.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 8AFAAC6059; Tue, 14 Apr 2020 10:20:19 +0000 (GMT) Received: from b03ledav006.gho.boulder.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id D0C80C6055; Tue, 14 Apr 2020 10:20:18 +0000 (GMT) Received: from sofia.ibm.com (unknown [9.85.109.81]) by b03ledav006.gho.boulder.ibm.com (Postfix) with ESMTP; Tue, 14 Apr 2020 10:20:18 +0000 (GMT) Received: by sofia.ibm.com (Postfix, from userid 1000) id F27BF2E301A; Tue, 14 Apr 2020 12:41:49 +0530 (IST) Date: Tue, 14 Apr 2020 12:41:49 +0530 From: Gautham R Shenoy To: Pratik Rajesh Sampat Cc: linux-kernel@vger.kernel.org, linuxppc-dev@ozlabs.org, mpe@ellerman.id.au, skiboot@lists.ozlabs.org, oohall@gmail.com, ego@linux.vnet.ibm.com, linuxram@us.ibm.com, pratik.r.sampat@gmail.com Subject: Re: [PATCH v6 0/3] powerpc/powernv: Introduce interface for self-restore support Message-ID: <20200414071149.GD24277@in.ibm.com> Reply-To: ego@linux.vnet.ibm.com References: <20200326071034.12838-1-psampat@linux.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200326071034.12838-1-psampat@linux.ibm.com> User-Agent: Mutt/1.5.23 (2014-03-12) X-TM-AS-GCONF: 00 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.138,18.0.676 definitions=2020-04-14_02:2020-04-13,2020-04-14 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxlogscore=999 phishscore=0 suspectscore=0 adultscore=0 mlxscore=0 malwarescore=0 priorityscore=1501 impostorscore=0 lowpriorityscore=0 spamscore=0 clxscore=1015 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2003020000 definitions=main-2004140083 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hello Pratik, On Thu, Mar 26, 2020 at 12:40:31PM +0530, Pratik Rajesh Sampat wrote: > v5: https://lkml.org/lkml/2020/3/17/944 > Changelog > v5-->v6 > 1. Updated background, motivation and illuminated potential design > choices > 2. Re-organization of patch-set > a. Split introducing preference for optimization from 1/1 to patch 3/3 > b. Merge introducing self-save API and parsing the device-tree > c. Introduce a supported mode called KERNEL_SAVE_RESTORE which > outlines and makes kernel supported SPRs for save-restore more > explicit > [..snip..] > Presenting the design choices in front of us: > > Design-Choice 1: > ---------------- > A simple implementation is to just replace self-restore calls with > self-save as it is direct super-set. > > Pros: > A simple design, quick to implement > > > Cons: > * Breaks backward compatibility. Self-restore has historically been > supported in the firmware and an old firmware running on an new > kernel will be incompatible and deep stop states will be cut. > * Furthermore, critical SPRs which need to be restored > before 0x100 vector like HID0 are not supported by self-save. > > Design-Choice 2: > ---------------- > Advertise both self-restore and self-save from OPAL including the set > of registers that each support. The kernel can then choose which API > to go with. > For the sake of simplicity, in case both modes are supported for an > SPR by default self-save would be called for it. > > Pros: > * Backwards compatible > > Cons: > Overhead in parsing device tree with the SPR list > > Possible optimization with Approach2: > ------------------------------------- > There are SPRs whose values don't tend to change over time and invoking > self-save on them, where the values are gotten each time may turn out to > be inefficient. In that case calling a self-restore where passing the > value makes more sense as, if the value is same, the memory location > is not updated. > SPRs that dont change are as follows: > SPRN_HSPRG0, > SPRN_LPCR, > SPRN_PTCR, > SPRN_HMEER, > SPRN_HID0, We can just pick self-save wherever available and fallback to self-restore when self-save support is not avaiable for any SPR. The optimization that you mention here can be revisited if the additional latency due to self-save becomes observable (Note that both stop4 and stop5 have wakeup latency between 200-500us). > > The values of PSSCR and MSR change at runtime and hence, the kernel > cannot determine during boot time what their values will be before > entering a particular deep-stop state. > > Therefore, a preference based interface is introduced for choosing > between self-save or self-restore between for each SPR. > The per-SPR preference is only a refinement of > approach 2 purely for performance reasons. It can be dropped if the > complexity is not deemed worth the returns. > > Patches Organization > ==================== > Design Choice 2 has been chosen as an implementation to demonstrate in > the patch series. > > Patch1: > Devises an interface which lists all the interested SPRs, along with > highlighting the support of mode. > It is an isomorphic patch to replicate the functionality of the older > self-restore firmware for the new interface > > Patch2: > Introduces the self-save API and leverages upon the struct interface to > add another supported mode in the mix of saving and restoring. It also > enforces that in case both modes are supported self-save is chosen over > self-restore > > The commit also parses the device-tree and populate support for > self-save and self-restore in the supported mask > > Patch3: > Introduce an optimization to allow preference to choose between one more > over the one when both both modes are supported. This optimization can > allow for better performance for the SPRs that don't change in value and > hence self-restore is a better alternative, and in cases when it is > known for values to change self-save is more convenient. > > Pratik Rajesh Sampat (3): > powerpc/powernv: Introduce interface for self-restore support > powerpc/powernv: Introduce support and parsing for self-save API > powerpc/powernv: Preference optimization for SPRs with constant values > > .../bindings/powerpc/opal/power-mgt.txt | 18 + > arch/powerpc/include/asm/opal-api.h | 3 +- > arch/powerpc/include/asm/opal.h | 1 + > arch/powerpc/platforms/powernv/idle.c | 385 +++++++++++++++--- > arch/powerpc/platforms/powernv/opal-call.c | 1 + > 5 files changed, 351 insertions(+), 57 deletions(-) > > -- > 2.17.1 >