Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp48034img; Wed, 20 Mar 2019 13:45:41 -0700 (PDT) X-Google-Smtp-Source: APXvYqyOu4RhHcjB+m/wz88XieYGelrWMNjyw2iTP36xp1i6Qwp91jBJZF2alyBZ7DzmskEptgdy X-Received: by 2002:a17:902:9306:: with SMTP id bc6mr9801101plb.59.1553114740973; Wed, 20 Mar 2019 13:45:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553114740; cv=none; d=google.com; s=arc-20160816; b=vrva/IYpYTRtKg7vcuCN9e54ckvGxGmaoyA9/220Pt7EGvCZ1wXOTV9kh4KoBeE7Xe vAq0mFoyu93ueDEMA+3PBZW+8uYwW1jzAT8E4N2sscwVbrlpCTZjc7V6gA0szOHwsaZ8 vA4MDUy4jTwb4BV1QgUByGO6eNOtSdzj4SAnumOjC2F0HunHcd7cr1Ln7WXdfUDhBHmj IT0vs/T2r/6eTGp5j2pBtwoXKTIaf7ndM56LrvJf9mMXIf1kRSRpIW7ILkRlRBdRiGzE 4nWDp4jgKVXrBcJoaXvyioKr4gitHDYkntRwli6NfitraRrobBu3vScFjC0NQjhe0lj7 72Jg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=2RLae5TxRnlaqkXd+oED+3b1Dwsri72MEioaQj3Oulg=; b=mAUvVKxYznFcTnW5zM3OU+kytgGjkcH0ksSulMJrlTuY11FWDiOTLngAX+YVT8Aoam aaTd+z/yIiysYHl+zVIVpel8Qk76JmOfGZIazgCXvcpZmtcjD7eCUoqILBSoKXKw7rYd no6B43TataJjnvpEP/pwB4gUPP097gpc1B8fnKvw7kOabTELnBt96oPY4YEDErZCWMzx BtmG7v3HDFHOGpQeKyu4d6I3QIEy8IGdbios89I+EdX1uKpuBrp96w5xlq5jyCRPhcgL eWz/dkpViJGuW7lh0SafywVQWZpScZd/GCtTn6Yg+K3vrRxD2i7c76gMGLnYZh3BrtFP R03w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lca.pw header.s=google header.b=lcrHgEg4; 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 f9si2328770pgi.76.2019.03.20.13.45.24; Wed, 20 Mar 2019 13:45:40 -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=pass header.i=@lca.pw header.s=google header.b=lcrHgEg4; 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 S1727050AbfCTUnL (ORCPT + 99 others); Wed, 20 Mar 2019 16:43:11 -0400 Received: from mail-qt1-f193.google.com ([209.85.160.193]:40253 "EHLO mail-qt1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726023AbfCTUnK (ORCPT ); Wed, 20 Mar 2019 16:43:10 -0400 Received: by mail-qt1-f193.google.com with SMTP id x12so4233255qts.7 for ; Wed, 20 Mar 2019 13:43:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lca.pw; s=google; h=from:to:cc:subject:date:message-id; bh=2RLae5TxRnlaqkXd+oED+3b1Dwsri72MEioaQj3Oulg=; b=lcrHgEg4Qfep15DQxX+bHhuyKyVVdmSuCCHmm0pqnrjeZt12Hp1KKQToATIau34B5P bCdAVNkHxXCnmo0CWbW+LVRsojBOGZIT4RwH9eskGG1dYel05xR5BJ7TDMb6bKLFqUzB RmeoH7wS9bXaw9c4sZ9wYOxqa4biXgAujOMa5Yjgn+N0yDF9jz20u3VvLtkJDR0d2wqx dlA5kBBZvUlqXW+HHowZEB1sg0ufmIClYpAhfxQh7XUrBW7mNVJpwGWNXs1KpJI49GF0 nzB+9ejLNQ5tuYK4SG3l7IZigpQenAh0iHQBZQcqxHSrjlDsigdBdC5Net74aLFHoA1a sixw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=2RLae5TxRnlaqkXd+oED+3b1Dwsri72MEioaQj3Oulg=; b=JHKdGCYASxyZZiqVBUWiTazz85aF0CFGra64+TkBd7fUM2P8z2Cz9vyECpqumyrHNT RizIn4F8gDzzeCA5kIciOYZ2nSCd1MGWpdAIoN6cLYypGaw+1HC5py1Eiymzqq90fBxo bjSqNEQMGWaR4YPZA5r04ADUcwti1KeeQy9R4Er+/46j4nXhLCKNTZS9YBjcjN2PtIGi uIxo108UeRmI0UjxQ1kULcpOjxaYg3A7u5FNRIPgNRG6ivZXFRNPbOu7N6a4qWMdJ3VE GNHNBTYQrcImPqgdFv2+H/mvYEFXs7ZI22KRJrZaONTcJqQ8VFzeRxey2gjEdg/NP/+f eCXA== X-Gm-Message-State: APjAAAUqEihglJPXAu1uycdf83D7c5t9B6Tqne/UUv7aflq0ehSwHk9/ 7Qctrbaj1ufmB6tGbzMS3aQ+kA== X-Received: by 2002:aed:302f:: with SMTP id 44mr8986876qte.178.1553114589845; Wed, 20 Mar 2019 13:43:09 -0700 (PDT) Received: from ovpn-120-94.rdu2.redhat.com (pool-71-184-117-43.bstnma.fios.verizon.net. [71.184.117.43]) by smtp.gmail.com with ESMTPSA id o19sm1971787qkl.65.2019.03.20.13.43.08 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 20 Mar 2019 13:43:09 -0700 (PDT) From: Qian Cai To: akpm@linux-foundation.org Cc: mhocko@kernel.org, osalvador@suse.de, anshuman.khandual@arm.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org, Qian Cai , stable@vger.kernel.org Subject: [RESEND PATCH] mm/hotplug: fix notification in offline error path Date: Wed, 20 Mar 2019 16:42:55 -0400 Message-Id: <20190320204255.53571-1-cai@lca.pw> X-Mailer: git-send-email 2.17.2 (Apple Git-113) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When start_isolate_page_range() returned -EBUSY in __offline_pages(), it calls memory_notify(MEM_CANCEL_OFFLINE, &arg) with an uninitialized "arg". As the result, it triggers warnings below. Also, it is only necessary to notify MEM_CANCEL_OFFLINE after MEM_GOING_OFFLINE. page:ffffea0001200000 count:1 mapcount:0 mapping:0000000000000000 index:0x0 flags: 0x3fffe000001000(reserved) raw: 003fffe000001000 ffffea0001200008 ffffea0001200008 0000000000000000 raw: 0000000000000000 0000000000000000 00000001ffffffff 0000000000000000 page dumped because: unmovable page WARNING: CPU: 25 PID: 1665 at mm/kasan/common.c:665 kasan_mem_notifier+0x34/0x23b CPU: 25 PID: 1665 Comm: bash Tainted: G W 5.0.0+ #94 Hardware name: HP ProLiant DL180 Gen9/ProLiant DL180 Gen9, BIOS U20 10/25/2017 RIP: 0010:kasan_mem_notifier+0x34/0x23b RSP: 0018:ffff8883ec737890 EFLAGS: 00010206 RAX: 0000000000000246 RBX: ff10f0f4435f1000 RCX: f887a7a21af88000 RDX: dffffc0000000000 RSI: 0000000000000020 RDI: ffff8881f221af88 RBP: ffff8883ec737898 R08: ffff888000000000 R09: ffffffffb0bddcd0 R10: ffffed103e857088 R11: ffff8881f42b8443 R12: dffffc0000000000 R13: 00000000fffffff9 R14: dffffc0000000000 R15: 0000000000000000 CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 CR2: 0000560fbd31d730 CR3: 00000004049c6003 CR4: 00000000001606a0 Call Trace: notifier_call_chain+0xbf/0x130 __blocking_notifier_call_chain+0x76/0xc0 blocking_notifier_call_chain+0x16/0x20 memory_notify+0x1b/0x20 __offline_pages+0x3e2/0x1210 offline_pages+0x11/0x20 memory_block_action+0x144/0x300 memory_subsys_offline+0xe5/0x170 device_offline+0x13f/0x1e0 state_store+0xeb/0x110 dev_attr_store+0x3f/0x70 sysfs_kf_write+0x104/0x150 kernfs_fop_write+0x25c/0x410 __vfs_write+0x66/0x120 vfs_write+0x15a/0x4f0 ksys_write+0xd2/0x1b0 __x64_sys_write+0x73/0xb0 do_syscall_64+0xeb/0xb78 entry_SYSCALL_64_after_hwframe+0x44/0xa9 RIP: 0033:0x7f14f75cc3b8 RSP: 002b:00007ffe84d01d68 EFLAGS: 00000246 ORIG_RAX: 0000000000000001 RAX: ffffffffffffffda RBX: 0000000000000008 RCX: 00007f14f75cc3b8 RDX: 0000000000000008 RSI: 0000563f8e433d70 RDI: 0000000000000001 RBP: 0000563f8e433d70 R08: 000000000000000a R09: 00007ffe84d018f0 R10: 000000000000000a R11: 0000000000000246 R12: 00007f14f789e780 R13: 0000000000000008 R14: 00007f14f7899740 R15: 0000000000000008 Fixes: 7960509329c2 ("mm, memory_hotplug: print reason for the offlining failure") CC: stable@vger.kernel.org # 5.0.x Reviewed-by: Oscar Salvador Acked-by: Michal Hocko Signed-off-by: Qian Cai --- mm/memory_hotplug.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mm/memory_hotplug.c b/mm/memory_hotplug.c index 0e0a16021fd5..0082d699be94 100644 --- a/mm/memory_hotplug.c +++ b/mm/memory_hotplug.c @@ -1699,12 +1699,12 @@ static int __ref __offline_pages(unsigned long start_pfn, failed_removal_isolated: undo_isolate_page_range(start_pfn, end_pfn, MIGRATE_MOVABLE); + memory_notify(MEM_CANCEL_OFFLINE, &arg); failed_removal: pr_debug("memory offlining [mem %#010llx-%#010llx] failed due to %s\n", (unsigned long long) start_pfn << PAGE_SHIFT, ((unsigned long long) end_pfn << PAGE_SHIFT) - 1, reason); - memory_notify(MEM_CANCEL_OFFLINE, &arg); /* pushback to free area */ mem_hotplug_done(); return ret; -- 2.17.2 (Apple Git-113)