Received: by 2002:ab2:6857:0:b0:1ef:ffd0:ce49 with SMTP id l23csp2573044lqp; Mon, 25 Mar 2024 03:07:30 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXBaEEG4NmCTXSUeuSiw1jYIOwr610a3tbWAV5BbvG9SV1AamTLreFJ4Wp7NS7E5pGWjpHk5gHxoruc0ZUzUnru5VYi5nb/nx+OYynMnA== X-Google-Smtp-Source: AGHT+IHbvHfwlJNo0Z6FJywTPwCVAwQuLJZSoat3JvVxI3rcD5+o40AjEheFkO13irqgDghJL1Og X-Received: by 2002:a05:620a:4512:b0:78a:43d0:d19 with SMTP id t18-20020a05620a451200b0078a43d00d19mr8890878qkp.10.1711361250188; Mon, 25 Mar 2024 03:07:30 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1711361250; cv=pass; d=google.com; s=arc-20160816; b=uVMcdgG9vZmxUqt20o0m7767D4UEX1DK1IwZQ/g+tl2hT/PK5zKoR7JVqgwYbIw8mR TT/836I/4Qadz99Im5tC72KoofVpY9zsR4yop5e6a4vSZiS1B61CvKcsrA2ehkKsKMcY SMFpSWtBk71c00dICSWRmjalwl17kPFY9xMbGj+ZdO/d/yIOXscI1VlNcdiKgjOeFcib FJ+s9eqfH4uv548is+jProlYUUlbK9203Bt56ZEjUIbIaUjN50iISauuXcJvheBu51Fs p7b5gm8xjckOYC/rzTSEGDYfDjS2eZBib5VEmclqrZp9x3Wx6OkgBk4DGCOxFpnEVXoX Rk6A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=TU7jSKCiHpgXxLfjIgUe8+MRkBKUPYYxh/03QRy/7eQ=; fh=4sX0AQqkeIj0OfiW+ozFIhOM0fQ6NXViqGWq13GB+Rg=; b=mYEGXeGYFHqWfPwd0+NsOII5oVytxaoQv4SPxcjoRS1JcThu57MgjTEg/tHpHdW0D8 ySdtfsxKRpAycbFj6cMq1VeI2vRpXeM1ephxE+zm5CxZU5eAkWBWHSs4PVCWaZhfj+b3 xYkeGzZBdDsXZ/Vdi08Vfp5Ta5Y5DGtqWqSmswt1LKV6qiHbSUsjjt7y8gL9qYSZMx5J RudLTQ3MLhANI6pmaSczd9wxODBKsuOHb3YzIAnOh+koKCrxF0pgzVW63vNhsdwxwHDx m71hIhqEE/ufLgdUc+qaWjw+qKqsh7wxulGdqhSBxcN6EavBCg7G7Xi6EAvmC+0qzktT GkXA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=jzg21le6; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-116105-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-116105-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id z37-20020a05620a262500b0078a4e457384si3935475qko.455.2024.03.25.03.07.29 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Mar 2024 03:07:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-116105-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=jzg21le6; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-116105-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-116105-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id 2DE761C2CD51 for ; Mon, 25 Mar 2024 10:07:16 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 4128828DFB3; Mon, 25 Mar 2024 03:31:12 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="jzg21le6" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EC9B527F0A0; Sun, 24 Mar 2024 23:40:03 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323604; cv=none; b=JttY4WAmVX6S2ELOjyA9JxwnRfwlndZRu/EhWjJg9j/ybpcVG0BpT7xdrI8MUF0JQkcyvvzB0CpGWR4amwuWK8A0zrW7f8TGDoiMl5RO4E/q6aRUbb2OoQPhWily98X7VZzAHcgrSmFtJynGQahK3Y0ytcv0Ac8zbhXpr3RxCVM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1711323604; c=relaxed/simple; bh=34NgVSaXwpxNu1Y2kRUvJtxcbAIMn1pKbBU9bE04Kn4=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=pDAEVw0438cLrgegVCd2VZg9oPfm6nYK62cjFJbxhqcFwQwldaOAvW62/izrWb8rDn4bQcTrpg4x9jUuqivoywajPK5aIdAUbGUBlxW0qkhyQ5UVROiyioLYbgs9rtVBmZ14MWV+i7RZPzDtvCDjPee4RKnrEj+3JAUEvsIb7Ng= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=jzg21le6; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 06069C433B1; Sun, 24 Mar 2024 23:40:02 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1711323603; bh=34NgVSaXwpxNu1Y2kRUvJtxcbAIMn1pKbBU9bE04Kn4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jzg21le62SAyB1977WdYY3dL4j7nl+MVH0oDegAHn5Hs/lplq0dR4Mbn41LMo/L+k OmpaeHtRQc6uuAv4jG+IcMyE0M+3o72tkiIz6NxsnkksEMc29dRXig1/KGYbIbiftP gwNtzL1M8LdnUoBlqtymHt1jQ5cS1vkEyM91NS/n/t0J4nnI/ffli1DXWf5ybj2V5l W1CRLnNiClWTPDc/23IP+s1YgpQIrIZT8FdBFGJMidD2zyIX5zTYLsBwakqFeuZT2e sR0m7ZSq0W4t1r1zd2ArRbMOQMkTzUEUo4lQ/nWCtyYHMFDYR1rjUUsqRE0ocRPSom JFvubEwiGRoUQ== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Yan Zhai , Jesper Dangaard Brouer , "Paul E . McKenney" , Jakub Kicinski , Sasha Levin Subject: [PATCH 5.15 310/317] bpf: report RCU QS in cpumap kthread Date: Sun, 24 Mar 2024 19:34:50 -0400 Message-ID: <20240324233458.1352854-311-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240324233458.1352854-1-sashal@kernel.org> References: <20240324233458.1352854-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit From: Yan Zhai [ Upstream commit 00bf63122459e87193ee7f1bc6161c83a525569f ] When there are heavy load, cpumap kernel threads can be busy polling packets from redirect queues and block out RCU tasks from reaching quiescent states. It is insufficient to just call cond_resched() in such context. Periodically raise a consolidated RCU QS before cond_resched fixes the problem. Fixes: 6710e1126934 ("bpf: introduce new bpf cpu map type BPF_MAP_TYPE_CPUMAP") Reviewed-by: Jesper Dangaard Brouer Signed-off-by: Yan Zhai Acked-by: Paul E. McKenney Acked-by: Jesper Dangaard Brouer Link: https://lore.kernel.org/r/c17b9f1517e19d813da3ede5ed33ee18496bb5d8.1710877680.git.yan@cloudflare.com Signed-off-by: Jakub Kicinski Signed-off-by: Sasha Levin --- kernel/bpf/cpumap.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/kernel/bpf/cpumap.c b/kernel/bpf/cpumap.c index f7de5b313cc5b..a8429cfb4ae8c 100644 --- a/kernel/bpf/cpumap.c +++ b/kernel/bpf/cpumap.c @@ -305,6 +305,7 @@ static int cpu_map_bpf_prog_run(struct bpf_cpu_map_entry *rcpu, void **frames, static int cpu_map_kthread_run(void *data) { struct bpf_cpu_map_entry *rcpu = data; + unsigned long last_qs = jiffies; complete(&rcpu->kthread_running); set_current_state(TASK_INTERRUPTIBLE); @@ -330,10 +331,12 @@ static int cpu_map_kthread_run(void *data) if (__ptr_ring_empty(rcpu->queue)) { schedule(); sched = 1; + last_qs = jiffies; } else { __set_current_state(TASK_RUNNING); } } else { + rcu_softirq_qs_periodic(last_qs); sched = cond_resched(); } -- 2.43.0