Received: by 2002:ac0:e350:0:0:0:0:0 with SMTP id g16csp220978imn; Thu, 4 Aug 2022 03:21:56 -0700 (PDT) X-Google-Smtp-Source: AA6agR4yRW6IUeeZgFer48ppLSbPitBwag+PE5ibM2D/6UlBwvP6FRMdVBCHkkmi9xUcwseVebGu X-Received: by 2002:a17:90b:4c07:b0:1f5:40a:8040 with SMTP id na7-20020a17090b4c0700b001f5040a8040mr9656657pjb.121.1659608516112; Thu, 04 Aug 2022 03:21:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659608516; cv=none; d=google.com; s=arc-20160816; b=yt5R56CvWt9/ruc/tuYOTPLw1O01GEM9SbbWIqjBWOWvx0KD4BoGdHJSJQUZar7Dt0 i/qVbLxyY+XjnuPpIdw9ecUR3CKOqjXSMoxoSYPXzBpQH4E6Bp7zVd4XnH3Hb/3lH78D vsM1E9qpOTPse6P3K+s+aZ3jeZnITKhRAqVU1GdRYAyX7iCwZc8pIJA9AMR+tMYeRHkn HtBsaWvtdb47RrbXqqI3vssLmZMGQ12mbXaYhbvOUOjr+x/yHonC1rEjM5OF10MnUxTp qlJqy/H6ALXSXrfcmuy5Bej0sS+NkNVa7GQmEHjxdBpRHh3iwEzN72kXxjUnW+aD8wfi SqRw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=QVj5FTcefmNqJMot3bew41bkxG8O2ChY58he43MyPzg=; b=O3dqn3OSbXE7dsKS4zec8MwKYXfOV43xPP+rzCS+8eHFemtTRxrT0vV5kub6CY33hS C/X+lr8tLR2U/ctTG1I1EpibK/VZUV/mK75jLPwy0UhLHqFfi6V/P+JV35AlalcFLyxZ BUZr2v75UItQ83pgMYhbrOL9EolWt04zJWytRZprsplewuug5QZC6tWa3x8knUV1hc3z 2AXjbFmFtJ5pCd94mh0c5j9igJRCHxc5hpmD8N+haIpJlKlbQt5D6d4S5F2hPTgsrYec i0M5o5WkQU0kCtjj2CNov+R+HKMJymrL3kCz1rsGTrdyum/93Ku8d1RBm2fwqAaxhSA2 9zSw== 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y10-20020aa793ca000000b0052d2aa737fcsi517829pff.222.2022.08.04.03.21.41; Thu, 04 Aug 2022 03:21:56 -0700 (PDT) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239261AbiHDKEI (ORCPT + 99 others); Thu, 4 Aug 2022 06:04:08 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44782 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231266AbiHDKEG (ORCPT ); Thu, 4 Aug 2022 06:04:06 -0400 Received: from fornost.hmeau.com (helcar.hmeau.com [216.24.177.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0B4F96435; Thu, 4 Aug 2022 03:04:04 -0700 (PDT) Received: from gwarestrin.arnor.me.apana.org.au ([192.168.103.7]) by fornost.hmeau.com with smtp (Exim 4.94.2 #2 (Debian)) id 1oJXhi-007m61-LH; Thu, 04 Aug 2022 20:03:47 +1000 Received: by gwarestrin.arnor.me.apana.org.au (sSMTP sendmail emulation); Thu, 04 Aug 2022 18:03:46 +0800 Date: Thu, 4 Aug 2022 18:03:46 +0800 From: Herbert Xu To: Abhishek Shah Cc: davem@davemloft.net, edumazet@google.com, kuba@kernel.org, netdev@vger.kernel.org, pabeni@redhat.com, steffen.klassert@secunet.com, linux-kernel@vger.kernel.org, Gabriel Ryan , Fan Du , Steffen Klassert Subject: [PATCH] af_key: Do not call xfrm_probe_algs in parallel Message-ID: References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_PASS 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 namespace support was added to xfrm/afkey, it caused the previously single-threaded call to xfrm_probe_algs to become multi-threaded. This is buggy and needs to be fixed with a mutex. Reported-by: Abhishek Shah Fixes: 283bc9f35bbb ("xfrm: Namespacify xfrm state/policy locks") Signed-off-by: Herbert Xu diff --git a/net/key/af_key.c b/net/key/af_key.c index fb16d7c4e1b8..20e73643b9c8 100644 --- a/net/key/af_key.c +++ b/net/key/af_key.c @@ -1697,9 +1697,12 @@ static int pfkey_register(struct sock *sk, struct sk_buff *skb, const struct sad pfk->registered |= (1<sadb_msg_satype); } + mutex_lock(&pfkey_mutex); xfrm_probe_algs(); supp_skb = compose_sadb_supported(hdr, GFP_KERNEL | __GFP_ZERO); + mutex_unlock(&pfkey_mutex); + if (!supp_skb) { if (hdr->sadb_msg_satype != SADB_SATYPE_UNSPEC) pfk->registered &= ~(1<sadb_msg_satype); -- Email: Herbert Xu Home Page: http://gondor.apana.org.au/~herbert/ PGP Key: http://gondor.apana.org.au/~herbert/pubkey.txt