Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp218207pxp; Wed, 9 Mar 2022 01:14:24 -0800 (PST) X-Google-Smtp-Source: ABdhPJwZJNv3H+qA9QJFxAQDUrJP9ONAwYJmx56PzjhRKrvR8eUj4SuwPA5AttM8g+E95TYIBAkV X-Received: by 2002:a05:6402:5304:b0:413:8a0c:c54a with SMTP id eo4-20020a056402530400b004138a0cc54amr19978745edb.172.1646817263721; Wed, 09 Mar 2022 01:14:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1646817263; cv=none; d=google.com; s=arc-20160816; b=g5KtRh58nZThWpO0HPM/mtW/J6wqtCKM/WTcWqIi/xbp6qeMFXUECJI8/rZLzS15zi cujF+zza7zBjuoc9zuG7MkLQmCKK5KCoTkiaUr7lN44CmO9/WveFUd+UMJHEpxaFAcHc WaYmx//GXr9WsjJ89YQa8I4siWEPhw/IF2OEh66zJeDT+dV4wYyQjtPsMdxAynOmocaS 1Pg3ocukaz3QGfCV7+29jOUbB2k/XwN+qEya3kVmEpbCQv2MsvArTqqSjdi7PNoyPMDI alPQhIQqIS/P71qhgWmmDOFSMA8vq4neCShxngISkKJdUUIuGeXNKaib74qdXEiG2YtZ WSoA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=CaCAAvfDCDaoKxEdA66+fje/StGnTpKfrPr4efsjt/s=; b=t+RbsCYKB2e38HEoZ1OZH9n7tj7d6OiFn1e1w70I2GAG4WTGRMfLum6ezUeOojQoaU vS0kzoLdpDkB8BHWn12qYDNXaRl25MKqiUkhKbEzEZMq8NRAeI3K0TAOAhVZShRI1MEJ MpoU9qnVGnFDJ0fTMxi/sTUUBeqj5WLbHT1uAWSNV/vKUKPAYxJWvEXY/DpyB0e9dnQg UPxS5ow+5Y9udfGll1yMSh3qSju+BHXrJYsI4Q+xiXws1sK3y7BmKEEVwOSEFlrwxWN3 4T0kKYNZSPzqjXYT8JTDn8+zSbDrHnM1FhvIdYCKLPNqES81CCYjoSjmhEwuD9bzhP1W 7c4A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ho9-20020a1709070e8900b006db19d8837csi976624ejc.871.2022.03.09.01.14.00; Wed, 09 Mar 2022 01:14:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231344AbiCIIUz (ORCPT + 99 others); Wed, 9 Mar 2022 03:20:55 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45982 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229955AbiCIIUm (ORCPT ); Wed, 9 Mar 2022 03:20:42 -0500 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A2736166A58; Wed, 9 Mar 2022 00:19:41 -0800 (PST) Received: from kwepemi500005.china.huawei.com (unknown [172.30.72.55]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4KD4k241ZNzbc0G; Wed, 9 Mar 2022 16:14:50 +0800 (CST) Received: from kwepemm600017.china.huawei.com (7.193.23.234) by kwepemi500005.china.huawei.com (7.221.188.179) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.21; Wed, 9 Mar 2022 16:19:39 +0800 Received: from localhost.localdomain (10.175.112.125) by kwepemm600017.china.huawei.com (7.193.23.234) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2308.21; Wed, 9 Mar 2022 16:19:38 +0800 From: Peng Liu To: , , , , , , , , , CC: , Subject: [PATCH v2 3/3] kfence: test: try to avoid test_gfpzero trigger rcu_stall Date: Wed, 9 Mar 2022 08:37:53 +0000 Message-ID: <20220309083753.1561921-4-liupeng256@huawei.com> X-Mailer: git-send-email 2.18.0.huawei.25 In-Reply-To: <20220309083753.1561921-1-liupeng256@huawei.com> References: <20220309083753.1561921-1-liupeng256@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.112.125] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To kwepemm600017.china.huawei.com (7.193.23.234) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When CONFIG_KFENCE_NUM_OBJECTS is set to a big number, kfence kunit-test-case test_gfpzero will eat up nearly all the CPU's resources and rcu_stall is reported as the following log which is cut from a physical server. rcu: INFO: rcu_sched self-detected stall on CPU rcu: 68-....: (14422 ticks this GP) idle=6ce/1/0x4000000000000002 softirq=592/592 fqs=7500 (t=15004 jiffies g=10677 q=20019) Task dump for CPU 68: task:kunit_try_catch state:R running task stack: 0 pid: 9728 ppid: 2 flags:0x0000020a Call trace: dump_backtrace+0x0/0x1e4 show_stack+0x20/0x2c sched_show_task+0x148/0x170 ... rcu_sched_clock_irq+0x70/0x180 update_process_times+0x68/0xb0 tick_sched_handle+0x38/0x74 ... gic_handle_irq+0x78/0x2c0 el1_irq+0xb8/0x140 kfree+0xd8/0x53c test_alloc+0x264/0x310 [kfence_test] test_gfpzero+0xf4/0x840 [kfence_test] kunit_try_run_case+0x48/0x20c kunit_generic_run_threadfn_adapter+0x28/0x34 kthread+0x108/0x13c ret_from_fork+0x10/0x18 To avoid rcu_stall and unacceptable latency, a schedule point is added to test_gfpzero. Signed-off-by: Peng Liu --- mm/kfence/kfence_test.c | 1 + 1 file changed, 1 insertion(+) diff --git a/mm/kfence/kfence_test.c b/mm/kfence/kfence_test.c index caed6b4eba94..1b50f70a4c0f 100644 --- a/mm/kfence/kfence_test.c +++ b/mm/kfence/kfence_test.c @@ -627,6 +627,7 @@ static void test_gfpzero(struct kunit *test) kunit_warn(test, "giving up ... cannot get same object back\n"); return; } + cond_resched(); } for (i = 0; i < size; i++) -- 2.18.0.huawei.25