Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp2948356ybi; Mon, 10 Jun 2019 01:19:52 -0700 (PDT) X-Google-Smtp-Source: APXvYqz7k+GqA6aYIxAQzWLM6n8n92Eq+3GNQwf5U4w7Q3ZY6Ir6qrNh3KqCA8YE6+CkCba4OxLY X-Received: by 2002:a63:8449:: with SMTP id k70mr15091958pgd.208.1560154791972; Mon, 10 Jun 2019 01:19:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560154791; cv=none; d=google.com; s=arc-20160816; b=z7+zK93W2rEbpnkZqaMvL3PrwT4diB4GQXKRXdcreOYykztU0Sz8IgJhYcDjsCT5xp YenGVlKmKT9dDOWg3+qO8eZGQX38O2QlLIyACChVMjuv9kBhPesqwXcsnm+mLgISgp4c b+fo36Q9IgqljP51mKeBYA4Ll8+W4VjzDsQr9+jJ5nGVt/xrB2x6jBBDm+SVSoGoMpVq MWsN9X/WHvoITpGjCRTUp2K/scqXcMgSg+yXJI+qN8dtuRc0/xmZS/7sPS4324Eqe1Gj qy3DLwpbkVtIPCt2jB2O1F/f0J530zf31VtwrdmkJ7eqz4qVwnE+6yCzM6T/okgHnqqF QE0w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=AUEXYFdzqEkxEy/SrRksCebP4SkLARCEQIzpXvm3TGE=; b=RcVqdQ3cMscMVVyGDvH69b/VfriI8sRuFQBbBbzShkO1XFgsXRoHM81kOuZNRfMwWF rMgJRkT2o9XOUNPQZp4eUnRyIlNqEdjnY7ndSWHjLAOS8EfUTNtUT8PFbOBuQ7WsbzR/ ZMHC8bLgF+IfVTF34WuqRaG2/B8+/kva0dMAPWEEvjZE/CLFCd1n8jadPn4Pzb72KPMY VMhWB99A+/1Q+wnsfAzG2sfhCz1e2Trq4Zf/S/TyGxdfxq6r+aIWD0/L8scZ+gCARHEY 7id6uTUN0WyyVzrNJ+ItXV13QTKtnlZ+HAP6rf0TRF337KRWNYbjcallBaA6AABm1Z0U Tb7A== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=cyT9+FXV; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b26si9050605pgm.318.2019.06.10.01.19.37; Mon, 10 Jun 2019 01:19:51 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=cyT9+FXV; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388540AbfFJISR (ORCPT + 99 others); Mon, 10 Jun 2019 04:18:17 -0400 Received: from mail-pf1-f196.google.com ([209.85.210.196]:36426 "EHLO mail-pf1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387825AbfFJISQ (ORCPT ); Mon, 10 Jun 2019 04:18:16 -0400 Received: by mail-pf1-f196.google.com with SMTP id u22so4846609pfm.3 for ; Mon, 10 Jun 2019 01:18:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id:in-reply-to:references; bh=AUEXYFdzqEkxEy/SrRksCebP4SkLARCEQIzpXvm3TGE=; b=cyT9+FXVxPoRnYYM8NvG7UpT1wnkiyplF8ecf3XPY/u/iqmkqnAAnZdWqNjLriS4zz DUdqN/LhfFSR8pCUIZfJo3MtBe9cBnLzQLwOKqZNmC+R1uzGgA0p0x3M6lmox17kn8Pu yLw+iT04RtIlyY/CwHAO+BI0jY/bNRZzg5683q5N717NtzHnBxUtDRRRGZEK9W3+kcNg QB3bMXVVpC2s5RuTVAETr1E5R7YdWUqROVDoZTFil92c5xHZSHAP5fM6aOMluEw9nUyI zpAur0kHuMojjNVkk6i+wRivdxWSYnTyOG4FjIZsXSCXzEu+xXGrUSOa8ghSoVG65hTL I/Ag== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :in-reply-to:references; bh=AUEXYFdzqEkxEy/SrRksCebP4SkLARCEQIzpXvm3TGE=; b=rp2Bqc3RZ4Hn1xTTOzBHyUB38n3gnKRyhtfsrOi13gVG1txmktEt8nWi3Vau8dQiIO Cm3vFbGu8eBEjuKJRzHIyixGdrn2iDBw/Q6S/m6FyNLQhOP0Z0b0gmtRceObKyEEU/Hs AMg3bYm21JeGPRmnsoV7fz/giIQbacrEcr5FflR8IgXaqkUQz1joLO08OORbEOYNWGBy s+V6SeDUkmVq1q3lYIWbuMfYhwz/urlH1sKXdAj4E9jRv53tsTYvHQA9abQL5br3I5yd TiFn/ZReYIzjmhOILmL986UpVesU1NK7Vu91toNyc0kSRl+esd/RwP4/X4nzAu5cEWFu J68A== X-Gm-Message-State: APjAAAXveMhnMPSyce5rfkHYNo+adclR8sFKGU333cbzqzlVyo6yA45M H3mHK2spVqLWpu92njeotQ== X-Received: by 2002:a17:90a:8982:: with SMTP id v2mr19823294pjn.136.1560154695802; Mon, 10 Jun 2019 01:18:15 -0700 (PDT) Received: from www9186uo.sakura.ne.jp (www9186uo.sakura.ne.jp. [153.121.56.200]) by smtp.gmail.com with ESMTPSA id j7sm9525014pfa.184.2019.06.10.01.18.13 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 10 Jun 2019 01:18:15 -0700 (PDT) From: Naoya Horiguchi To: linux-mm@kvack.org Cc: Andrew Morton , Michal Hocko , Mike Kravetz , xishi.qiuxishi@alibaba-inc.com, "Chen, Jerry T" , "Zhuo, Qiuxu" , linux-kernel@vger.kernel.org Subject: [PATCH v2 2/2] mm: hugetlb: soft-offline: dissolve_free_huge_page() return zero on !PageHuge Date: Mon, 10 Jun 2019 17:18:06 +0900 Message-Id: <1560154686-18497-3-git-send-email-n-horiguchi@ah.jp.nec.com> X-Mailer: git-send-email 2.7.0 In-Reply-To: <1560154686-18497-1-git-send-email-n-horiguchi@ah.jp.nec.com> References: <1560154686-18497-1-git-send-email-n-horiguchi@ah.jp.nec.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org madvise(MADV_SOFT_OFFLINE) often returns -EBUSY when calling soft offline for hugepages with overcommitting enabled. That was caused by the suboptimal code in current soft-offline code. See the following part: ret = migrate_pages(&pagelist, new_page, NULL, MPOL_MF_MOVE_ALL, MIGRATE_SYNC, MR_MEMORY_FAILURE); if (ret) { ... } else { /* * We set PG_hwpoison only when the migration source hugepage * was successfully dissolved, because otherwise hwpoisoned * hugepage remains on free hugepage list, then userspace will * find it as SIGBUS by allocation failure. That's not expected * in soft-offlining. */ ret = dissolve_free_huge_page(page); if (!ret) { if (set_hwpoison_free_buddy_page(page)) num_poisoned_pages_inc(); } } return ret; Here dissolve_free_huge_page() returns -EBUSY if the migration source page was freed into buddy in migrate_pages(), but even in that case we actually has a chance that set_hwpoison_free_buddy_page() succeeds. So that means current code gives up offlining too early now. dissolve_free_huge_page() checks that a given hugepage is suitable for dissolving, where we should return success for !PageHuge() case because the given hugepage is considered as already dissolved. This change also affects other callers of dissolve_free_huge_page(), which are cleaned up together. Reported-by: Chen, Jerry T Tested-by: Chen, Jerry T Signed-off-by: Naoya Horiguchi Fixes: 6bc9b56433b76 ("mm: fix race on soft-offlining") Cc: # v4.19+ --- mm/hugetlb.c | 15 +++++++++------ mm/memory-failure.c | 5 +---- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git v5.2-rc3/mm/hugetlb.c v5.2-rc3_patched/mm/hugetlb.c index ac843d3..048d071 100644 --- v5.2-rc3/mm/hugetlb.c +++ v5.2-rc3_patched/mm/hugetlb.c @@ -1519,7 +1519,12 @@ int dissolve_free_huge_page(struct page *page) int rc = -EBUSY; spin_lock(&hugetlb_lock); - if (PageHuge(page) && !page_count(page)) { + if (!PageHuge(page)) { + rc = 0; + goto out; + } + + if (!page_count(page)) { struct page *head = compound_head(page); struct hstate *h = page_hstate(head); int nid = page_to_nid(head); @@ -1564,11 +1569,9 @@ int dissolve_free_huge_pages(unsigned long start_pfn, unsigned long end_pfn) for (pfn = start_pfn; pfn < end_pfn; pfn += 1 << minimum_order) { page = pfn_to_page(pfn); - if (PageHuge(page) && !page_count(page)) { - rc = dissolve_free_huge_page(page); - if (rc) - break; - } + rc = dissolve_free_huge_page(page); + if (rc) + break; } return rc; diff --git v5.2-rc3/mm/memory-failure.c v5.2-rc3_patched/mm/memory-failure.c index 7ea485e..3a83e27 100644 --- v5.2-rc3/mm/memory-failure.c +++ v5.2-rc3_patched/mm/memory-failure.c @@ -1859,11 +1859,8 @@ static int soft_offline_in_use_page(struct page *page, int flags) static int soft_offline_free_page(struct page *page) { - int rc = 0; - struct page *head = compound_head(page); + int rc = dissolve_free_huge_page(page); - if (PageHuge(head)) - rc = dissolve_free_huge_page(page); if (!rc) { if (set_hwpoison_free_buddy_page(page)) num_poisoned_pages_inc(); -- 2.7.0