53 lines
2.1 KiB
Diff
53 lines
2.1 KiB
Diff
From 087151816f810052c013d496e32be1011e5c01ef Mon Sep 17 00:00:00 2001
|
|
From: =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= <berrange@redhat.com>
|
|
Date: Tue, 10 Jun 2025 13:37:03 +0100
|
|
Subject: [PATCH 25/31] hw/ppc/spapr_tpm_proxy: skip automatic zero-init of
|
|
large arrays
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
RH-Author: Stefan Hajnoczi <stefanha@redhat.com>
|
|
RH-MergeRequest: 461: Solve -ftrivial-auto-var-init performance regression with QEMU_UNINITIALIZED
|
|
RH-Jira: RHEL-99887
|
|
RH-Acked-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
RH-Commit: [24/30] a2360ae956c03481af7aceb34d26c7d8ba33a1d7
|
|
|
|
The 'tpm_execute' method has a pair of 4k arrays used for copying
|
|
data between guest and host. Skip the automatic zero-init of these
|
|
arrays to eliminate the performance overhead in the I/O hot path.
|
|
|
|
The two arrays will be fully initialized when reading data from
|
|
guest memory or reading data from the proxy FD.
|
|
|
|
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
|
|
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
Reviewed-by: Klaus Jensen <k.jensen@samsung.com>
|
|
Reviewed-by: Harsh Prateek Bora <harshpb@linux.ibm.com>
|
|
Message-id: 20250610123709.835102-26-berrange@redhat.com
|
|
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
(cherry picked from commit 5dd9087fff74b5672526cad254e76f790fb35c7a)
|
|
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
---
|
|
hw/ppc/spapr_tpm_proxy.c | 4 ++--
|
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
|
|
diff --git a/hw/ppc/spapr_tpm_proxy.c b/hw/ppc/spapr_tpm_proxy.c
|
|
index e10af35a18..88833d9e2e 100644
|
|
--- a/hw/ppc/spapr_tpm_proxy.c
|
|
+++ b/hw/ppc/spapr_tpm_proxy.c
|
|
@@ -41,8 +41,8 @@ static ssize_t tpm_execute(SpaprTpmProxy *tpm_proxy, target_ulong *args)
|
|
target_ulong data_in_size = args[2];
|
|
uint64_t data_out = ppc64_phys_to_real(args[3]);
|
|
target_ulong data_out_size = args[4];
|
|
- uint8_t buf_in[TPM_SPAPR_BUFSIZE];
|
|
- uint8_t buf_out[TPM_SPAPR_BUFSIZE];
|
|
+ QEMU_UNINITIALIZED uint8_t buf_in[TPM_SPAPR_BUFSIZE];
|
|
+ QEMU_UNINITIALIZED uint8_t buf_out[TPM_SPAPR_BUFSIZE];
|
|
ssize_t ret;
|
|
|
|
trace_spapr_tpm_execute(data_in, data_in_size, data_out, data_out_size);
|
|
--
|
|
2.39.3
|
|
|