Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp4269254pxf; Tue, 23 Mar 2021 07:00:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx/dRTZ00lRJiMxLwhINr6Jt3+ZAlbgaUcFmLhMTSsuzjE2PZjpGOM1auTUojr7PI3Ga1F6 X-Received: by 2002:a05:6402:440d:: with SMTP id y13mr4814270eda.316.1616508027996; Tue, 23 Mar 2021 07:00:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616508027; cv=none; d=google.com; s=arc-20160816; b=rDYbUQnR+UwBRUieWT4Ke6DuUTntkCQytNpxVs8jVl7Uam7D2pALV6vTqrzXVDw87+ RhSvrSMTm9NubPEXPuSpJIGqENutR3RbxclFjP0MMjTO7DGmmOajA524dtzi0op3KCDU PoFXDTw0Sdh7kwGZhyFoUqeoBAvgtCpoP6cII7OzLHK8HHwAU64wuCu2IvtQSZVu9TZF jdq/JFm48dzpqZzeqEOVkz9HQYwtw206kfJlRruwatTzv3gcctpxTuiQ3vdcylw0+Uzu PhkOO6tyR7zk4no9rPZRs9/iNOBlTqGBBdEEbNfR4N6wRVZm75EL1wBpGX8nbsyyFA9d i1WA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=1u3M9zzULQ5dYH4x4B7sIOtJy0VHS5TS9Mmszg25pq0=; b=Hid/RUdte3817+NSKD7yw1OvBwoqlXs15L2BfLpZmRq0a+IfI6RtOmvg6SZmXGMVSz zKh898q8g64uQGYm31CvXPDaXKnL/zpKgBFWiyS7zGkCdx+EnAvQjVsd//voo0X8BOXV BFrqbioCPFcbPNzP1+eNptCfMoAhPFpyfWURBnQq4bEwyicCmhaYQLSJPvpmJtkpycFz yuSB0JPCRcm6Hk7QVRCRBfmWtMUgCv5Cq+GPxHd4Rm8rn1X8YiTGJrkDguVii7XAmdb2 Vt/vpAxYNpHhw1Ga+jzO3EK/SGqIo6uQKqrWYkDJK4IE7n328mA0Cm8iLbvhAKFUkn7W OSfQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h20si13798863ejy.416.2021.03.23.07.00.04; Tue, 23 Mar 2021 07:00:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231839AbhCWNzg (ORCPT + 99 others); Tue, 23 Mar 2021 09:55:36 -0400 Received: from szxga07-in.huawei.com ([45.249.212.35]:14856 "EHLO szxga07-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231901AbhCWNy6 (ORCPT ); Tue, 23 Mar 2021 09:54:58 -0400 Received: from DGGEMS414-HUB.china.huawei.com (unknown [172.30.72.59]) by szxga07-in.huawei.com (SkyGuard) with ESMTP id 4F4Xr93QBxz92yY; Tue, 23 Mar 2021 21:52:57 +0800 (CST) Received: from huawei.com (10.175.104.175) by DGGEMS414-HUB.china.huawei.com (10.3.19.214) with Microsoft SMTP Server id 14.3.498.0; Tue, 23 Mar 2021 21:54:46 +0800 From: Miaohe Lin To: CC: , , , , , , , Subject: [PATCH v2 5/5] mm/migrate.c: fix potential deadlock in NUMA balancing shared exec THP case Date: Tue, 23 Mar 2021 09:54:05 -0400 Message-ID: <20210323135405.65059-6-linmiaohe@huawei.com> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20210323135405.65059-1-linmiaohe@huawei.com> References: <20210323135405.65059-1-linmiaohe@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.104.175] X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since commit c77c5cbafe54 ("mm: migrate: skip shared exec THP for NUMA balancing"), the NUMA balancing would skip shared exec transhuge page. But this enhancement is not suitable for transhuge page. Because it's required that page_mapcount() must be 1 due to no migration pte dance is done here. On the other hand, the shared exec transhuge page will leave the migrate_misplaced_page() with pte entry untouched and page locked. Thus pagefault for NUMA will be triggered again and deadlock occurs when we start waiting for the page lock held by ourselves. Fixes: c77c5cbafe54 ("mm: migrate: skip shared exec THP for NUMA balancing") Signed-off-by: Miaohe Lin --- mm/migrate.c | 4 ---- 1 file changed, 4 deletions(-) diff --git a/mm/migrate.c b/mm/migrate.c index 5357a8527ca2..68bfa1625898 100644 --- a/mm/migrate.c +++ b/mm/migrate.c @@ -2192,9 +2192,6 @@ int migrate_misplaced_transhuge_page(struct mm_struct *mm, int page_lru = page_is_file_lru(page); unsigned long start = address & HPAGE_PMD_MASK; - if (is_shared_exec_page(vma, page)) - goto out; - new_page = alloc_pages_node(node, (GFP_TRANSHUGE_LIGHT | __GFP_THISNODE), HPAGE_PMD_ORDER); @@ -2306,7 +2303,6 @@ int migrate_misplaced_transhuge_page(struct mm_struct *mm, out_unlock: unlock_page(page); -out: put_page(page); return 0; } -- 2.19.1