From patchwork Fri Mar 17 07:24:41 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Shuai Xue X-Patchwork-Id: 13178611 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 0BCE5C74A5B for ; Fri, 17 Mar 2023 07:25:00 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 30F8B900004; Fri, 17 Mar 2023 03:25:00 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 29868900002; Fri, 17 Mar 2023 03:25:00 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 1121B900004; Fri, 17 Mar 2023 03:25:00 -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 F2CF6900002 for ; Fri, 17 Mar 2023 03:24:59 -0400 (EDT) Received: from smtpin02.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id CB14E1616D5 for ; Fri, 17 Mar 2023 07:24:59 +0000 (UTC) X-FDA: 80577553518.02.1AC7A66 Received: from out30-118.freemail.mail.aliyun.com (out30-118.freemail.mail.aliyun.com [115.124.30.118]) by imf26.hostedemail.com (Postfix) with ESMTP id 1437C14000E for ; Fri, 17 Mar 2023 07:24:56 +0000 (UTC) Authentication-Results: imf26.hostedemail.com; dkim=none; dmarc=pass (policy=none) header.from=alibaba.com; spf=pass (imf26.hostedemail.com: domain of xueshuai@linux.alibaba.com designates 115.124.30.118 as permitted sender) smtp.mailfrom=xueshuai@linux.alibaba.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1679037898; 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-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=FjlODwbc1GAuh9cveguRxEnCcToTcEG472KR0yHH4ug=; b=u+Nwlhz6aA3CGrhxT4RnsB2LBTpCgYOsAY4BduwYO889qNXEGreyn3yNr8dsMGyy8gf3FY WGDQ1z0mYaNfoBlmOeJd+/R99fb4X5kRd7eja+yrtoMboFbTBp8e1mRBKl51m5E5uyBeYr higcTQijz2eApJ/JNw9PLaK1sFNWOuY= ARC-Authentication-Results: i=1; imf26.hostedemail.com; dkim=none; dmarc=pass (policy=none) header.from=alibaba.com; spf=pass (imf26.hostedemail.com: domain of xueshuai@linux.alibaba.com designates 115.124.30.118 as permitted sender) smtp.mailfrom=xueshuai@linux.alibaba.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1679037898; a=rsa-sha256; cv=none; b=PKwNorP+U3fo/nAErvdB3luQqnHlhz11ZfNy6Tzel00uoI8SRvuNLZ4p3LYvxIibHypftv EsnVwRSTUNC7D12SZcTJI883oUsfr6b0tBqY+s8JdSct3LTdHLxIZ7DIcHhHDzbEbRMCkA 1Emlsm0lN8Qne2JHhflHM9OyWFbW6n0= X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R101e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046060;MF=xueshuai@linux.alibaba.com;NM=1;PH=DS;RN=22;SR=0;TI=SMTPD_---0Ve21xtP_1679037888; Received: from localhost.localdomain(mailfrom:xueshuai@linux.alibaba.com fp:SMTPD_---0Ve21xtP_1679037888) by smtp.aliyun-inc.com; Fri, 17 Mar 2023 15:24:51 +0800 From: Shuai Xue To: tony.luck@intel.com, naoya.horiguchi@nec.com Cc: linux-acpi@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, xueshuai@linux.alibaba.com, justin.he@arm.com, akpm@linux-foundation.org, ardb@kernel.org, ashish.kalra@amd.com, baolin.wang@linux.alibaba.com, bp@alien8.de, cuibixuan@linux.alibaba.com, dave.hansen@linux.intel.com, james.morse@arm.com, jarkko@kernel.org, lenb@kernel.org, linmiaohe@huawei.com, lvying6@huawei.com, rafael@kernel.org, xiexiuqi@huawei.com, zhuo.song@linux.alibaba.com Subject: [PATCH v3 0/2] ACPI: APEI: handle synchronous exceptions with proper si_code Date: Fri, 17 Mar 2023 15:24:41 +0800 Message-Id: <20230317072443.3189-1-xueshuai@linux.alibaba.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20221027042445.60108-1-xueshuai@linux.alibaba.com> References: <20221027042445.60108-1-xueshuai@linux.alibaba.com> MIME-Version: 1.0 X-Rspamd-Server: rspam05 X-Rspamd-Queue-Id: 1437C14000E X-Stat-Signature: 4yd85skqj4gtcqwbeoqyqieycbb18opd X-Rspam-User: X-HE-Tag: 1679037896-394230 X-HE-Meta: U2FsdGVkX18oBiOOEMhyiiyyFUSe3zIBRNgXnHUkoZ7aiHMGwAapEgLCSpCG0INKIu2KZv+VzS5oQZnFo6GucVVtpXNNPvi/IgtsnD47lln/ddQ7jJ6q4cjIEPH2XKiX6H4DBWPOyZ2XSpftOQXkkgWQPG33xe6GQHRgZjTnGhjq4QISiHuRgIaKJu9WLnISMACBqR0yU9V52hhtYNinfRv4lGlcPPCgUBo/0y6QBdWhRXhoLl2p1LjoCCDICbJFvY+iNP0SIjRLLdC09dCmL95eL2pm32Aux8PyNtHwRsFadyQK/PH5CgF8V66Fr2F5kbF1U5DoXb9Pie5rXT12AsBYENS4VNvBvp1lkqhI5w3QORzi+0bhT0eVpfWRhY2Forp4GurpfrCLwDTKwWyzxYvQVssTjHyIcCGaF9/Q5Z9u3WHGNzsi783wZKC1piuUDWmosGpgUhcNdG8045h2yp3yPjYXFPdACyrmWfwRIgN6nJRzEnGaKjYcCZnlsB7hRqQtWk3Jr3FzJ21Fs11PyFGUPUD+qJ6I1L6CJPzINT7EWcVEJMZGWq0/90xdLnybJsuFbv7I0ABKQCbNV9OMfyH2hQFTKKi0rdtf32qN6qTxkOjvoF691Yi2by6BxFgBhw++H+364OcHGG2+V1ijjFWxHxqj2Gz6DFdZkSaJOCAjmvbL6dMLTKCRSv/Vx9dg18JJ+umi/8wKJDtIWDHKq4OtklDU+owAhlxyThngfuOfYzDJw4V6mI+Zk5JZmd9SpKMFfJhQy/gJ7MY7LRZUzF+e9dJstmNutDB2OZj82RcLgQy2+XHKI2LUHJ9nBLAvyuKnnLOjhlC+k7tXzEO9Jt5LFHXCXOm/RI1M4x2vwqUxDUgUYDCYwBKxgBzxura3AtAgzJDqUeQylKvSwLEi0rxAu/2LT60kmbtmDUFq0zF+YkXJlCxRXE2ZSPgSz3e0mkwHb0Dc7a9iTc9L4V4 rfIwMH86 OqLzfLMMtJCXncnaBX3VAkJ4OQS1SkKgcf3/NI0QpexAfr9DuvEPsZonj4X7S9LkvWq8y8fnKAtH9Zf70D/6gIW0dvUJ1iKtTXqCHjBJWin8V1B6GcEbu/B/nk3ZSUG8qfWct5prM5L6Gpf/+51bgVPX9EqdzwLP2ehbAfVHeSd+92UKlKUPZYmiZJzLUAkSd9XCM26GsOCWNjnXE2oSU1fGzjv0suBf/8hxUF7aC9JRqaNTGDMWMq7w704RvP/EPIZaaNw/7TLWKrOOtgqBgK5bQX1TpSb0TyTeLGjxl0XWsJDj4FYj6YHZwSw== 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: changes since v2 by addressing comments from Naoya: - rename mce_task_work to sync_task_work - drop ACPI_HEST_NOTIFY_MCE case in is_hest_sync_notify() - add steps to reproduce this problem in cover letter - Link: https://lore.kernel.org/lkml/1aa0ca90-d44c-aa99-1e2d-bd2ae610b088@linux.alibaba.com/T/#mb3dede6b7a6d189dc8de3cf9310071e38a192f8e changes since v1: - synchronous events by notify type - Link: https://lore.kernel.org/lkml/20221206153354.92394-3-xueshuai@linux.alibaba.com/ Currently, both synchronous and asynchronous error are queued and handled by a dedicated kthread in workqueue. And Memory failure for synchronous error is synced by a cancel_work_sync trick which ensures that the corrupted page is unmapped and poisoned. And after returning to user-space, the task starts at current instruction which triggering a page fault in which kernel will send SIGBUS to current process due to VM_FAULT_HWPOISON. However, the memory failure recovery for hwpoison-aware mechanisms does not work as expected. For example, hwpoison-aware user-space processes like QEMU register their customized SIGBUS handler and enable early kill mode by seting PF_MCE_EARLY at initialization. Then the kernel will directy notify the process by sending a SIGBUS signal in memory failure with wrong si_code: BUS_MCEERR_AO si_code to the actual user-space process instead of BUS_MCEERR_AR. To address this problem: - PATCH 1 sets mf_flags as MF_ACTION_REQUIRED on synchronous events which indicates error happened in current execution context - PATCH 2 separates synchronous error handling into task work so that the current context in memory failure is exactly belongs to the task consuming poison data. Then, kernel will send SIGBUS with proper si_code in kill_proc(). Lv Ying and XiuQi also proposed to address similar problem and we discussed about new solution to add a new flag(acpi_hest_generic_data::flags bit 8) to distinguish synchronous event. [2][3] The UEFI community still has no response. After a deep dive into the SDEI TRM, the SDEI notification should be used for asynchronous error. As SDEI TRM[1] describes "the dispatcher can simulate an exception-like entry into the client, **with the client providing an additional asynchronous entry point similar to an interrupt entry point**". The client (kernel) lacks complete synchronous context, e.g. systeam register (ELR, ESR, etc). So notify type is enough to distinguish synchronous event. To reproduce this problem: # STEP1: enable early kill mode #sysctl -w vm.memory_failure_early_kill=1 vm.memory_failure_early_kill = 1 # STEP2: inject an UCE error and consume it to trigger a synchronous error #einj_mem_uc single 0: single vaddr = 0xffffb0d75400 paddr = 4092d55b400 injecting ... triggering ... signal 7 code 5 addr 0xffffb0d75000 page not present Test passed The si_code (code 5) from einj_mem_uc indicates that it is BUS_MCEERR_AO error and it is not fact. After this patch set: # STEP1: enable early kill mode #sysctl -w vm.memory_failure_early_kill=1 vm.memory_failure_early_kill = 1 # STEP2: inject an UCE error and consume it to trigger a synchronous error #einj_mem_uc single 0: single vaddr = 0xffffb0d75400 paddr = 4092d55b400 injecting ... triggering ... signal 7 code 4 addr 0xffffb0d75000 page not present Test passed The si_code (code 4) from einj_mem_uc indicates that it is BUS_MCEERR_AR error as we expected. [1] https://developer.arm.com/documentation/den0054/latest/ [2] https://lore.kernel.org/linux-arm-kernel/20221205160043.57465-4-xiexiuqi@huawei.com/T/ [3] https://lore.kernel.org/lkml/20221209095407.383211-1-lvying6@huawei.com/ Shuai Xue (2): ACPI: APEI: set memory failure flags as MF_ACTION_REQUIRED on synchronous events ACPI: APEI: handle synchronous exceptions in task work drivers/acpi/apei/ghes.c | 135 ++++++++++++++++++++++++--------------- include/acpi/ghes.h | 3 - mm/memory-failure.c | 13 ---- 3 files changed, 83 insertions(+), 68 deletions(-)