Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp85206imw; Thu, 14 Jul 2022 21:24:33 -0700 (PDT) X-Google-Smtp-Source: AGRyM1u7jL7E85fszbWtNfR9KbnEKyuASsysQlFC1NoWYT923NszXerJYCILZ3/rgMEPDYwzX08T X-Received: by 2002:a63:1607:0:b0:412:8fc0:756b with SMTP id w7-20020a631607000000b004128fc0756bmr10260302pgl.142.1657859073137; Thu, 14 Jul 2022 21:24:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657859073; cv=none; d=google.com; s=arc-20160816; b=xst23XxUckn7Bv/VuKVNZPenMMzwfrJiTsjX3WHqOJzs/rb9J+H7DBK4pY3W3ubq10 7dXYs/SlzhxefcMUvzXhr+duIPXWYM/UO2nz5hTGWhjqXweOG/NQJOfh2AKxi6QoC3tI /W1fZcnD2AtI+dULcYPobpyETcoR7J6i9pWvfbaiYwXqc7QbXPLbgdV3w3N6QqCvZfag 59YmMntTL3YBOVliwnw9eE4v+ZdqMd6BWL9t8QuZhf02+ALDeA/D8WfS335YV+iO1g2B 5eO6iYnKKE59N+8RTBzALf9YLqoIoeIPoSHcPL7Dcn7oOihdq3yCp2ACN8DeKbzU7t2D Xv0A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=oCw7IEIIqHU3zWcvx56D1WqOQslQBIYbw1tA/koHekY=; b=iRRmcQlx8EwdyBaqOOEzGC1dcfQoDgYBVL6+oF/mf3+5Ej1OjGaNJAkyvn9A+b7gLP VDflNs7bcImK6lxYxcQ7BDHk3CiK9j34jjnRrV1cBrIF0oK+8KFhYYLBRfu1UG8Abt4K lI5v83CcuHEqS0iAxotdx58z1i1iRVgC7RFkhX035DMaevMN/dE02tIWGAtPFRr4ROF7 PNVFlTgKDxLh2wzOYt2Tq76ediODWWkrPhgXCVP5DP4dYrMh3hq+HChsZ+7mjuHZtnp6 FUbVwkT6wCfDiboNoFSTgLf99w8PEz8+nHi34SpZxlwT6nWrqBqV7IAMWYeWDMXLterl S2cw== 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; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id np4-20020a17090b4c4400b001f01fcbab18si4141298pjb.20.2022.07.14.21.24.19; Thu, 14 Jul 2022 21:24:33 -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; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240927AbiGOD4p (ORCPT + 99 others); Thu, 14 Jul 2022 23:56:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33520 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229481AbiGOD4o (ORCPT ); Thu, 14 Jul 2022 23:56:44 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 45B9565583 for ; Thu, 14 Jul 2022 20:56:43 -0700 (PDT) Received: from canpemm500002.china.huawei.com (unknown [172.30.72.54]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4LkctV5XsQzkX3S; Fri, 15 Jul 2022 11:54:26 +0800 (CST) Received: from [10.174.177.76] (10.174.177.76) by canpemm500002.china.huawei.com (7.192.104.244) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Fri, 15 Jul 2022 11:56:41 +0800 Subject: Re: [PATCH] mm/hugetlb: avoid corrupting page->mapping in hugetlb_mcopy_atomic_pte To: Peter Xu , Axel Rasmussen CC: Andrew Morton , , , , References: <20220712130542.18836-1-linmiaohe@huawei.com> <20220713102357.8328614813db01b569650ffd@linux-foundation.org> From: Miaohe Lin Message-ID: <402ae708-4c86-8feb-75c4-9339e1deac3b@huawei.com> Date: Fri, 15 Jul 2022 11:56:40 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.174.177.76] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To canpemm500002.china.huawei.com (7.192.104.244) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 On 2022/7/14 23:52, Peter Xu wrote: > On Thu, Jul 14, 2022 at 05:59:53PM +0800, Miaohe Lin wrote: >> On 2022/7/14 1:23, Andrew Morton wrote: >>> On Tue, 12 Jul 2022 21:05:42 +0800 Miaohe Lin wrote: >>> >>>> In MCOPY_ATOMIC_CONTINUE case with a non-shared VMA, pages in the page >>>> cache are installed in the ptes. But hugepage_add_new_anon_rmap is called >>>> for them mistakenly because they're not vm_shared. This will corrupt the >>>> page->mapping used by page cache code. >>> >>> Well that sounds bad. And theories on why this has gone unnoticed for >>> over a year? I assume this doesn't have coverage in our selftests? >> >> As discussed in another thread, when minor fault handling is proposed, only >> VM_SHARED vma is expected to be supported. And the test case is also missing. > > Yes, after this patch applied it'll be great to have the test case covering > private mappings too. > > It's just that it'll be a bit more than setting test_uffdio_minor=1 for > "hugetlb" test. In hugetlb_allocate_area() we'll need to setup the alias > too for !shared case, it'll be a bit challenging since currently we're > using anonymous hugetlb mappings for private tests, and I'm not sure > whether we'll need the hugetlb path back just like what we have with > "hugetlb_shared" tests. I'm afraid not. When minor fault handling is proposed, only VM_SHARED vma is expected to be supported. It seems it's hard to image how one might benefit from using it with a private mapping. But I'm not sure as I'm still a layman in userfaultfd now. Any further suggestions? > Thanks!