/* * s390 storage key device * * Copyright 2015 IBM Corp. * Author(s): Jason J. Herne * * This work is licensed under the terms of the GNU GPL, version 2 or (at * your option) any later version. See the COPYING file in the top-level * directory. */ #ifndef S390_STORAGE_KEYS_H #define S390_STORAGE_KEYS_H #include "hw/qdev-core.h" #include "monitor/monitor.h" #include "qom/object.h" #define TYPE_S390_SKEYS "s390-skeys" OBJECT_DECLARE_TYPE(S390SKeysState, S390SKeysClass, S390_SKEYS) struct S390SKeysState { DeviceState parent_obj; bool migration_enabled; }; struct S390SKeysClass { DeviceClass parent_class; /** * @skeys_are_enabled: * * Check whether storage keys are enabled. If not enabled, they were not * enabled lazily either by the guest via a storage key instruction or * by the host during migration. * * If disabled, everything not explicitly triggered by the guest, * such as outgoing migration or dirty/change tracking, should not touch * storage keys and should not lazily enable it. * * @ks: the #S390SKeysState * * Returns false if not enabled and true if enabled. */ bool (*skeys_are_enabled)(S390SKeysState *ks); /** * @enable_skeys: * * Lazily enable storage keys. If this function is not implemented, * setting a storage key will lazily enable storage keys implicitly * instead. TCG guests have to make sure to flush the TLB of all CPUs * if storage keys were not enabled before this call. * * @ks: the #S390SKeysState * * Returns false if not enabled before this call, and true if already * enabled. */ bool (*enable_skeys)(S390SKeysState *ks); /** * @get_skeys: * * Get storage keys for the given PFN range. This call will fail if * storage keys have not been lazily enabled yet. * * Callers have to validate that a GFN is valid before this call. * * @ks: the #S390SKeysState * @start_gfn: the start GFN to get storage keys for * @count: the number of storage keys to get * @keys: the byte array where storage keys will be stored to * * Returns 0 on success, returns an error if getting a storage key failed. */ int (*get_skeys)(S390SKeysState *ks, uint64_t start_gfn, uint64_t count, uint8_t *keys); /** * @set_skeys: * * Set storage keys for the given PFN range. This call will fail if * storage keys have not been lazily enabled yet and implicit * enablement is not supported. * * Callers have to validate that a GFN is valid before this call. * * @ks: the #S390SKeysState * @start_gfn: the start GFN to set storage keys for * @count: the number of storage keys to set * @keys: the byte array where storage keys will be read from * * Returns 0 on success, returns an error if setting a storage key failed. */ int (*set_skeys)(S390SKeysState *ks, uint64_t start_gfn, uint64_t count, uint8_t *keys); }; #define TYPE_KVM_S390_SKEYS "s390-skeys-kvm" #define TYPE_QEMU_S390_SKEYS "s390-skeys-qemu" typedef struct QEMUS390SKeysState QEMUS390SKeysState; DECLARE_INSTANCE_CHECKER(QEMUS390SKeysState, QEMU_S390_SKEYS, TYPE_QEMU_S390_SKEYS) struct QEMUS390SKeysState { S390SKeysState parent_obj; uint8_t *keydata; uint32_t key_count; }; void s390_skeys_init(void); S390SKeysState *s390_get_skeys_device(void); void hmp_dump_skeys(Monitor *mon, const QDict *qdict); void hmp_info_skeys(Monitor *mon, const QDict *qdict); #endif /* S390_STORAGE_KEYS_H */