From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 7A0ECC25B06 for ; Mon, 15 Aug 2022 01:40:42 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id C36158D0001; Sun, 14 Aug 2022 21:40:41 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id BE4096B0074; Sun, 14 Aug 2022 21:40:41 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id AAC758D0001; Sun, 14 Aug 2022 21:40:41 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0013.hostedemail.com [216.40.44.13]) by kanga.kvack.org (Postfix) with ESMTP id 9CAEC6B0073 for ; Sun, 14 Aug 2022 21:40:41 -0400 (EDT) Received: from smtpin11.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id 3B69F160633 for ; Mon, 15 Aug 2022 01:40:18 +0000 (UTC) X-FDA: 79800121716.11.254ADA3 Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by imf23.hostedemail.com (Postfix) with ESMTP id 6FF33140095 for ; Mon, 15 Aug 2022 01:40:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1660527616; x=1692063616; h=from:to:cc:subject:references:date:in-reply-to: message-id:mime-version; bh=aSAI38280sAdYFjY8JRMFFvIv1OTYOVqedJJav6rXec=; b=TAlRsS5xRIDt6+isJ3Lu1w9FNhvtBRFxX/oSB1zyex0almm7rQ5JHo29 mPC3mI1if3b1UOUV11ENt9Fv2Fz7ERDZoVsB2tmK7PNTnBLaBeMvfrrSf ytrEmOewk+UWc2Rm6n6rMIRYEvnQJl5QCgrMPOe6OzKf3+SCix1bJMBWd uOfbYPSEIzbya2TcT0Jd8tHnSDVsL9OZ8GZFRkMxsQl4bi7Nubx8m+pBT MeI6q8Tr40SbmXqrDU6W4V60+WmMAxvOs/CiiKJ/CmBK1i2yMztglK1dE xDGhHiTEF8o/1bQ+1MxQ/FD29m7byByPEfnljaXkGinFlhPDei4TbzMD2 g==; X-IronPort-AV: E=McAfee;i="6400,9594,10439"; a="378158383" X-IronPort-AV: E=Sophos;i="5.93,237,1654585200"; d="scan'208";a="378158383" Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 14 Aug 2022 18:40:14 -0700 X-IronPort-AV: E=Sophos;i="5.93,237,1654585200"; d="scan'208";a="674686959" Received: from yhuang6-desk2.sh.intel.com (HELO yhuang6-desk2.ccr.corp.intel.com) ([10.238.208.55]) by fmsmga004-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 14 Aug 2022 18:40:12 -0700 From: "Huang, Ying" To: Haiyue Wang Cc: , , , , , , , , Felix Kuehling , "Alistair Popple" Subject: Re: [PATCH v3 2/2] mm: fix the handling Non-LRU pages returned by follow_page References: <20220812084921.409142-1-haiyue.wang@intel.com> <20220815010349.432313-1-haiyue.wang@intel.com> <20220815010349.432313-3-haiyue.wang@intel.com> Date: Mon, 15 Aug 2022 09:39:59 +0800 In-Reply-To: <20220815010349.432313-3-haiyue.wang@intel.com> (Haiyue Wang's message of "Mon, 15 Aug 2022 09:03:49 +0800") Message-ID: <87czd2e13k.fsf@yhuang6-desk2.ccr.corp.intel.com> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/27.1 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=ascii ARC-Authentication-Results: i=1; imf23.hostedemail.com; dkim=none ("invalid DKIM record") header.d=intel.com header.s=Intel header.b=TAlRsS5x; spf=pass (imf23.hostedemail.com: domain of ying.huang@intel.com designates 192.55.52.43 as permitted sender) smtp.mailfrom=ying.huang@intel.com; dmarc=pass (policy=none) header.from=intel.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1660527617; a=rsa-sha256; cv=none; b=k6/vqKUf9fIvl/YV4RQxVEIt73uYmIagPQJQRhhRlyLYyFqV6XTTBqOXszofnPXpyGwEVJ 9jE2JTl+/VERRz11yuh/OZQA38fu/CipjgCHCBnrzJA5xbuV+5fOjBWl7Tzqug3bubAkRc DgPxDl9DDGm0822uIr6TNm9+Jtn/ksI= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1660527617; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=GT3SmHgKHRnIzylGRGgQjfR8hRYdoIW4O1fsMh8QNNQ=; b=E4xWJcTzAjpWRze1RY/j7cTDW8sGUjFF4co8+aqoCix9FBHrEJCDr9QDezcF/xshRzxKNx HKIH93LEFyR/H2H11wfaFDn2qf4EpKM7HFL4yYMOrI49Pi3Lm3H81lUGghyjtL4TOI9FyW eM3LgMqCYoehuQvv/idBueEJTd7Aby8= Authentication-Results: imf23.hostedemail.com; dkim=none ("invalid DKIM record") header.d=intel.com header.s=Intel header.b=TAlRsS5x; spf=pass (imf23.hostedemail.com: domain of ying.huang@intel.com designates 192.55.52.43 as permitted sender) smtp.mailfrom=ying.huang@intel.com; dmarc=pass (policy=none) header.from=intel.com X-Rspamd-Server: rspam07 X-Rspamd-Queue-Id: 6FF33140095 X-Stat-Signature: o89bpfnmumj5bc7rbk3siu8qucru8kni X-Rspam-User: X-HE-Tag: 1660527616-693508 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: Haiyue Wang writes: > The page returned by follow_page with 'FOLL_GET' has get_page called, so Better to add "()" after function name to improve the readability, for example, "follow_page()". > it needs to call put_page for handling the reference count correctly. > > And as David reviewed, "device pages are never PageKsm pages". Drop this > zone device page check for break_ksm. > > Fixes: 3218f8712d6b ("mm: handling Non-LRU pages returned by vm_normal_pages") In your patch description, I cannot find how the above commit is related to the bug you fixed. Add some words about that? Best Regards, Huang, Ying > Signed-off-by: Haiyue Wang > --- > mm/huge_memory.c | 4 ++-- > mm/ksm.c | 12 +++++++++--- > mm/migrate.c | 10 +++++++--- > 3 files changed, 18 insertions(+), 8 deletions(-) > > diff --git a/mm/huge_memory.c b/mm/huge_memory.c > index 8a7c1b344abe..b2ba17c3dcd7 100644 > --- a/mm/huge_memory.c > +++ b/mm/huge_memory.c > @@ -2963,10 +2963,10 @@ static int split_huge_pages_pid(int pid, unsigned long vaddr_start, > /* FOLL_DUMP to ignore special (like zero) pages */ > page = follow_page(vma, addr, FOLL_GET | FOLL_DUMP); > > - if (IS_ERR_OR_NULL(page) || is_zone_device_page(page)) > + if (IS_ERR_OR_NULL(page)) > continue; > > - if (!is_transparent_hugepage(page)) > + if (is_zone_device_page(page) || !is_transparent_hugepage(page)) > goto next; > > total++; > diff --git a/mm/ksm.c b/mm/ksm.c > index 42ab153335a2..e26f57fc1f0e 100644 > --- a/mm/ksm.c > +++ b/mm/ksm.c > @@ -475,7 +475,7 @@ static int break_ksm(struct vm_area_struct *vma, unsigned long addr) > cond_resched(); > page = follow_page(vma, addr, > FOLL_GET | FOLL_MIGRATION | FOLL_REMOTE); > - if (IS_ERR_OR_NULL(page) || is_zone_device_page(page)) > + if (IS_ERR_OR_NULL(page)) > break; > if (PageKsm(page)) > ret = handle_mm_fault(vma, addr, > @@ -560,12 +560,15 @@ static struct page *get_mergeable_page(struct rmap_item *rmap_item) > goto out; > > page = follow_page(vma, addr, FOLL_GET); > - if (IS_ERR_OR_NULL(page) || is_zone_device_page(page)) > + if (IS_ERR_OR_NULL(page)) > goto out; > + if (is_zone_device_page(page)) > + goto out_putpage; > if (PageAnon(page)) { > flush_anon_page(vma, page, addr); > flush_dcache_page(page); > } else { > +out_putpage: > put_page(page); > out: > page = NULL; > @@ -2308,11 +2311,13 @@ static struct rmap_item *scan_get_next_rmap_item(struct page **page) > if (ksm_test_exit(mm)) > break; > *page = follow_page(vma, ksm_scan.address, FOLL_GET); > - if (IS_ERR_OR_NULL(*page) || is_zone_device_page(*page)) { > + if (IS_ERR_OR_NULL(*page)) { > ksm_scan.address += PAGE_SIZE; > cond_resched(); > continue; > } > + if (is_zone_device_page(*page)) > + goto next_page; > if (PageAnon(*page)) { > flush_anon_page(vma, *page, ksm_scan.address); > flush_dcache_page(*page); > @@ -2327,6 +2332,7 @@ static struct rmap_item *scan_get_next_rmap_item(struct page **page) > mmap_read_unlock(mm); > return rmap_item; > } > +next_page: > put_page(*page); > ksm_scan.address += PAGE_SIZE; > cond_resched(); > diff --git a/mm/migrate.c b/mm/migrate.c > index 581dfaad9257..fee12cd2f294 100644 > --- a/mm/migrate.c > +++ b/mm/migrate.c > @@ -1672,9 +1672,12 @@ static int add_page_for_migration(struct mm_struct *mm, unsigned long addr, > goto out; > > err = -ENOENT; > - if (!page || is_zone_device_page(page)) > + if (!page) > goto out; > > + if (is_zone_device_page(page)) > + goto out_putpage; > + > err = 0; > if (page_to_nid(page) == node) > goto out_putpage; > @@ -1868,8 +1871,9 @@ static void do_pages_stat_array(struct mm_struct *mm, unsigned long nr_pages, > if (IS_ERR(page)) > goto set_status; > > - if (page && !is_zone_device_page(page)) { > - err = page_to_nid(page); > + if (page) { > + err = !is_zone_device_page(page) ? page_to_nid(page) > + : -ENOENT; > if (foll_flags & FOLL_GET) > put_page(page); > } else {