Received: by 10.223.176.5 with SMTP id f5csp305476wra; Fri, 26 Jan 2018 23:58:34 -0800 (PST) X-Google-Smtp-Source: AH8x226aHOouieByiKgMNumr0rP73G6BgmK7aVr/g0Rl13rx8qr3dPG11SCmL71Q0Z+uYlzlgzaD X-Received: by 2002:a17:902:a03:: with SMTP id 3-v6mr14672252plo.282.1517039914177; Fri, 26 Jan 2018 23:58:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517039914; cv=none; d=google.com; s=arc-20160816; b=XaFDsMhrb57HJQwcsnyT9t2d5STq248aVmegkOa4jORPNf7+fVh4V6FVmnsqNIkTJn l0V459JcugZ4OQ0FJ5ZG6MwyA8XYnPSYIECj4cY9lIfeJIr+MYji5ARNLCX0JA7aUc/A VI0/ie7ipFHZYL+N8uF0AYBsMWmvlTqi94EjcnQWlImQv/KgmmscIywg/QKkyOkQaY8c LK1gZv7ryrxfCvweFZpkNEoirmSK4BTzJg30qc/ear8fST+CnnO6VOLXKOVBoNISMMQf wBlwjiO/P9WKId/EKiT/Lf1L7mG0Y4NWt/etwGe9cOASuMFNLbf19S7kzGYmXuID6YAp 7oFg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:user-agent:in-reply-to :content-disposition:mime-version:references:reply-to:subject:cc:to :from:date:arc-authentication-results; bh=B5xDVQHtWfDOXTGWR/lkjJuLWSDWaDBh/V46QHz/oAw=; b=WsTqSKlIiyqqqE68ajx+W4Uyc9gpRBugXdHHGztFFeq2tKk7TF4P4WUfA0cdUOPZ7v wxrm5BGZSjQsxVfw/5jrwf7fWii41CYD8/wO0wct6ViWnvkFgm8/tRmzozMXlwMwmG/o 5UPNfv5CYtggwaJFe9B4CLuiXMR3gb975M7pQWkkDnfp6mNCKhdhdegFfmy/uZKmMkfr 9zNYWgBXfiebeDNV36GyvgwXFRP1iwue5LNGitSLW/QhSXL33jIrF0jTCPDQtOMF+vXX /HmdV6KlB21t38/tFD96lE5FA4hYIl8nYCBuhue+DXNGzk0ZQ2Dpuhm3CzWmLq8F8Jel lXTQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v79si4115238pgb.185.2018.01.26.23.58.19; Fri, 26 Jan 2018 23:58:34 -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; 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=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751987AbeA0H5x (ORCPT + 99 others); Sat, 27 Jan 2018 02:57:53 -0500 Received: from mx0b-001b2d01.pphosted.com ([148.163.158.5]:42114 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751267AbeA0H5w (ORCPT ); Sat, 27 Jan 2018 02:57:52 -0500 Received: from pps.filterd (m0098417.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.22/8.16.0.22) with SMTP id w0R7rjrN095687 for ; Sat, 27 Jan 2018 02:57:52 -0500 Received: from e18.ny.us.ibm.com (e18.ny.us.ibm.com [129.33.205.208]) by mx0a-001b2d01.pphosted.com with ESMTP id 2frk0xbdy0-1 (version=TLSv1.2 cipher=AES256-SHA bits=256 verify=NOT) for ; Sat, 27 Jan 2018 02:57:51 -0500 Received: from localhost by e18.ny.us.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Sat, 27 Jan 2018 02:57:51 -0500 Received: from b01cxnp23032.gho.pok.ibm.com (9.57.198.27) by e18.ny.us.ibm.com (146.89.104.205) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; Sat, 27 Jan 2018 02:57:48 -0500 Received: from b01ledav003.gho.pok.ibm.com (b01ledav003.gho.pok.ibm.com [9.57.199.108]) by b01cxnp23032.gho.pok.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id w0R7vmgf44368116; Sat, 27 Jan 2018 07:57:48 GMT Received: from b01ledav003.gho.pok.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 36FE7B2050; Sat, 27 Jan 2018 02:54:46 -0500 (EST) Received: from paulmck-ThinkPad-W541 (unknown [9.80.203.246]) by b01ledav003.gho.pok.ibm.com (Postfix) with ESMTP id A8534B2046; Sat, 27 Jan 2018 02:54:43 -0500 (EST) Received: by paulmck-ThinkPad-W541 (Postfix, from userid 1000) id BEA3116C69C0; Fri, 26 Jan 2018 23:57:44 -0800 (PST) Date: Fri, 26 Jan 2018 23:57:44 -0800 From: "Paul E. McKenney" To: Lihao Liang Cc: "Guohanjun (Hanjun Guo)" , heng.z@huawei.com, hb.chen@huawei.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH RFC 00/16] A new RCU implementation based on a fast consensus protocol Reply-To: paulmck@linux.vnet.ibm.com References: <1516694381-20333-1-git-send-email-lianglihao@huawei.com> <20180125055356.GT3741@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) X-TM-AS-GCONF: 00 x-cbid: 18012707-0044-0000-0000-000003D6CF8A X-IBM-SpamModules-Scores: X-IBM-SpamModules-Versions: BY=3.00008435; HX=3.00000241; KW=3.00000007; PH=3.00000004; SC=3.00000248; SDB=6.00981002; UDB=6.00497342; IPR=6.00760301; BA=6.00005797; NDR=6.00000001; ZLA=6.00000005; ZF=6.00000009; ZB=6.00000000; ZP=6.00000000; ZH=6.00000000; ZU=6.00000002; MB=3.00019242; XFM=3.00000015; UTC=2018-01-27 07:57:50 X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 18012707-0045-0000-0000-000008063667 Message-Id: <20180127075744.GK3741@linux.vnet.ibm.com> X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2018-01-27_05:,, signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1709140000 definitions=main-1801270106 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Jan 27, 2018 at 07:22:27AM +0000, Lihao Liang wrote: > On Thu, Jan 25, 2018 at 5:53 AM, Paul E. McKenney > wrote: > > On Tue, Jan 23, 2018 at 03:59:25PM +0800, lianglihao@huawei.com wrote: > >> From: Lihao Liang > >> > >> Dear Paul, > >> > >> This patch set implements a preemptive version of RCU (PRCU) based on the following paper: > >> > >> Fast Consensus Using Bounded Staleness for Scalable Read-mostly Synchronization. > >> Haibo Chen, Heng Zhang, Ran Liu, Binyu Zang, and Haibing Guan. > >> IEEE Transactions on Parallel and Distributed Systems (TPDS), 2016. > >> https://dl.acm.org/citation.cfm?id=3024114.3024143 > >> > >> We have also added preliminary callback-handling support. Thus, the current version > >> provides APIs prcu_read_lock(), prcu_read_unlock(), synchronize_prcu(), call_prcu(), > >> and prcu_barrier(). > >> > >> This is an experimental patch, so it would be good to have some feedback. > >> > >> Known shortcoming is that the grace-period version is incremented in synchronize_prcu(). > >> If call_prcu() or prcu_barrier() is called but there is no synchronized_prcu() invoked, > >> callbacks cannot be invoked. Later version should address this issue, e.g. adding a > >> grace-period expedition mechanism. Others include to use a a hierarchical structure, > >> taking into account the NUMA topology, to send IPI in synchronize_prcu(). > >> > >> We have tested the implementation using rcutorture on both an x86 and ARM64 machine. > >> PRCU passed 1h and 3h tests on all the newly added config files except PRCU07 reported BUG > >> in a 1h run. > >> > >> [ 1593.604201] ---[ end trace b3bae911bec86152 ]--- > >> [ 1594.629450] prcu-torture:torture_onoff task: offlining 14 > >> [ 1594.755553] smpboot: CPU 14 is now offline > >> [ 1594.757732] prcu-torture:torture_onoff task: offlined 14 > >> [ 1597.765149] prcu-torture:torture_onoff task: onlining 11 > >> [ 1597.766795] smpboot: Booting Node 0 Processor 11 APIC 0xb > >> [ 1597.804102] prcu-torture:torture_onoff task: onlined 11 > >> [ 1599.365098] prcu-torture: rtc: ffffffffb0277b90 ver: 66358 tfle: 0 rta: 66358 rtaf: 0 > >> rtf: 66349 rtmbe: 0 rtbe: 1 rtbke: 0 rtbre: 0 rtbf: 0 rtb: 0 nt: 2233418 > >> onoff: 191/191:199/199 34,199:59,5102 10403:0 (HZ=1000) barrier: 188/189:1 cbflood: 225 > >> [ 1599.367946] prcu-torture: !!! > >> [ 1599.367966] ------------[ cut here ]------------ > > > > The "rtbe: 1" indicates that your implementation of prcu_barrier() > > failed to wait for all preceding call_prcu() callbacks to be invoked. > > > > Does the immediately following "Reader Pipe:" list have any but the > > first two numbers non-zero? > > Yes. If the third or subsequent numbers are non-zero, that would indicate too-short grace periods. This would be a critical bug in PRCU. > >> We have also compared PRCU with TREE RCU using rcuperf with gp_exp set to true, that is > >> synchronize_rcu_expedited was tested. > >> > >> The rcuperf results are as follows (average grace-period duration in ms of ten 10min runs): > >> > >> 16*Intel Xeon CPU@2.4GHz, 16GB memory, Ubuntu Linux 3.13.0-47-generic > >> > >> CPUs 2 4 8 12 15 16 > >> PRCU 0.14 1.07 4.15 8.02 10.79 15.16 > >> TREE 49.30 104.75 277.55 390.82 620.82 1381.54 > >> > >> 64*Cortex-A72 CPU@2.4GHz, 130GB memory, Ubuntu Linux 4.10.0-21.23-generic > >> > >> CPUs 2 4 8 16 32 48 63 64 > >> PRCU 0.23 19.69 38.28 63.21 95.41 167.18 252.01 1841.44 > >> TREE 416.73 901.89 1060.86 743.00 920.66 1325.21 1646.20 23806.27 > > > > Well, at the very least, this is a bug report on either expedited RCU > > grace-period latency or on rcuperf's measurements, and thank you for that. > > I will look into this. In the meantime, could you please let me know > > exactly how you invoked rcuperf? > > We used the following command to invoke rcuperf: > > sudo ./kvm.sh --torture rcuperf --duration 10 --configs 10*TREE > > The actual script run-rcuperf.sh to run the experiments can be found > in the following email of this patch series: > > [PATCH RFC 15/16] rcutorture: Add scripts to run experiments > > Please let us know how it goes. Will do! As I said before, at the very least you have identified a performance bug in RCU expedited grace periods. Thanx, Paul > Many thanks, > Lihao. > > > I have a few comments on some of your patches based on a quick scan > > through them. > > > > Thanx, Paul > > > >> Best wishes, > >> Lihao. > >> > >> > >> Lihao Liang (15): > >> rcutorture: Add PRCU rcu_torture_ops > >> rcutorture: Add PRCU test config files > >> rcuperf: Add PRCU rcu_perf_ops > >> rcuperf: Add PRCU test config files > >> rcuperf: Set gp_exp to true for tests to run > >> prcu: Implement call_prcu() API > >> prcu: Implement PRCU callback processing > >> prcu: Implement prcu_barrier() API > >> rcutorture: Test call_prcu() and prcu_barrier() > >> rcutorture: Add basic ARM64 support to run scripts > >> prcu: Add PRCU Kconfig parameter > >> prcu: Comment source code > >> rcuperf: Add config files with various CONFIG_NR_CPUS > >> rcutorture: Add scripts to run experiments > >> Add GPLv2 license > >> > >> Heng Zhang (1): > >> prcu: Add PRCU implementation > >> > >> include/linux/interrupt.h | 3 + > >> include/linux/prcu.h | 122 +++++ > >> include/linux/rcupdate.h | 1 + > >> init/Kconfig | 7 + > >> init/main.c | 2 + > >> kernel/rcu/Makefile | 1 + > >> kernel/rcu/prcu.c | 497 +++++++++++++++++++++ > >> kernel/rcu/rcuperf.c | 33 +- > >> kernel/rcu/rcutorture.c | 40 +- > >> kernel/rcu/tree.c | 1 + > >> kernel/sched/core.c | 2 + > >> kernel/time/timer.c | 2 + > >> kvm.sh | 452 +++++++++++++++++++ > >> run-rcuperf.sh | 26 ++ > >> .../testing/selftests/rcutorture/bin/functions.sh | 17 +- > >> .../selftests/rcutorture/configs/rcu/CFLIST | 5 + > >> .../selftests/rcutorture/configs/rcu/PRCU02 | 27 ++ > >> .../selftests/rcutorture/configs/rcu/PRCU02.boot | 1 + > >> .../selftests/rcutorture/configs/rcu/PRCU03 | 23 + > >> .../selftests/rcutorture/configs/rcu/PRCU03.boot | 2 + > >> .../selftests/rcutorture/configs/rcu/PRCU06 | 26 ++ > >> .../selftests/rcutorture/configs/rcu/PRCU06.boot | 5 + > >> .../selftests/rcutorture/configs/rcu/PRCU07 | 25 ++ > >> .../selftests/rcutorture/configs/rcu/PRCU07.boot | 2 + > >> .../selftests/rcutorture/configs/rcu/PRCU09 | 19 + > >> .../selftests/rcutorture/configs/rcu/PRCU09.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/CFLIST | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU | 20 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-12 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-12.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-14 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-14.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-15 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-15.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-16 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-16.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-2 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-2.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-32 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-32.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-4 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-4.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-48 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-48.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-56 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-56.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-60 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-60.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-62 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-62.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-64 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-64.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU-8 | 21 + > >> .../rcutorture/configs/rcuperf/PRCU-8.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/PRCU.boot | 1 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-12 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-14 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-15 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-16 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-2 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-32 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-4 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-48 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-56 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-60 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-62 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-64 | 21 + > >> .../selftests/rcutorture/configs/rcuperf/TREE-8 | 21 + > >> 68 files changed, 1918 insertions(+), 5 deletions(-) > >> create mode 100644 include/linux/prcu.h > >> create mode 100644 kernel/rcu/prcu.c > >> create mode 100755 kvm.sh > >> create mode 100755 run-rcuperf.sh > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU02 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU02.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU03 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU03.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU06 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU06.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU07 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU07.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU09 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcu/PRCU09.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-12 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-12.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-14 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-14.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-15 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-15.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-16 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-16.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-2 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-2.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-32 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-32.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-4 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-4.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-48 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-48.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-56 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-56.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-60 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-60.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-62 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-62.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-64 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-64.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-8 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU-8.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/PRCU.boot > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-12 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-14 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-15 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-16 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-2 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-32 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-4 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-48 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-56 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-60 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-62 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-64 > >> create mode 100644 tools/testing/selftests/rcutorture/configs/rcuperf/TREE-8 > >> > >> -- > >> 2.14.1.729.g59c0ea183 > >> > > >