Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp290751pxb; Sat, 21 Aug 2021 02:45:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxfWA9OXuPmlXI1J95tao99eUccpA6eFZMTbPnskP6zpDvdbde8tNvFjqnMfJAY7OLspyts X-Received: by 2002:a5d:850f:: with SMTP id q15mr19649934ion.118.1629539136694; Sat, 21 Aug 2021 02:45:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629539136; cv=none; d=google.com; s=arc-20160816; b=HW+2nncoSTJNrtKy8NS0eNYOYT2G7QYmQ0+xztGUQ2GKEM2ZFmkYWDUY91IjXOhGcW dLEpF/GQG0yP15thevzjZaCecQTQn3SGql235JJRqdCItCUFo4JYL3wZSHyUkzY96Xy5 y42GbfX+nzm6W8Au+kZHNKrOrDt9ezIj8dKGHaTqDGUYkI9+ZCAiEtkSwowJP1neEJCu bPlGkK4yR6M3TohtR3eTgK+DU3p+RDjhw/Hy1fDP4EgZ3UYVtl48b23nkPf9l2eXm2ke PW0AfpyfpcPAsKmA6BpRqgI8ecFgFrllX+ye5ylRpfpNZZVPYOYT+ulw/ecBjuz8ugVF 3GoA== 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=ema8vWz1AhGTWzZNPGy4adPqbcc7qaXB3HgmSH49dJ4=; b=yDzvJ+iIZsehnnzZRy8eYxsYjLf4rVpvJFn/7oZjWWFwfIfDppURfO/I3U5mX07uoR xirnx4C8hX1tdPnfHXghuQBXkWy4QvUGFBciXdsGfAwMi2Y5GJ6Y7H/v0VBtb7/rA6EH jAruzKNNDVjkOiflD4Vqdk+I48OgNgYTMlKm4SYdZWcIFnCe0Af2kTYQNInFgydYsIlN RCOs1EJQRRX3MsGMVCfCL3XBRuox3+0BukFDk1O2cb8SeycVVz9hwzIY8UP4MqLPBbwM LcaDbkC/Vh4/mjzr7lwq0lR20+y2iBdEC66zOIbQq9Lqo5mvvGvMWFS+fRV8nYA6l5jI uzGg== 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 x8si2666780ill.70.2021.08.21.02.45.25; Sat, 21 Aug 2021 02:45:36 -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 S234227AbhHUJni (ORCPT + 99 others); Sat, 21 Aug 2021 05:43:38 -0400 Received: from szxga02-in.huawei.com ([45.249.212.188]:14405 "EHLO szxga02-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233879AbhHUJnf (ORCPT ); Sat, 21 Aug 2021 05:43:35 -0400 Received: from dggeme703-chm.china.huawei.com (unknown [172.30.72.54]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4GsD3c0Pj9zdcDt; Sat, 21 Aug 2021 17:39:08 +0800 (CST) Received: from huawei.com (10.175.124.27) by dggeme703-chm.china.huawei.com (10.1.199.99) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2176.2; Sat, 21 Aug 2021 17:42:54 +0800 From: Miaohe Lin To: CC: , , , , , , Subject: [PATCH 3/3] mm/memory_hotplug: make HWPoisoned dirty swapcache pages unmovable Date: Sat, 21 Aug 2021 17:42:46 +0800 Message-ID: <20210821094246.10149-4-linmiaohe@huawei.com> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20210821094246.10149-1-linmiaohe@huawei.com> References: <20210821094246.10149-1-linmiaohe@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.124.27] X-ClientProxiedBy: dggems702-chm.china.huawei.com (10.3.19.179) To dggeme703-chm.china.huawei.com (10.1.199.99) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org HWPoisoned dirty swapcache pages are kept for killing owner processes. We should not offline these pages or do_swap_page() would access the offline pages and lead to bad ending. Signed-off-by: Miaohe Lin --- mm/memory_hotplug.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/mm/memory_hotplug.c b/mm/memory_hotplug.c index 9fd0be32a281..0488eed3327c 100644 --- a/mm/memory_hotplug.c +++ b/mm/memory_hotplug.c @@ -1664,6 +1664,12 @@ static int scan_movable_pages(unsigned long start, unsigned long end, */ if (PageOffline(page) && page_count(page)) return -EBUSY; + /* + * HWPoisoned dirty swapcache pages are definitely unmovable + * because they are kept for killing owner processes. + */ + if (PageHWPoison(page) && PageSwapCache(page)) + return -EBUSY; if (!PageHuge(page)) continue; -- 2.23.0