Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp1656602rdh; Mon, 25 Sep 2023 22:17:04 -0700 (PDT) X-Google-Smtp-Source: AGHT+IF5WQLyNGDF0WR6csuvZaQSy2mnG0cZJ53+3sP7jaF0gio7cqoHQa28NdSCSbzoieNwZRUU X-Received: by 2002:a17:902:ee86:b0:1c6:c90:2aeb with SMTP id a6-20020a170902ee8600b001c60c902aebmr4971770pld.51.1695705423896; Mon, 25 Sep 2023 22:17:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695705423; cv=none; d=google.com; s=arc-20160816; b=LLZmFa1JrQdjs4nPx6vKRFZQQs8VrKY4IpQQfsyvmMBEKrGfJSFZOO0oyrS7KQy+uN kLGSOm+PU8XWEeLzYo0V05/IQZO2RakFeAZcyHhhikC92GYUxESfYW1TWcSqwFTtdgOf NPUeuQHdd/++oOkD/PIyvEGHXGAX2uAvQUG60EmabWa4pYhcCO1xnWSobCkonl8DCkKT jbSePCGrG2nwQuwrMVWpxl+EkdSfLqPXdR8SN8TWFOgNwdOsInuKY/xx3BChaQROl9ji JtBVOYdbBGQH6JM78gVTSSlz4RBaP6cg9dDN68Wivh2CZMObPyC2yGG6rNldEmkp6QYE dDgQ== 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:dkim-signature; bh=igN5+zK37ol5ClF0Mp4pRyBssbWi6Pl+w3dqFJhRiHw=; fh=Yibd+6efQ2NbloUNqjhUgqChaOBGlXVnr6VE1C45OVo=; b=DwE2YzKKaCjYVP0u1PvnVGi1qodwgvdpjD+R9DbbGSE+wjDDOLk4CyrkJqUjdXG6hh PMR8gpBAeyy0FVpxTc1mAdLFiVfiFqkqjQLe28eL9fsXOE0Kuunoa9ojaRBkEbNSg/1D +n8mWmgXA5PNuChDNu9VtAc82DfVKKUca2ydMz5XRLSuvtT8GoGY9QXannJFPlwTU1OY qdebC03j4JPhJHR46HRiDKUoOtSmXHw+mMD8p7XWXuJw+KbisGh4X0kA2vSsrpFw3PS7 TB+687W7J3lnJ1H3QgOkc5VIJ/1AJW+T6LndyRpoGgdU86uvMa3QUJoc4yq2Qukrudzv bGWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=qRqa4eH3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from morse.vger.email (morse.vger.email. [2620:137:e000::3:1]) by mx.google.com with ESMTPS id t4-20020a17090340c400b001bba7713547si11924720pld.151.2023.09.25.22.17.01 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Sep 2023 22:17:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) client-ip=2620:137:e000::3:1; Authentication-Results: mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=qRqa4eH3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id 6D76B8104F56; Mon, 25 Sep 2023 15:22:55 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230476AbjIYWWy (ORCPT + 99 others); Mon, 25 Sep 2023 18:22:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47886 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229485AbjIYWWx (ORCPT ); Mon, 25 Sep 2023 18:22:53 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 52D6E107 for ; Mon, 25 Sep 2023 15:22:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=igN5+zK37ol5ClF0Mp4pRyBssbWi6Pl+w3dqFJhRiHw=; b=qRqa4eH3r6DVlOYQBhH0CMCIxQ 03OwsKs7lVSp0WqBKvCeNU/d+D9ZSa2gMf0LvOQ6PKyquIpznVHy4ZU3cmvg7LQiV5VJePGAVl/8K 0N6rjZBsdz6YxRY1WebwWCefITT5jmBEmUFDqKyz5An1QMlsZEGWGRLR3LI5GK8sgl7SDd2rvapl2 p4BZKSE37glpKUG1WXAo6r9eBMt9mfXg5qLqMtnHeruwfnQFusFKQWvS47iyvg9tQ9BFzOV2JuJEQ sowiU/pz8uO145PBBou+Yu6aH7C/6Nw4tH8UR9VQUFwf1Y7+hpdc+RQGnGY/JkKlgVa9/KoD1ouZw Sw6mfEAQ==; Received: from willy by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1qktyC-0040bK-Op; Mon, 25 Sep 2023 22:22:24 +0000 Date: Mon, 25 Sep 2023 23:22:24 +0100 From: Matthew Wilcox To: Hugh Dickins Cc: Andrew Morton , Andi Kleen , Christoph Lameter , Mike Kravetz , David Hildenbrand , Suren Baghdasaryan , Yang Shi , Sidhartha Kumar , Vishal Moola , Kefeng Wang , Greg Kroah-Hartman , Tejun Heo , Mel Gorman , Michal Hocko , linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: Re: [PATCH 03/12] mempolicy: fix migrate_pages(2) syscall return nr_failed Message-ID: References: <2d872cef-7787-a7ca-10e-9d45a64c80b4@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (morse.vger.email [0.0.0.0]); Mon, 25 Sep 2023 15:22:55 -0700 (PDT) On Mon, Sep 25, 2023 at 01:24:02AM -0700, Hugh Dickins wrote: > "man 2 migrate_pages" says "On success migrate_pages() returns the number > of pages that could not be moved". Although 5.3 and 5.4 commits fixed > mbind(MPOL_MF_STRICT|MPOL_MF_MOVE*) to fail with EIO when not all pages > could be moved (because some could not be isolated for migration), > migrate_pages(2) was left still reporting only those pages failing at the > migration stage, forgetting those failing at the earlier isolation stage. > > Fix that by accumulating a long nr_failed count in struct queue_pages, > returned by queue_pages_range() when it's not returning an error, for > adding on to the nr_failed count from migrate_pages() in mm/migrate.c. > A count of pages? It's more a count of folios, but changing it to pages > would entail more work (also in mm/migrate.c): does not seem justified. I certainly see what you're saying. If a folio is only partially mapped (in an extreme case, the VMA is PAGE_SIZE and maps one page of a 512-page folio), then setting nr_failed to folio_nr_pages() is misleading at best. > +static void queue_folios_pmd(pmd_t *pmd, spinlock_t *ptl, unsigned long addr, > unsigned long end, struct mm_walk *walk) > - __releases(ptl) > { > - int ret = 0; > struct folio *folio; > struct queue_pages *qp = walk->private; > - unsigned long flags; > > if (unlikely(is_pmd_migration_entry(*pmd))) { > - ret = -EIO; > - goto unlock; > + qp->nr_failed++; > + return; > } > folio = pfn_folio(pmd_pfn(*pmd)); > if (is_huge_zero_page(&folio->page)) { > walk->action = ACTION_CONTINUE; > - goto unlock; > + return; > } > if (!queue_folio_required(folio, qp)) > - goto unlock; > - > - flags = qp->flags; > - /* go to folio migration */ > - if (flags & (MPOL_MF_MOVE | MPOL_MF_MOVE_ALL)) { > - if (!vma_migratable(walk->vma) || > - migrate_folio_add(folio, qp->pagelist, flags)) { > - ret = 1; > - goto unlock; > - } > - } else > - ret = -EIO; > -unlock: > - spin_unlock(ptl); > - return ret; > + return; > + if (!(qp->flags & (MPOL_MF_MOVE | MPOL_MF_MOVE_ALL)) || > + !vma_migratable(walk->vma) || > + !migrate_folio_add(folio, qp->pagelist, qp->flags)) > + qp->nr_failed++; However, I think here, we would do well to increment by HPAGE_PMD_NR. Or whatever equivalent is flavour of the week. Bravo to the other changes. Reviewed-by: Matthew Wilcox (Oracle)