2016-03-07 09:04:21 +01:00
|
|
|
/*
|
|
|
|
* virtio ccw machine definitions
|
|
|
|
*
|
|
|
|
* Copyright 2012, 2016 IBM Corp.
|
|
|
|
* Author(s): Cornelia Huck <cornelia.huck@de.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_S390X_S390_VIRTIO_CCW_H
|
|
|
|
#define HW_S390X_S390_VIRTIO_CCW_H
|
|
|
|
|
|
|
|
#include "hw/boards.h"
|
2020-09-03 16:43:22 -04:00
|
|
|
#include "qom/object.h"
|
2024-05-02 15:15:31 +02:00
|
|
|
#include "hw/s390x/sclp.h"
|
2016-03-07 09:04:21 +01:00
|
|
|
|
|
|
|
#define TYPE_S390_CCW_MACHINE "s390-ccw-machine"
|
|
|
|
|
2020-09-16 14:25:18 -04:00
|
|
|
OBJECT_DECLARE_TYPE(S390CcwMachineState, S390CcwMachineClass, S390_CCW_MACHINE)
|
2016-03-07 09:04:21 +01:00
|
|
|
|
|
|
|
|
2020-09-03 16:43:22 -04:00
|
|
|
struct S390CcwMachineState {
|
2016-03-07 09:04:21 +01:00
|
|
|
/*< private >*/
|
|
|
|
MachineState parent_obj;
|
|
|
|
|
|
|
|
/*< public >*/
|
|
|
|
bool aes_key_wrap;
|
|
|
|
bool dea_key_wrap;
|
2020-03-23 04:36:06 -04:00
|
|
|
bool pv;
|
2016-03-29 16:18:47 +02:00
|
|
|
uint8_t loadparm[8];
|
2024-05-02 15:15:31 +02:00
|
|
|
|
|
|
|
SCLPDevice *sclp;
|
2020-09-03 16:43:22 -04:00
|
|
|
};
|
2016-03-07 09:04:21 +01:00
|
|
|
|
2023-10-16 20:39:11 +02:00
|
|
|
#define S390_PTF_REASON_NONE (0x00 << 8)
|
|
|
|
#define S390_PTF_REASON_DONE (0x01 << 8)
|
|
|
|
#define S390_PTF_REASON_BUSY (0x02 << 8)
|
|
|
|
#define S390_TOPO_FC_MASK 0xffUL
|
|
|
|
void s390_handle_ptf(S390CPU *cpu, uint8_t r1, uintptr_t ra);
|
|
|
|
|
2020-09-03 16:43:22 -04:00
|
|
|
struct S390CcwMachineClass {
|
2016-03-07 09:04:21 +01:00
|
|
|
/*< private >*/
|
|
|
|
MachineClass parent_class;
|
|
|
|
|
|
|
|
/*< public >*/
|
2016-03-09 13:11:17 +01:00
|
|
|
bool ri_allowed;
|
2016-09-07 12:50:40 +02:00
|
|
|
bool cpu_model_allowed;
|
2018-09-28 11:34:35 +02:00
|
|
|
bool hpage_1m_allowed;
|
2022-11-03 18:01:41 +01:00
|
|
|
int max_threads;
|
2020-09-03 16:43:22 -04:00
|
|
|
};
|
2016-03-07 09:04:21 +01:00
|
|
|
|
2016-03-09 13:11:17 +01:00
|
|
|
/* runtime-instrumentation allowed by the machine */
|
|
|
|
bool ri_allowed(void);
|
2016-09-07 12:50:40 +02:00
|
|
|
/* cpu model allowed by the machine */
|
|
|
|
bool cpu_model_allowed(void);
|
2018-09-28 11:34:35 +02:00
|
|
|
/* 1M huge page mappings allowed by the machine */
|
|
|
|
bool hpage_1m_allowed(void);
|
2016-03-09 13:11:17 +01:00
|
|
|
|
2016-03-07 09:04:21 +01:00
|
|
|
#endif
|