Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1498113ybh; Sun, 19 Jul 2020 22:49:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxA0/5CmKN19bPyhDlCY2ANM7ultEszJ4ytcovcvNxUZA8OOfed0dGWiHveff8mO6aXEfnL X-Received: by 2002:a17:906:410c:: with SMTP id j12mr18982312ejk.284.1595224192606; Sun, 19 Jul 2020 22:49:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595224192; cv=none; d=google.com; s=arc-20160816; b=dovsbPDqEwUhjZEt0cKGiCthdriHjnOv3MDEIKDuHwnxgYC/lkuW30m5FEV8oT1ZOn caPyFuWUwO1Box0TVNwz1wyiDkOFwDef7A5JoJ7aH0x+VZJSnRA6CyE0b+MfHhpn0RLd dG+mzSVSEAtAgtxUWRbQEzHLpEg3ajNZOFUvnB9fU8d2sIUc383DgeqrkrPuS+EowsdA 8ZdU17WnaxIE60sWzpxGOVYsdPtpDkc5met2hOmOjmCc8sgkLO8PNefeDpZshzuDB0ZL QuGvDIH30By4Zuf3R37PzffDKBkJMJYIk1ezubKx8ScxC8l3+cn1F+JGN7fl+h7NqEr2 nxaA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:reply-to:message-id:subject:cc:to:from:date; bh=FBoCXIUGQGy0P89xCra0zc6ppM8nk9waLTvSfoCZ8gU=; b=gnZrbizcTrsMyUrgUuHxvegUPTxlawX1UlrIcfBIyhQg8ht/WyxaV5zbfzwvObDeOT JPM3Px6KEv3u0z1btfCAGjCfvcv5dT2e69shIRgSBkFrgFUrxsnIJwkbbDojGz9YEoYV 10V/YRtJcLV0XH6YxDA3u34iz6u6G0UMntNkZkegunOza6C6y1nM8BVdsFSQfHS93TDf P8Bwvk/paKvXn3ppu+CsnUSN/oQ6C1DbJCs/TtxRe9Wu0TEl9lej3GC+RHqdXuUSeNKn hwh8x+Q//aAmYm5RRvZaDkbSaVvzISxLmKUaVYXg9z6n/hII1I0NrjRXBqUY6QNIQJoU Cxdw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: 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 60si10185505edp.566.2020.07.19.22.49.28; Sun, 19 Jul 2020 22:49:52 -0700 (PDT) Received-SPF: pass (google.com: 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: 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 S1726483AbgGTFtD (ORCPT + 99 others); Mon, 20 Jul 2020 01:49:03 -0400 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:10774 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725805AbgGTFtD (ORCPT ); Mon, 20 Jul 2020 01:49:03 -0400 Received: from pps.filterd (m0098413.ppops.net [127.0.0.1]) by mx0b-001b2d01.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 06K5V4J0089870; Mon, 20 Jul 2020 01:48:57 -0400 Received: from pps.reinject (localhost [127.0.0.1]) by mx0b-001b2d01.pphosted.com with ESMTP id 32bu7r1835-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 20 Jul 2020 01:48:57 -0400 Received: from m0098413.ppops.net (m0098413.ppops.net [127.0.0.1]) by pps.reinject (8.16.0.36/8.16.0.36) with SMTP id 06K5VO5Z090716; Mon, 20 Jul 2020 01:48:57 -0400 Received: from ppma03ams.nl.ibm.com (62.31.33a9.ip4.static.sl-reverse.com [169.51.49.98]) by mx0b-001b2d01.pphosted.com with ESMTP id 32bu7r182e-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 20 Jul 2020 01:48:57 -0400 Received: from pps.filterd (ppma03ams.nl.ibm.com [127.0.0.1]) by ppma03ams.nl.ibm.com (8.16.0.42/8.16.0.42) with SMTP id 06K5jZqx023895; Mon, 20 Jul 2020 05:48:55 GMT Received: from b06cxnps3074.portsmouth.uk.ibm.com (d06relay09.portsmouth.uk.ibm.com [9.149.109.194]) by ppma03ams.nl.ibm.com with ESMTP id 32brq7j7e9-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 20 Jul 2020 05:48:55 +0000 Received: from d06av21.portsmouth.uk.ibm.com (d06av21.portsmouth.uk.ibm.com [9.149.105.232]) by b06cxnps3074.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 06K5mrdU32833938 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Mon, 20 Jul 2020 05:48:53 GMT Received: from d06av21.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 3CA765205A; Mon, 20 Jul 2020 05:48:53 +0000 (GMT) Received: from drishya.in.ibm.com (unknown [9.85.113.150]) by d06av21.portsmouth.uk.ibm.com (Postfix) with ESMTPS id 9022952051; Mon, 20 Jul 2020 05:48:51 +0000 (GMT) Date: Mon, 20 Jul 2020 11:18:49 +0530 From: Vaidyanathan Srinivasan To: "Gautham R. Shenoy" Cc: Nicholas Piggin , Anton Blanchard , Nathan Lynch , Michael Ellerman , Michael Neuling , linuxppc-dev@ozlabs.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org Subject: Re: [PATCH 0/5] cpuidle-pseries: Parse extended CEDE information for idle. Message-ID: <20200720054849.GA4000@drishya.in.ibm.com> Reply-To: svaidy@linux.ibm.com References: <1594120299-31389-1-git-send-email-ego@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline In-Reply-To: <1594120299-31389-1-git-send-email-ego@linux.vnet.ibm.com> X-TM-AS-GCONF: 00 X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.235,18.0.687 definitions=2020-07-20_01:2020-07-17,2020-07-20 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 suspectscore=1 impostorscore=0 adultscore=0 malwarescore=0 priorityscore=1501 spamscore=0 lowpriorityscore=0 mlxlogscore=999 clxscore=1011 phishscore=0 mlxscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2006250000 definitions=main-2007200038 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Gautham R Shenoy [2020-07-07 16:41:34]: > From: "Gautham R. Shenoy" > > Hi, > > On pseries Dedicated Linux LPARs, apart from the polling snooze idle > state, we currently have the CEDE idle state which cedes the CPU to > the hypervisor with latency-hint = 0. > > However, the PowerVM hypervisor supports additional extended CEDE > states, which can be queried through the "ibm,get-systems-parameter" > rtas-call with the CEDE_LATENCY_TOKEN. The hypervisor maps these > extended CEDE states to appropriate platform idle-states in order to > provide energy-savings as well as shifting power to the active > units. On existing pseries LPARs today we have extended CEDE with > latency-hints {1,2} supported. > > In Patches 1-3 of this patchset, we add the code to parse the CEDE > latency records provided by the hypervisor. We use this information to > determine the wakeup latency of the regular CEDE (which we have been > so far hardcoding to 10us while experimentally it is much lesser ~ > 1us), by looking at the wakeup latency provided by the hypervisor for > Extended CEDE states. Since the platform currently advertises Extended > CEDE 1 to have wakeup latency of 2us, we can be sure that the wakeup > latency of the regular CEDE is no more than this. > > Patch 4 (currently marked as RFC), expose the extended CEDE states > parsed above to the cpuidle framework, provided that they can wakeup > on an interrupt. On current platforms only Extended CEDE 1 fits the > bill, but this is going to change in future platforms where even > Extended CEDE 2 may be responsive to external interrupts. > > Patch 5 (currently marked as RFC), filters out Extended CEDE 1 since > it offers no added advantage over the normal CEDE. > > With Patches 1-3, we see an improvement in the single-threaded > performance on ebizzy. > > 2 ebizzy threads bound to the same big-core. 25% improvement in the > avg records/s (higher the better) with patches 1-3. > x without_patches > * with_patches > N Min Max Median Avg Stddev > x 10 2491089 5834307 5398375 4244335 1596244.9 > * 10 2893813 5834474 5832448 5327281.3 1055941.4 > > We do not observe any major regression in either the context_switch2 > benchmark or the schbench benchmark > > context_switch2 across CPU0 CPU1 (Both belong to same big-core, but different > small cores). We observe a minor 0.14% regression in the number of > context-switches (higher is better). > x without_patch > * with_patch > N Min Max Median Avg Stddev > x 500 348872 362236 354712 354745.69 2711.827 > * 500 349422 361452 353942 354215.4 2576.9258 > > context_switch2 across CPU0 CPU8 (Different big-cores). We observe a 0.37% > improvement in the number of context-switches (higher is better). > x without_patch > * with_patch > N Min Max Median Avg Stddev > x 500 287956 294940 288896 288977.23 646.59295 > * 500 288300 294646 289582 290064.76 1161.9992 > > schbench: > No major difference could be seen until the 99.9th percentile. > > Without-patch > Latency percentiles (usec) > 50.0th: 29 > 75.0th: 39 > 90.0th: 49 > 95.0th: 59 > *99.0th: 13104 > 99.5th: 14672 > 99.9th: 15824 > min=0, max=17993 > > With-patch: > Latency percentiles (usec) > 50.0th: 29 > 75.0th: 40 > 90.0th: 50 > 95.0th: 61 > *99.0th: 13648 > 99.5th: 14768 > 99.9th: 15664 > min=0, max=29812 This patch series mainly cleans up the CEDE latency discovery and prepares to add different cpuidle states in virtualised environment. This helps in improving SMT folding speeds and also power savings and power shifting with newer platform firmware. The current benefit is primarily from faster SMT folding and resulting single performance achieved by updating the platform firmware provided heuristics in the cpuidle states. --Vaidy