2016-03-07 11:04:21 +03: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 23:43:22 +03:00
|
|
|
#include "qom/object.h"
|
2016-03-07 11:04:21 +03:00
|
|
|
|
|
|
|
#define TYPE_S390_CCW_MACHINE "s390-ccw-machine"
|
|
|
|
|
2020-09-16 21:25:18 +03:00
|
|
|
OBJECT_DECLARE_TYPE(S390CcwMachineState, S390CcwMachineClass, S390_CCW_MACHINE)
|
2016-03-07 11:04:21 +03:00
|
|
|
|
|
|
|
|
2020-09-03 23:43:22 +03:00
|
|
|
struct S390CcwMachineState {
|
2016-03-07 11:04:21 +03:00
|
|
|
/*< private >*/
|
|
|
|
MachineState parent_obj;
|
|
|
|
|
|
|
|
/*< public >*/
|
|
|
|
bool aes_key_wrap;
|
|
|
|
bool dea_key_wrap;
|
2020-03-23 11:36:06 +03:00
|
|
|
bool pv;
|
2016-03-29 17:18:47 +03:00
|
|
|
uint8_t loadparm[8];
|
2020-09-03 23:43:22 +03:00
|
|
|
};
|
2016-03-07 11:04:21 +03:00
|
|
|
|
2023-10-16 21:39:11 +03: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 23:43:22 +03:00
|
|
|
struct S390CcwMachineClass {
|
2016-03-07 11:04:21 +03:00
|
|
|
/*< private >*/
|
|
|
|
MachineClass parent_class;
|
|
|
|
|
|
|
|
/*< public >*/
|
2016-03-09 15:11:17 +03:00
|
|
|
bool ri_allowed;
|
2016-09-07 13:50:40 +03:00
|
|
|
bool cpu_model_allowed;
|
2017-07-11 17:54:37 +03:00
|
|
|
bool css_migration_enabled;
|
2018-09-28 12:34:35 +03:00
|
|
|
bool hpage_1m_allowed;
|
2022-11-03 20:01:41 +03:00
|
|
|
int max_threads;
|
2020-09-03 23:43:22 +03:00
|
|
|
};
|
2016-03-07 11:04:21 +03:00
|
|
|
|
2016-03-09 15:11:17 +03:00
|
|
|
/* runtime-instrumentation allowed by the machine */
|
|
|
|
bool ri_allowed(void);
|
2016-09-07 13:50:40 +03:00
|
|
|
/* cpu model allowed by the machine */
|
|
|
|
bool cpu_model_allowed(void);
|
2018-09-28 12:34:35 +03:00
|
|
|
/* 1M huge page mappings allowed by the machine */
|
|
|
|
bool hpage_1m_allowed(void);
|
2016-03-09 15:11:17 +03:00
|
|
|
|
2017-07-11 17:54:37 +03:00
|
|
|
/**
|
|
|
|
* Returns true if (vmstate based) migration of the channel subsystem
|
|
|
|
* is enabled, false if it is disabled.
|
|
|
|
*/
|
|
|
|
bool css_migration_enabled(void);
|
|
|
|
|
2016-03-07 11:04:21 +03:00
|
|
|
#endif
|