[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 66/76] hw/s390x: Introduce s390_skeys_get|set() helpers
From: |
Philippe Mathieu-Daudé |
Subject: |
[PULL 66/76] hw/s390x: Introduce s390_skeys_get|set() helpers |
Date: |
Tue, 18 Jun 2024 18:00:28 +0200 |
s390_skeys_set() dispatch to S390SKeysClass::set_skeys(),
and s390_skeys_get() to S390SKeysClass::get_skeys().
Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
Message-Id: <20240613104415.9643-2-philmd@linaro.org>
---
include/hw/s390x/storage-keys.h | 10 ++++++++++
hw/s390x/s390-skeys.c | 27 +++++++++++++++++++++++++++
hw/s390x/trace-events | 4 ++++
3 files changed, 41 insertions(+)
diff --git a/include/hw/s390x/storage-keys.h b/include/hw/s390x/storage-keys.h
index aa2ec2aae5..976ffb2039 100644
--- a/include/hw/s390x/storage-keys.h
+++ b/include/hw/s390x/storage-keys.h
@@ -111,6 +111,16 @@ struct QEMUS390SKeysState {
};
void s390_skeys_init(void);
+/**
+ * @s390_skeys_get: See S390SKeysClass::get_skeys()
+ */
+int s390_skeys_get(S390SKeysState *ks, uint64_t start_gfn,
+ uint64_t count, uint8_t *keys);
+/**
+ * @s390_skeys_set: See S390SKeysClass::set_skeys()
+ */
+int s390_skeys_set(S390SKeysState *ks, uint64_t start_gfn,
+ uint64_t count, uint8_t *keys);
S390SKeysState *s390_get_skeys_device(void);
diff --git a/hw/s390x/s390-skeys.c b/hw/s390x/s390-skeys.c
index 5c535d483e..bf22d6863e 100644
--- a/hw/s390x/s390-skeys.c
+++ b/hw/s390x/s390-skeys.c
@@ -23,6 +23,7 @@
#include "sysemu/kvm.h"
#include "migration/qemu-file-types.h"
#include "migration/register.h"
+#include "trace.h"
#define S390_SKEYS_BUFFER_SIZE (128 * KiB) /* Room for 128k storage keys */
#define S390_SKEYS_SAVE_FLAG_EOS 0x01
@@ -54,6 +55,32 @@ void s390_skeys_init(void)
qdev_realize(DEVICE(obj), NULL, &error_fatal);
}
+int s390_skeys_get(S390SKeysState *ks, uint64_t start_gfn,
+ uint64_t count, uint8_t *keys)
+{
+ S390SKeysClass *kc = S390_SKEYS_GET_CLASS(ks);
+ int rc;
+
+ rc = kc->get_skeys(ks, start_gfn, count, keys);
+ if (rc) {
+ trace_s390_skeys_get_nonzero(rc);
+ }
+ return rc;
+}
+
+int s390_skeys_set(S390SKeysState *ks, uint64_t start_gfn,
+ uint64_t count, uint8_t *keys)
+{
+ S390SKeysClass *kc = S390_SKEYS_GET_CLASS(ks);
+ int rc;
+
+ rc = kc->set_skeys(ks, start_gfn, count, keys);
+ if (rc) {
+ trace_s390_skeys_set_nonzero(rc);
+ }
+ return rc;
+}
+
static void write_keys(FILE *f, uint8_t *keys, uint64_t startgfn,
uint64_t count, Error **errp)
{
diff --git a/hw/s390x/trace-events b/hw/s390x/trace-events
index 34da5ea323..4e74bf4484 100644
--- a/hw/s390x/trace-events
+++ b/hw/s390x/trace-events
@@ -36,3 +36,7 @@ s390_pci_unknown(const char *msg, uint32_t cmd) "%s unknown
command 0x%x"
s390_pci_bar(uint32_t bar, uint32_t addr, uint64_t size, uint32_t barsize)
"bar %d addr 0x%x size 0x%" PRIx64 "barsize 0x%x"
s390_pci_nodev(const char *cmd, uint32_t fh) "%s no pci dev fh 0x%x"
s390_pci_invalid(const char *cmd, uint32_t fh) "%s invalid space fh 0x%x"
+
+# s390-skeys.c
+s390_skeys_get_nonzero(int rc) "SKEY: Call to get_skeys unexpectedly returned
%d"
+s390_skeys_set_nonzero(int rc) "SKEY: Call to set_skeys unexpectedly returned
%d"
--
2.41.0
- [PULL 56/76] accel/tcg: Make TCGCPUOps::cpu_exec_halt mandatory, (continued)
- [PULL 56/76] accel/tcg: Make TCGCPUOps::cpu_exec_halt mandatory, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 55/76] target: Set TCGCPUOps::cpu_exec_halt to target's has_work implementation, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 57/76] memory: Constify IOMMUTLBEvent in memory_region_notify_iommu_one(), Philippe Mathieu-Daudé, 2024/06/18
- [PULL 58/76] memory: Constify IOMMUTLBEvent in memory_region_notify_iommu(), Philippe Mathieu-Daudé, 2024/06/18
- [PULL 59/76] hw/i386/iommu: Constify IOMMUTLBEvent in vtd_page_walk_hook prototype, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 60/76] hw/usb: Remove unused 'host.h' header, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 63/76] hw/intc/loongson_ipi: Provide per core MMIO address spaces, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 62/76] hw/intc: Remove loongarch_ipi.c, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 61/76] hw/usb/dev-mtp: Correctly report free space, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 64/76] hw/intc/loongson_ipi: Replace ipi_getcpu with cpu_by_arch_id, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 66/76] hw/s390x: Introduce s390_skeys_get|set() helpers,
Philippe Mathieu-Daudé <=
- [PULL 65/76] hw/mips/loongson3_virt: Wire up loongson_ipi device, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 67/76] target/s390x: Use s390_skeys_get|set() helper, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 68/76] util/readline: Fix lints for readline_handle_byte, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 69/76] util/readline: Add C-n, C-p shortcuts, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 70/76] util/readline: Add C-u shortcut, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 71/76] MAINTAINERS: drop virtio-gpu maintainership, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 72/76] MAINTAINERS: drop spice+ui maintainership, Philippe Mathieu-Daudé, 2024/06/18
- [PULL 73/76] ui/cocoa: Use qemu_add_mouse_change_notifier, Philippe Mathieu-Daudé, 2024/06/18