a30fb811cb
Calling pause_all_vcpus()/resume_all_vcpus() from a VCPU thread might not be the best idea. As pause_all_vcpus() temporarily drops the qemu mutex, two parallel calls to pause_all_vcpus() can be active at a time, resulting in a deadlock. (either by two VCPUs or by the main thread and a VCPU) Let's handle it via the main loop instead, as suggested by Paolo. If we would have two parallel reset requests by two different VCPUs at the same time, the last one would win. We use the existing ipl device to handle it. The nice side effect is that we can get rid of reipl_requested. This change implies that all reset handling now goes via the common path, so "no-reboot" handling is now active for all kinds of reboots. Let's execute any CPU initialization code on the target CPU using run_on_cpu. Signed-off-by: David Hildenbrand <david@redhat.com> Message-Id: <20180424101859.10239-1-david@redhat.com> Acked-by: Thomas Huth <thuth@redhat.com> Signed-off-by: Cornelia Huck <cohuck@redhat.com>
57 lines
1.4 KiB
C
57 lines
1.4 KiB
C
/*
|
|
* 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"
|
|
|
|
#define TYPE_S390_CCW_MACHINE "s390-ccw-machine"
|
|
|
|
#define S390_CCW_MACHINE(obj) \
|
|
OBJECT_CHECK(S390CcwMachineState, (obj), TYPE_S390_CCW_MACHINE)
|
|
|
|
#define S390_MACHINE_CLASS(klass) \
|
|
OBJECT_CLASS_CHECK(S390CcwMachineClass, (klass), TYPE_S390_CCW_MACHINE)
|
|
|
|
typedef struct S390CcwMachineState {
|
|
/*< private >*/
|
|
MachineState parent_obj;
|
|
|
|
/*< public >*/
|
|
bool aes_key_wrap;
|
|
bool dea_key_wrap;
|
|
uint8_t loadparm[8];
|
|
bool s390_squash_mcss;
|
|
} S390CcwMachineState;
|
|
|
|
typedef struct S390CcwMachineClass {
|
|
/*< private >*/
|
|
MachineClass parent_class;
|
|
|
|
/*< public >*/
|
|
bool ri_allowed;
|
|
bool cpu_model_allowed;
|
|
bool css_migration_enabled;
|
|
} S390CcwMachineClass;
|
|
|
|
/* runtime-instrumentation allowed by the machine */
|
|
bool ri_allowed(void);
|
|
/* cpu model allowed by the machine */
|
|
bool cpu_model_allowed(void);
|
|
|
|
/**
|
|
* Returns true if (vmstate based) migration of the channel subsystem
|
|
* is enabled, false if it is disabled.
|
|
*/
|
|
bool css_migration_enabled(void);
|
|
|
|
#endif
|