Received: by 2002:a05:6512:3d0e:0:0:0:0 with SMTP id d14csp7670lfv; Tue, 12 Apr 2022 15:04:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwuD5dJhBjHFPRrc1fJeohHfdWxq7hoRL+5sDrR3FJMeHP7dGs7a8Kvi5Sxavo2QBYwrU4u X-Received: by 2002:a17:90b:4c45:b0:1ca:7c3a:5b4d with SMTP id np5-20020a17090b4c4500b001ca7c3a5b4dmr7306140pjb.131.1649801058614; Tue, 12 Apr 2022 15:04:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649801058; cv=none; d=google.com; s=arc-20160816; b=MId23lpdZP2MLEMg+vm5gVVnAGoN1qMi9LXSY5wLfhSeZ8ikYz7kU0JH7+QUMzckkI mqCJH2BUwyb/Wkgo4pb0/nYaQh44/IC2x4qlT4Z2d6s+CMov7UPCNix4DTkvDSQrbhxk E/G1CQz9rk78X0XlC/3KMuBSx6YnxCekKJmFi6iypSSH6Svxy5iLigJkXYT7Lhq9ahbh Cybrn9JmqVlgFeIgiIL0Xia5qhDdl67z/9mbzA9z4OIkq7g1I7jbxKQo6PqmW1IE5MWT I05oKVndwZXuj7r0Ws1F89tWqzHYXwvG4UEw2u3eJwT9x5KBurf0oTqeLVGNTc1gyStH JK1g== 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=9xfHdz0uvkDQwXONQk45j1YM0PnPtg2mxe7GAHqKB5k=; b=nViD9i6loTI9eKLM7mfBGFLTBlfzQBlYSYe/gkkjR5/KHPtnfGlsj1xNsUCpY0VvVo Cstc2ilDwWS4LlsIcGssEg9dSrF42v9lYw4Av4HmmpscOXss5Z480rRslMQ/5QMwsr8v EdKN9EKU03O08AHzXeyc31plU/JZ1zmLMT5ier0+yaOL6TBGogcAp3muG7hOtMTQj0X2 H6Dzkqgj1zKuc8rOtePmY6Oh8wT2Pv2Fq3rsubcEW6VOrCoeYpkqUIa3Z5PxyNr7SbQe R7hMFqpdm7Bq9irZszPS3+snQ/8eWN5LgrHv+Srb73G5P/ls58abNz7RH0g4ck/I5ugp NPdQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=xZQz4gWG; 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 x11-20020a63cc0b000000b0039cce4a507dsi3857051pgf.326.2022.04.12.15.04.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 12 Apr 2022 15:04:18 -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=xZQz4gWG; 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 6C73BDF1A; Tue, 12 Apr 2022 13:55:47 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1381263AbiDLIXU (ORCPT + 99 others); Tue, 12 Apr 2022 04:23:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33398 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1353715AbiDLHZw (ORCPT ); Tue, 12 Apr 2022 03:25:52 -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 897B4E80; Tue, 12 Apr 2022 00:04:05 -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 29CEE60B65; Tue, 12 Apr 2022 07:04:05 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 3038AC385A1; Tue, 12 Apr 2022 07:04:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1649747044; bh=fvIHxnnFvwmIhSD9YWqBPMFEOBPHcD8Axfxa+wT9Qgk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=xZQz4gWGOexgtYZsqsuye/c2nrnOBPdV6MUYkeztifpju9f1R/imNRghv1rCgqfBA r9IRpphGi2i6ShHHBcrJyx7UXFeOsik2qBQoFHjoUBLpxQTeBciZ147u89DUlCdLxF F5T+ED+/OmHZPD5qysM2phU2ryM4v20sme0uaV6s= 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.16 223/285] mm/mempolicy: fix mpol_new leak in shared_policy_replace Date: Tue, 12 Apr 2022 08:31:20 +0200 Message-Id: <20220412062950.093125745@linuxfoundation.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220412062943.670770901@linuxfoundation.org> References: <20220412062943.670770901@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 @@ -2653,6 +2653,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; }