Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp3579847pxb; Mon, 24 Jan 2022 12:42:37 -0800 (PST) X-Google-Smtp-Source: ABdhPJzcj54YTi6sCxyMbdgPMW9UA56z+U5iKCxnRt9JMKP46xcsq4g47wrC5wDmY4lsSiQtifuq X-Received: by 2002:a17:902:d70a:b0:14b:1d14:8dd7 with SMTP id w10-20020a170902d70a00b0014b1d148dd7mr15042563ply.63.1643056957112; Mon, 24 Jan 2022 12:42:37 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643056957; cv=none; d=google.com; s=arc-20160816; b=a3B0WSgImtIiPLdQvRzRFKNa2vG+tmpHLmZW7Z3YX/5IJp8VADg3eVIHyH3JNLoerI C8u4h8zuFBZ4X3yw59QCHzad1TTgNoVnKHefxGLJd4CYF0oDIQgcVWoQqPA5c0iAS2p5 PZ+B4CMChn/yY4USxpIRd/BwpiodOGgNyMZVyd3iZMXn54hZwgxrbl22hWnXNWD5Mi/Y 1KCBIqRrHj+3fIjXO5j5FCVeZPRXxD/jnYYny/a9xwylYRj0NzI79qgV0aeKXsgZKv7F 9e+T8+p7IQZjq5rBcYYlhXPw2r6P02StC4Hz0ekBXt4og+dRl9Jd47YmR8dbaRTXMXPE uzHg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=yBQnfykSkzlLcKGMpifguAebdtl68cMSk6HRnaWW95w=; b=NvY4n8M86KVc8dgq6IRbB7efXEGYoX1j9AuzXZ+ObMKRKsasCN4SZ3tfKicOGCHN3a r0oEcqunRqJbxI93mViqHd1fEpCAvMCZbMXZYIEgx9++Aodsc21Cm8eQlgYZGrRuY4V7 GlNHjwe/0+cGfmtbWXnOMPkfurOwoooWxbuIAAm7DkJUQLpsdzn2muojAkqB+JNjAPdI McUsm22Qhtu8KJy+Gvo9BmKAzMthyhfMxGTCQ2qfx87ZI8Yi2CWnM6LMwg2LCS5mHNYx x/YECXY8xo/Bz3X7NoBjfx47ln9fyZsofDUkXGTFJFW5khUNA8iofypA4h++WSIMBd36 Iz5Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="UuSPG/zo"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t1si14841241pgl.490.2022.01.24.12.42.24; Mon, 24 Jan 2022 12:42:37 -0800 (PST) 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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="UuSPG/zo"; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351146AbiAXT4r (ORCPT + 99 others); Mon, 24 Jan 2022 14:56:47 -0500 Received: from dfw.source.kernel.org ([139.178.84.217]:33376 "EHLO dfw.source.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1354433AbiAXTgg (ORCPT ); Mon, 24 Jan 2022 14:36:36 -0500 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 86D6361488; Mon, 24 Jan 2022 19:36:36 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 64D6AC340E5; Mon, 24 Jan 2022 19:36:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1643052996; bh=Rg17Dj64ENb9qLkvReuWQv612SCW6VQtuChYHLBUX6g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UuSPG/zoP6sPaHDZYt90bUzPR5tBKo/SIplXW3pQh9ifLKdoDzKD8a4jl8MjH3xKA Za1sKrDZ1eUeQ/ystSnNyCCtdW5g1TSo57X2ggsFNgo1oNXLfuHpEIg2qAaw0YztMm Mbp3Jj1B2QVJuY1un1QAM0MRttkk7PFuiSAf4pyI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Kirill A. Shutemov" , "Rafael J. Wysocki" , Bob Moore , Sasha Levin Subject: [PATCH 5.4 208/320] ACPICA: Hardware: Do not flush CPU cache when entering S4 and S5 Date: Mon, 24 Jan 2022 19:43:12 +0100 Message-Id: <20220124184000.704367846@linuxfoundation.org> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20220124183953.750177707@linuxfoundation.org> References: <20220124183953.750177707@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Kirill A. Shutemov [ Upstream commit 1d4e0b3abb168b2ee1eca99c527cffa1b80b6161 ] ACPICA commit 3dd7e1f3996456ef81bfe14cba29860e8d42949e According to ACPI 6.4, Section 16.2, the CPU cache flushing is required on entering to S1, S2, and S3, but the ACPICA code flushes the CPU cache regardless of the sleep state. Blind cache flush on entering S5 causes problems for TDX. Flushing happens with WBINVD that is not supported in the TDX environment. TDX only supports S5 and adjusting ACPICA code to conform to the spec more strictly fixes the issue. Link: https://github.com/acpica/acpica/commit/3dd7e1f3 Signed-off-by: Kirill A. Shutemov [ rjw: Subject and changelog edits ] Signed-off-by: Rafael J. Wysocki Signed-off-by: Bob Moore Signed-off-by: Rafael J. Wysocki Signed-off-by: Sasha Levin --- drivers/acpi/acpica/hwesleep.c | 4 +++- drivers/acpi/acpica/hwsleep.c | 4 +++- drivers/acpi/acpica/hwxfsleep.c | 2 -- 3 files changed, 6 insertions(+), 4 deletions(-) diff --git a/drivers/acpi/acpica/hwesleep.c b/drivers/acpi/acpica/hwesleep.c index aa502ae3b6b31..de0a59878e52d 100644 --- a/drivers/acpi/acpica/hwesleep.c +++ b/drivers/acpi/acpica/hwesleep.c @@ -104,7 +104,9 @@ acpi_status acpi_hw_extended_sleep(u8 sleep_state) /* Flush caches, as per ACPI specification */ - ACPI_FLUSH_CPU_CACHE(); + if (sleep_state < ACPI_STATE_S4) { + ACPI_FLUSH_CPU_CACHE(); + } status = acpi_os_enter_sleep(sleep_state, sleep_control, 0); if (status == AE_CTRL_TERMINATE) { diff --git a/drivers/acpi/acpica/hwsleep.c b/drivers/acpi/acpica/hwsleep.c index 5f7d63badbe9d..321aaad97e2f7 100644 --- a/drivers/acpi/acpica/hwsleep.c +++ b/drivers/acpi/acpica/hwsleep.c @@ -110,7 +110,9 @@ acpi_status acpi_hw_legacy_sleep(u8 sleep_state) /* Flush caches, as per ACPI specification */ - ACPI_FLUSH_CPU_CACHE(); + if (sleep_state < ACPI_STATE_S4) { + ACPI_FLUSH_CPU_CACHE(); + } status = acpi_os_enter_sleep(sleep_state, pm1a_control, pm1b_control); if (status == AE_CTRL_TERMINATE) { diff --git a/drivers/acpi/acpica/hwxfsleep.c b/drivers/acpi/acpica/hwxfsleep.c index 79731efbe8fe2..4e3398819718d 100644 --- a/drivers/acpi/acpica/hwxfsleep.c +++ b/drivers/acpi/acpica/hwxfsleep.c @@ -162,8 +162,6 @@ acpi_status acpi_enter_sleep_state_s4bios(void) return_ACPI_STATUS(status); } - ACPI_FLUSH_CPU_CACHE(); - status = acpi_hw_write_port(acpi_gbl_FADT.smi_command, (u32)acpi_gbl_FADT.s4_bios_request, 8); -- 2.34.1