Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp1118461ybm; Fri, 29 May 2020 22:42:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxeGVDEEMd2x0IOGqrsJ34GD0NGRh8IVdyspbqL6yYb7don/6jVMdr4M2Tag7u+8yW9c+IT X-Received: by 2002:a17:906:7498:: with SMTP id e24mr2408429ejl.174.1590817360368; Fri, 29 May 2020 22:42:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590817360; cv=none; d=google.com; s=arc-20160816; b=p8iGybogate8VPG796c6Nmfy1GDU46hM98qSksqACH6qzWwT+J6vUXT5jzGDsKHOSu uPKiG3fIt7Aok8MaWl59ofhTg8kwhngmhLikZ8nlPIwFsJis+GCnwoK4FD0l/SrhJFAi aoaV635lToMwLU1Bzuk5AbImnG05qcPuJji03knKX7ZIINM6XuQWjF61aisTwWdhe9VG 4k/N7yLXRrhP1bLygehexLS7VMVd7yGPd0ZvrYv5ZODpLTmJiFerQgu5PSRzIDBascVp TUxRFpt4T+LI+dXG6xrUKwt7pRUmamIgrAazAXShr+cauJm8nW3cjYM3nRhHUqPdTUG0 lI3w== 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; bh=WtANocehzUJckw0LqRIxJJlW2dRyd6jEdzDNzRr/ISo=; b=oyZZfyC3znNhnZYiISpLA35vVpjEbArTl+KmiBIukxqhR6kkHGiyQZhfMiEImaRWpf 9Rdm+eWFqMDY7d5UpkqDcMBbukCtc3lh8WgL0aRVVxs/QKeDCjo+LaBIs4pdHziFoaj2 /EB454+pB5/b9RZNBfR+veJu2Y02Wur9JskV59nGpbCM0z8HUu3XksnXR8Po2lgv1YFv 1h77h/0cI1/u6QMoYYfordvUJC8feonO2TMDlyQaGOjo4DRmS/SlFD7d7/9sqtQT6JRy a2DnnyYZYZUdyxdCBc7Qn1VcNfFh0M2f84yWJV8sCXAJL2zyG8+Dxxf8ez209/vWfMOP ewzA== 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=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d5si6813172edr.410.2020.05.29.22.42.04; Fri, 29 May 2020 22:42:40 -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=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725950AbgE3FjU (ORCPT + 99 others); Sat, 30 May 2020 01:39:20 -0400 Received: from out30-54.freemail.mail.aliyun.com ([115.124.30.54]:52852 "EHLO out30-54.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725851AbgE3FjT (ORCPT ); Sat, 30 May 2020 01:39:19 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R181e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e04426;MF=wetp.zy@linux.alibaba.com;NM=1;PH=DS;RN=5;SR=0;TI=SMTPD_---0U-0OSNd_1590817116; Received: from localhost(mailfrom:wetp.zy@linux.alibaba.com fp:SMTPD_---0U-0OSNd_1590817116) by smtp.aliyun-inc.com(127.0.0.1); Sat, 30 May 2020 13:38:43 +0800 From: Wetp Zhang To: n-horiguchi@ah.jp.nec.com, naoya.horiguchi@nec.com, akpm@linux-foundation.org Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: [PATCH V2] mm, memory_failure: don't send BUS_MCEERR_AO for action required error Date: Sat, 30 May 2020 13:38:36 +0800 Message-Id: <1590817116-21281-1-git-send-email-wetp.zy@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Some processes dont't want to be killed early, but in "Action Required" case, those also may be killed by BUS_MCEERR_AO when sharing memory with other which is accessing the fail memory. And sending SIGBUS with BUS_MCEERR_AO for action required error is strange, so ignore the non-current processes here. Suggested-by: Naoya Horiguchi Signed-off-by: Wetp Zhang --- mm/memory-failure.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/mm/memory-failure.c b/mm/memory-failure.c index a96364be8ab4..dd3862fcf2e9 100644 --- a/mm/memory-failure.c +++ b/mm/memory-failure.c @@ -210,14 +210,17 @@ static int kill_proc(struct to_kill *tk, unsigned long pfn, int flags) { struct task_struct *t = tk->tsk; short addr_lsb = tk->size_shift; - int ret; + int ret = 0; - pr_err("Memory failure: %#lx: Sending SIGBUS to %s:%d due to hardware memory corruption\n", - pfn, t->comm, t->pid); + if ((t->mm == current->mm) || !(flags & MF_ACTION_REQUIRED)) + pr_err("Memory failure: %#lx: Sending SIGBUS to %s:%d due to hardware memory corruption\n", + pfn, t->comm, t->pid); - if ((flags & MF_ACTION_REQUIRED) && t->mm == current->mm) { - ret = force_sig_mceerr(BUS_MCEERR_AR, (void __user *)tk->addr, - addr_lsb); + if (flags & MF_ACTION_REQUIRED) { + if (t->mm == current->mm) + ret = force_sig_mceerr(BUS_MCEERR_AR, + (void __user *)tk->addr, addr_lsb); + /* send no signal to non-current processes */ } else { /* * Don't use force here, it's convenient if the signal -- 2.14.3 (Apple Git-98)