Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1986580imu; Fri, 14 Dec 2018 04:06:54 -0800 (PST) X-Google-Smtp-Source: AFSGD/Upl9xpi5nNsoI6x3Bfur1SRaDYEBV2SqVhPYie4xyiku3Ee3pkkksV31vsypzCxmfs0h6h X-Received: by 2002:a65:4784:: with SMTP id e4mr2446692pgs.12.1544789214820; Fri, 14 Dec 2018 04:06:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544789214; cv=none; d=google.com; s=arc-20160816; b=t3WubkSaTLLsqpugPfPgoKjRWkBweJxSk3vA6dcu2leBR3aO9cHattAm+CIXF0uUIq uCyuqCikRpHFcR/y2dIy/eKgfOOC2xHWjlhMXGvre3oVk/ctF5MmJBzZ3J62YE+JwFe8 X2TT6ysmnB9/du2n4Chg0GZ/ZvqA3rkxLUXyf9X2yCC98ifvLRYq5M4eUgP3fSdvb/Rq D5Quho0ZoAlbIiJ+/pteXtYGCOk6SgAPEbgrZM0tFKOJhR0Qm+vf24bAG5T89Y2fOQx3 4qCHy3xI65NugHPKyUuAqYZWB5YEewLCq2w2pLFmXE+7m+NVtzNRvsuizWK2P+tCjLZ6 7Ejw== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=n86q9PFQ7EyZ+mfG0ANBGz1IJ1l7chvzV2ejCE9QhrE=; b=d5JIycjXxabuAB4NQuQ6v4gCG6MjE77pYFOkzCHtypGQMl1TAIG3vK1G8bTyNoGmge 3/mEwap8Ot4Lli8yGQWzoixI6345wxHz2k1pCDPl66TQ+SC7NwscTJ6+snZx9R4KDq/K q/0TOQEI0kr/DKrT6owsKcM7od3ymOx2yF/vB/GEF1Ww1TesAIlKhQ3h8pnZwjPo3n80 GIrhYBD2QQi883WT3i8/dM01H0nuP4rxOVxzf2GwCUt1xD1HMKIfkp5lyxdlMRX87k9q fj/MBju3Qn/+RIBaPTXJI5AVZN6Dra6tTiIlRUqWgyl1hhUNgh7pOTPFFkhvZpENyXbL IyXg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="evSbd//Y"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j14si4085239pgi.354.2018.12.14.04.06.40; Fri, 14 Dec 2018 04:06:54 -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; dkim=pass header.i=@kernel.org header.s=default header.b="evSbd//Y"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730314AbeLNMD2 (ORCPT + 99 others); Fri, 14 Dec 2018 07:03:28 -0500 Received: from mail.kernel.org ([198.145.29.99]:47128 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729775AbeLNMD1 (ORCPT ); Fri, 14 Dec 2018 07:03:27 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 22DB32147D; Fri, 14 Dec 2018 12:03:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1544789006; bh=0rKXBEQeJBNeLa7TfmYmuOHN+xGbvlY52ISPWuGsLHc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=evSbd//YeTaVTu2vC83D+biAuEcOQMbFzNHSL/4irkrzOVMwNjJJYjqb6qGx742as kjZmJY4GamWCfqJMxSJtJnPiWbwKtnuS2eYx+yMmiv97U4MVrK8zDekS+WV8+aZJv1 M0Af8pFidCbZKDBLEh+LlteF/RQK8ZIhOLgLZ9iQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Naresh Kamboju , Roman Gushchin , Alexei Starovoitov , Daniel Borkmann , Sasha Levin Subject: [PATCH 4.19 058/142] bpf: allocate local storage buffers using GFP_ATOMIC Date: Fri, 14 Dec 2018 12:59:03 +0100 Message-Id: <20181214115749.382334320@linuxfoundation.org> X-Mailer: git-send-email 2.20.0 In-Reply-To: <20181214115747.053633987@linuxfoundation.org> References: <20181214115747.053633987@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 569a933b03f3c48b392fe67c0086b3a6b9306b5a ] Naresh reported an issue with the non-atomic memory allocation of cgroup local storage buffers: [ 73.047526] BUG: sleeping function called from invalid context at /srv/oe/build/tmp-rpb-glibc/work-shared/intel-corei7-64/kernel-source/mm/slab.h:421 [ 73.060915] in_atomic(): 1, irqs_disabled(): 0, pid: 3157, name: test_cgroup_sto [ 73.068342] INFO: lockdep is turned off. [ 73.072293] CPU: 2 PID: 3157 Comm: test_cgroup_sto Not tainted 4.20.0-rc2-next-20181113 #1 [ 73.080548] Hardware name: Supermicro SYS-5019S-ML/X11SSH-F, BIOS 2.0b 07/27/2017 [ 73.088018] Call Trace: [ 73.090463] dump_stack+0x70/0xa5 [ 73.093783] ___might_sleep+0x152/0x240 [ 73.097619] __might_sleep+0x4a/0x80 [ 73.101191] __kmalloc_node+0x1cf/0x2f0 [ 73.105031] ? cgroup_storage_update_elem+0x46/0x90 [ 73.109909] cgroup_storage_update_elem+0x46/0x90 cgroup_storage_update_elem() (as well as other update map update callbacks) is called with disabled preemption, so GFP_ATOMIC allocation should be used: e.g. alloc_htab_elem() in hashtab.c. Reported-by: Naresh Kamboju Tested-by: Naresh Kamboju Signed-off-by: Roman Gushchin Cc: Alexei Starovoitov Cc: Daniel Borkmann Signed-off-by: Alexei Starovoitov Signed-off-by: Sasha Levin --- kernel/bpf/local_storage.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/kernel/bpf/local_storage.c b/kernel/bpf/local_storage.c index 830d7f095748..fc1605aee5ea 100644 --- a/kernel/bpf/local_storage.c +++ b/kernel/bpf/local_storage.c @@ -138,7 +138,8 @@ static int cgroup_storage_update_elem(struct bpf_map *map, void *_key, return -ENOENT; new = kmalloc_node(sizeof(struct bpf_storage_buffer) + - map->value_size, __GFP_ZERO | GFP_USER, + map->value_size, + __GFP_ZERO | GFP_ATOMIC | __GFP_NOWARN, map->numa_node); if (!new) return -ENOMEM; -- 2.19.1