[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v6 09/18] s390x: protvirt: Move STSI data over SIDAD
From: |
Janosch Frank |
Subject: |
[PATCH v6 09/18] s390x: protvirt: Move STSI data over SIDAD |
Date: |
Wed, 4 Mar 2020 06:42:22 -0500 |
For protected guests, we need to put the STSI emulation results into
the SIDA, so SIE will write them into the guest at the next entry.
Signed-off-by: Janosch Frank <address@hidden>
Acked-by: David Hildenbrand <address@hidden>
---
target/s390x/kvm.c | 15 ++++++++++++---
1 file changed, 12 insertions(+), 3 deletions(-)
diff --git a/target/s390x/kvm.c b/target/s390x/kvm.c
index cdcd538b4f..43fc0c088b 100644
--- a/target/s390x/kvm.c
+++ b/target/s390x/kvm.c
@@ -1797,11 +1797,16 @@ static int handle_tsch(S390CPU *cpu)
static void insert_stsi_3_2_2(S390CPU *cpu, __u64 addr, uint8_t ar)
{
+ CPUS390XState *env = &cpu->env;
SysIB_322 sysib;
int del;
- if (s390_cpu_virt_mem_read(cpu, addr, ar, &sysib, sizeof(sysib))) {
- return;
+ if (env->pv) {
+ s390_cpu_pv_mem_read(cpu, 0, &sysib, sizeof(sysib));
+ } else {
+ if (s390_cpu_virt_mem_read(cpu, addr, ar, &sysib, sizeof(sysib))) {
+ return;
+ }
}
/* Shift the stack of Extended Names to prepare for our own data */
memmove(&sysib.ext_names[1], &sysib.ext_names[0],
@@ -1840,7 +1845,11 @@ static void insert_stsi_3_2_2(S390CPU *cpu, __u64 addr,
uint8_t ar)
/* Insert UUID */
memcpy(sysib.vm[0].uuid, &qemu_uuid, sizeof(sysib.vm[0].uuid));
- s390_cpu_virt_mem_write(cpu, addr, ar, &sysib, sizeof(sysib));
+ if (env->pv) {
+ s390_cpu_pv_mem_write(cpu, 0, &sysib, sizeof(sysib));
+ } else {
+ s390_cpu_virt_mem_write(cpu, addr, ar, &sysib, sizeof(sysib));
+ }
}
static int handle_stsi(S390CPU *cpu)
--
2.20.1
- Re: [PATCH v6 10/18] s390x: protvirt: SCLP interpretation, (continued)
[PATCH v6 13/18] s390x: protvirt: Disable address checks for PV guest IO emulation, Janosch Frank, 2020/03/04
[PATCH v6 11/18] s390x: protvirt: Set guest IPL PSW, Janosch Frank, 2020/03/04
[PATCH v6 09/18] s390x: protvirt: Move STSI data over SIDAD,
Janosch Frank <=
[PATCH v6 14/18] s390x: protvirt: Move IO control structures over SIDA, Janosch Frank, 2020/03/04
[PATCH v6 12/18] s390x: protvirt: Move diag 308 data over SIDAD, Janosch Frank, 2020/03/04
[PATCH v6 16/18] s390x: Add unpack facility feature to GA1, Janosch Frank, 2020/03/04