Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3595550ybt; Tue, 30 Jun 2020 06:54:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwMo8iNgmdY50TSncKyaFd0mKA142EcMY9rSknVcfoPbx/g+sqWk+saCXj4rQTZRIIxahrd X-Received: by 2002:a17:907:94c4:: with SMTP id dn4mr17833179ejc.150.1593525294287; Tue, 30 Jun 2020 06:54:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593525294; cv=none; d=google.com; s=arc-20160816; b=RA8GmDDyUTWJqjuq2LMlgLp4kKicf+I00ga6LkMhOiX4NoXhGsJaaLWVNhnSjdgwnQ T8zpdIq1HVF+We8boSBFPPGDbJGTj2tAnTIKyC4EKE5BayNFdVy9U7lWzB2B+/7kkCg4 AAwZE8ULKfE4PKXB75vvhLyoAnQd2CQRqZhubammEyRGCWfAWEbyDc43gmFP88qTGc9D 8J+ajkW07Rtzq/WIgzdSUefo6CGMsuQUaVYy+DzmKrF/j5K7rQfmPk2W6oUTG+vP13cr g2BeN6JSEdpN217k+acu1oo4Puv2niNMvmkzuN9pRsrKu/Qfta5PlcjI4nhz2++vpxe0 A7pA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=0CFd2vrNZ7OLG6Iny9A0fU/wadNeNndeI5jl+7clJjY=; b=AiKrvsVEP3le2V6D9JI7frALrj0z7AYldXpXEsxWh0l3KZYh+HUZTaYeELHf2XE5q/ CcEGWydMaBu4AXsrh1OYshP6iMaJ1ZdckkTsuIaJeZvwueTCZ8pwZ0lLNKX3ktmN/sx2 Si8hJ8Uw+ka/tFD0RGgyb3dZoFTDXnMD66P3I+2sFazY9HPPGvuA5fUXrLbOzgihg+VN RoOcMrKOsq+UkMsYPGWmSbDNmrjKcYHbMK60vJ5fcBdpaRD2jKdBJQ7ge+B2HMF3jNuu GZkR6qAnfAUTWqmcH4wGp57u02PxDxGtTXJR3rRhpBpT9DYHFnVpPXVduLKtm+8Xuw5Z 7lYQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s21si379954edy.104.2020.06.30.06.54.30; Tue, 30 Jun 2020 06:54:54 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731789AbgF3Ni2 (ORCPT + 99 others); Tue, 30 Jun 2020 09:38:28 -0400 Received: from szxga05-in.huawei.com ([45.249.212.191]:6788 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1732994AbgF3NiY (ORCPT ); Tue, 30 Jun 2020 09:38:24 -0400 Received: from DGGEMS404-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 62F8ABE43F81FB854361; Tue, 30 Jun 2020 21:38:19 +0800 (CST) Received: from DESKTOP-8RFUVS3.china.huawei.com (10.174.185.226) by DGGEMS404-HUB.china.huawei.com (10.3.19.204) with Microsoft SMTP Server id 14.3.487.0; Tue, 30 Jun 2020 21:38:12 +0800 From: Zenghui Yu To: CC: , , , , , , Zenghui Yu Subject: [PATCH] irqchip/gic-v4.1: Use GFP_ATOMIC flag in allocate_vpe_l1_table() Date: Tue, 30 Jun 2020 21:37:46 +0800 Message-ID: <20200630133746.816-1-yuzenghui@huawei.com> X-Mailer: git-send-email 2.23.0.windows.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.174.185.226] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Booting the latest kernel with DEBUG_ATOMIC_SLEEP=y on a GICv4.1 enabled box, I get the following kernel splat: [ 0.053766] BUG: sleeping function called from invalid context at mm/slab.h:567 [ 0.053767] in_atomic(): 1, irqs_disabled(): 128, non_block: 0, pid: 0, name: swapper/1 [ 0.053769] CPU: 1 PID: 0 Comm: swapper/1 Not tainted 5.8.0-rc3+ #23 [ 0.053770] Call trace: [ 0.053774] dump_backtrace+0x0/0x218 [ 0.053775] show_stack+0x2c/0x38 [ 0.053777] dump_stack+0xc4/0x10c [ 0.053779] ___might_sleep+0xfc/0x140 [ 0.053780] __might_sleep+0x58/0x90 [ 0.053782] slab_pre_alloc_hook+0x7c/0x90 [ 0.053783] kmem_cache_alloc_trace+0x60/0x2f0 [ 0.053785] its_cpu_init+0x6f4/0xe40 [ 0.053786] gic_starting_cpu+0x24/0x38 [ 0.053788] cpuhp_invoke_callback+0xa0/0x710 [ 0.053789] notify_cpu_starting+0xcc/0xd8 [ 0.053790] secondary_start_kernel+0x148/0x200 # ./scripts/faddr2line vmlinux its_cpu_init+0x6f4/0xe40 its_cpu_init+0x6f4/0xe40: allocate_vpe_l1_table at drivers/irqchip/irq-gic-v3-its.c:2818 (inlined by) its_cpu_init_lpis at drivers/irqchip/irq-gic-v3-its.c:3138 (inlined by) its_cpu_init at drivers/irqchip/irq-gic-v3-its.c:5166 It turned out that we're allocating memory using GFP_KERNEL (may sleep) within the CPU hotplug notifier, which is indeed an atomic context. Bad thing may happen if we're playing on a system with more than a single CommonLPIAff group. Avoid it by turning this into an atomic allocation. Fixes: 5e5168461c22 ("irqchip/gic-v4.1: VPE table (aka GICR_VPROPBASER) allocation") Signed-off-by: Zenghui Yu --- drivers/irqchip/irq-gic-v3-its.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/irqchip/irq-gic-v3-its.c b/drivers/irqchip/irq-gic-v3-its.c index 6a5a87fc4601..b66eeca442c4 100644 --- a/drivers/irqchip/irq-gic-v3-its.c +++ b/drivers/irqchip/irq-gic-v3-its.c @@ -2814,7 +2814,7 @@ static int allocate_vpe_l1_table(void) if (val & GICR_VPROPBASER_4_1_VALID) goto out; - gic_data_rdist()->vpe_table_mask = kzalloc(sizeof(cpumask_t), GFP_KERNEL); + gic_data_rdist()->vpe_table_mask = kzalloc(sizeof(cpumask_t), GFP_ATOMIC); if (!gic_data_rdist()->vpe_table_mask) return -ENOMEM; @@ -2881,7 +2881,7 @@ static int allocate_vpe_l1_table(void) pr_debug("np = %d, npg = %lld, psz = %d, epp = %d, esz = %d\n", np, npg, psz, epp, esz); - page = alloc_pages(GFP_KERNEL | __GFP_ZERO, get_order(np * PAGE_SIZE)); + page = alloc_pages(GFP_ATOMIC | __GFP_ZERO, get_order(np * PAGE_SIZE)); if (!page) return -ENOMEM; -- 2.19.1