Received: by 2002:a05:6512:3d0e:0:0:0:0 with SMTP id d14csp54278lfv; Tue, 12 Apr 2022 17:02:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwOC1dMSaC1Ynbgl7cwsxXIVkbsQ/lDx6wQ/ml6Z0xeM2W/XYilep7zXpaN1K0V80jYPN5P X-Received: by 2002:a05:6a00:c8f:b0:505:d602:679a with SMTP id a15-20020a056a000c8f00b00505d602679amr9213531pfv.66.1649808174738; Tue, 12 Apr 2022 17:02:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649808174; cv=none; d=google.com; s=arc-20160816; b=YIk90kDCP0W3g64RlabzipKti9PadjIZlNHfPe42pPTEPXWLDk4JYM/aojdtI/UNLx OBE9Uu5oQLXWnKcS19wfPMoW9t2sIqazUUcVuXk4rE4H2YIapxb12FgaSYt2wnK4aOCY 4Hs4NarhvUOIFlUikE02bjOYryWpMD7BnK+1V58/bpHsFpGKjHZYofzEO/x9CvE/6CYg jnE2WSEUwHuaD9nT1cjEdH1NHEjfc/HExcCLJH+qtzFnOhEz2fs+zFSl8mr4ftM+sHzY ggluCPbIL8caKC3rdL1mA1g3ZV/5tyPdJHcLYH+h5Cprl4c9vNT4NOJTUVA4chBrzluh /6Zg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=dbtNzwBOAf6NlXRzjmeHDu338fryDLa/tjBeE31zUHQ=; b=KKekmNo4Y08ZEyFwhh+Hsh5FOTyLX7EeuugLQ/y2sWmT9k7QLpxML3AwPl6iu4qqis eV410zDmqWMqo+fTCLhVcdNiSSUMOdjLpp+uOA04jINGxO78oGMeZYUIe2AZ9JpJEL5v OnMXuHyYJwLOxwyJ+TcPq8UOooVPdZzSGkxwDlwxhvPw5Xzi2S1fh9/eKNKceKtCyY6Y KB0ZOGmY0LDPNG6z0NyhytL04WpBQlvTTxr5GZ642cfo4FHQyh36v29MGEvZgmdA/fOz rxNiy6+jw0dJnPr1zMffccNx6yjXNK6h7V4vVHe8WC4npWnKbcs+6g0dYV7WUVqbsFfW PLuQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=w5IWT7Q2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id c25-20020aa79539000000b00505e5d98912si4019002pfp.296.2022.04.12.17.02.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 Apr 2022 17:02:54 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=w5IWT7Q2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 950801456DE; Tue, 12 Apr 2022 14:59:13 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1354369AbiDLH0U (ORCPT + 99 others); Tue, 12 Apr 2022 03:26:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59496 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351658AbiDLHMu (ORCPT ); Tue, 12 Apr 2022 03:12:50 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2739129829; Mon, 11 Apr 2022 23:51:01 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id B98636149D; Tue, 12 Apr 2022 06:51:00 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id CBBE6C385A8; Tue, 12 Apr 2022 06:50:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1649746260; bh=PYLZrxg0aezzpobDXdHRgrI8u0w+vJG252MHRYdhv/A=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=w5IWT7Q2Kg+g8Wt3BqVGEVsaM30h6ofoSfdkKGf49zC5DsP3XMZynXvFU+8AbXukJ dxhBTMp21ClHJrMqiy83KxDS+ZtftzXoyL8ZXr4teKGmfCRkiSEOua7b/iOV0t5J4A JV/NcToHWNzcCINvok8oShV6UHE8V9rdeZjDPU6c= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Miaohe Lin , Michal Hocko , KOSAKI Motohiro , Mel Gorman , Andrew Morton , Linus Torvalds Subject: [PATCH 5.15 217/277] mm/mempolicy: fix mpol_new leak in shared_policy_replace Date: Tue, 12 Apr 2022 08:30:20 +0200 Message-Id: <20220412062948.320606515@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220412062942.022903016@linuxfoundation.org> References: <20220412062942.022903016@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 From: Miaohe Lin commit 4ad099559b00ac01c3726e5c95dc3108ef47d03e upstream. If mpol_new is allocated but not used in restart loop, mpol_new will be freed via mpol_put before returning to the caller. But refcnt is not initialized yet, so mpol_put could not do the right things and might leak the unused mpol_new. This would happen if mempolicy was updated on the shared shmem file while the sp->lock has been dropped during the memory allocation. This issue could be triggered easily with the below code snippet if there are many processes doing the below work at the same time: shmid = shmget((key_t)5566, 1024 * PAGE_SIZE, 0666|IPC_CREAT); shm = shmat(shmid, 0, 0); loop many times { mbind(shm, 1024 * PAGE_SIZE, MPOL_LOCAL, mask, maxnode, 0); mbind(shm + 128 * PAGE_SIZE, 128 * PAGE_SIZE, MPOL_DEFAULT, mask, maxnode, 0); } Link: https://lkml.kernel.org/r/20220329111416.27954-1-linmiaohe@huawei.com Fixes: 42288fe366c4 ("mm: mempolicy: Convert shared_policy mutex to spinlock") Signed-off-by: Miaohe Lin Acked-by: Michal Hocko Cc: KOSAKI Motohiro Cc: Mel Gorman Cc: [3.8] Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- mm/mempolicy.c | 1 + 1 file changed, 1 insertion(+) --- a/mm/mempolicy.c +++ b/mm/mempolicy.c @@ -2561,6 +2561,7 @@ alloc_new: mpol_new = kmem_cache_alloc(policy_cache, GFP_KERNEL); if (!mpol_new) goto err_out; + atomic_set(&mpol_new->refcnt, 1); goto restart; }