Extend DIAG308 subcode 10 to return the UVC RC, RRC and command code in bit positions 32-47, 16-31, and 0-15 of register R1 + 1 if the function does not complete successfully (in addition to the previously returned diag response code in bit position 47-63). Reviewed-by: Janosch Frank <frankja@linux.ibm.com> Signed-off-by: Gautam Gala <ggala@linux.ibm.com> Reviewed-by: Steffen Eiden <seiden@linux.ibm.com> Message-ID: <20250423080915.1048123-4-ggala@linux.ibm.com> Signed-off-by: Thomas Huth <thuth@redhat.com>
95 lines
3.6 KiB
C
95 lines
3.6 KiB
C
/*
|
|
* Protected Virtualization header
|
|
*
|
|
* Copyright IBM Corp. 2020
|
|
* Author(s):
|
|
* Janosch Frank <frankja@linux.ibm.com>
|
|
*
|
|
* 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 HW_S390_PV_H
|
|
#define HW_S390_PV_H
|
|
|
|
#include "qapi/error.h"
|
|
#include "system/kvm.h"
|
|
#include "hw/s390x/s390-virtio-ccw.h"
|
|
|
|
struct S390PVResponse {
|
|
uint16_t cmd;
|
|
uint16_t rrc;
|
|
uint16_t rc;
|
|
};
|
|
|
|
#ifdef CONFIG_KVM
|
|
#include "cpu.h"
|
|
|
|
static inline bool s390_is_pv(void)
|
|
{
|
|
static S390CcwMachineState *ccw;
|
|
Object *obj;
|
|
|
|
if (ccw) {
|
|
return ccw->pv;
|
|
}
|
|
|
|
/* we have to bail out for the "none" machine */
|
|
obj = object_dynamic_cast(qdev_get_machine(),
|
|
TYPE_S390_CCW_MACHINE);
|
|
if (!obj) {
|
|
return false;
|
|
}
|
|
ccw = S390_CCW_MACHINE(obj);
|
|
return ccw->pv;
|
|
}
|
|
|
|
int s390_pv_query_info(void);
|
|
int s390_pv_vm_enable(void);
|
|
void s390_pv_vm_disable(void);
|
|
bool s390_pv_vm_try_disable_async(S390CcwMachineState *ms);
|
|
int s390_pv_set_sec_parms(uint64_t origin, uint64_t length,
|
|
struct S390PVResponse *pv_resp, Error **errp);
|
|
int s390_pv_unpack(uint64_t addr, uint64_t size, uint64_t tweak,
|
|
struct S390PVResponse *pv_resp);
|
|
void s390_pv_prep_reset(void);
|
|
int s390_pv_verify(struct S390PVResponse *pv_resp);
|
|
void s390_pv_unshare(void);
|
|
void s390_pv_inject_reset_error(CPUState *cs,
|
|
struct S390PVResponse pv_resp);
|
|
uint64_t kvm_s390_pv_dmp_get_size_cpu(void);
|
|
uint64_t kvm_s390_pv_dmp_get_size_mem_state(void);
|
|
uint64_t kvm_s390_pv_dmp_get_size_completion_data(void);
|
|
bool kvm_s390_pv_info_basic_valid(void);
|
|
int kvm_s390_dump_init(void);
|
|
int kvm_s390_dump_cpu(S390CPU *cpu, void *buff);
|
|
int kvm_s390_dump_mem_state(uint64_t addr, size_t len, void *dest);
|
|
int kvm_s390_dump_completion_data(void *buff);
|
|
#else /* CONFIG_KVM */
|
|
static inline bool s390_is_pv(void) { return false; }
|
|
static inline int s390_pv_query_info(void) { return 0; }
|
|
static inline int s390_pv_vm_enable(void) { return 0; }
|
|
static inline void s390_pv_vm_disable(void) {}
|
|
static inline bool s390_pv_vm_try_disable_async(S390CcwMachineState *ms) { return false; }
|
|
static inline int s390_pv_set_sec_parms(uint64_t origin, uint64_t length,
|
|
struct S390PVResponse *pv_resp,
|
|
Error **errp) { return 0; }
|
|
static inline int s390_pv_unpack(uint64_t addr, uint64_t size, uint64_t tweak,
|
|
struct S390PVResponse *pv_resp) { return 0; }
|
|
static inline void s390_pv_prep_reset(void) {}
|
|
static inline int s390_pv_verify(struct S390PVResponse *pv_resp) { return 0; }
|
|
static inline void s390_pv_unshare(void) {}
|
|
static inline void s390_pv_inject_reset_error(CPUState *cs,
|
|
struct S390PVResponse pv_resp) {};
|
|
static inline uint64_t kvm_s390_pv_dmp_get_size_cpu(void) { return 0; }
|
|
static inline uint64_t kvm_s390_pv_dmp_get_size_mem_state(void) { return 0; }
|
|
static inline uint64_t kvm_s390_pv_dmp_get_size_completion_data(void) { return 0; }
|
|
static inline bool kvm_s390_pv_info_basic_valid(void) { return false; }
|
|
static inline int kvm_s390_dump_init(void) { return 0; }
|
|
static inline int kvm_s390_dump_cpu(S390CPU *cpu, void *buff) { return 0; }
|
|
static inline int kvm_s390_dump_mem_state(uint64_t addr, size_t len,
|
|
void *dest) { return 0; }
|
|
static inline int kvm_s390_dump_completion_data(void *buff) { return 0; }
|
|
#endif /* CONFIG_KVM */
|
|
|
|
#endif /* HW_S390_PV_H */
|