mirror of https://github.com/xemu-project/xemu.git
- various fixes and improvements in the tcg code
- split off the individual virtio-ccw devices into separate files -----BEGIN PGP SIGNATURE----- iQJGBAABCAAwFiEEw9DWbcNiT/aowBjO3s9rk8bwL68FAluGaXsSHGNvaHVja0By ZWRoYXQuY29tAAoJEN7Pa5PG8C+vD84QAKRKsoAGVq7qo+bAjqCVEQQXSKn9zII+ XDK7ZIQEPIQXks7nY/RFeRMLcP5i4WFcuW5PCg4LHTvptiAUGFzryOUc5qbB/1h8 fRxjwHxwDnc3zaDmx1aKpRTftX/tQuqgQX+N1Yr/2G/QdbKmTLN+WUlq9AT6YysJ tkFNzKQgbze3ejHEdQKlioaQUuIwqrXzE5cBH/luLemrhoMghqP9W3CHmevKxXUO 0cUbGR4H2BWPaGcnxwtk9GHc4OZjKSJrH4JlKr3J5XBFZjJZO6nhsxzynbkPk0ll xQlxrw0LGWVQPGJM51Ne5KPw9lElw4Fte1zmBXLpjHTAsBFT3Y0ImB1e8ALDaG8C fejAlolHD5W6520GXrnCcTica71v7/7iaA7wg0jd8BDRopqNDgmrxdTT9vWTopRG wrXihAA8r8Fwm+uPV+6qrCTr6B/v982OeIjnnlD4sQbWbIeH0EfetStQgGlcuO6t tLPoZef8X4Qt05e71jrcVv802FlODoFbH+P26btL8jpnQdRQY4HKBPczjZIl/14Z ZP6ORUHvN8w2k2Ld4esZzn2L3Kkpcpg79s+pBdIus4y+hnHSXlKe8Ipp4Nw/QFf6 h5C/p4ujchHyNPv30PfIHiqQIdVJuvC8gJvp7QnvK5nIlOqDAgeduvWZ9JI3Dj65 H7hKyqZR2HJr =c1n9 -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/cohuck/tags/s390x-20180829' into staging - various fixes and improvements in the tcg code - split off the individual virtio-ccw devices into separate files # gpg: Signature made Wed 29 Aug 2018 10:38:03 BST # gpg: using RSA key DECF6B93C6F02FAF # gpg: Good signature from "Cornelia Huck <conny@cornelia-huck.de>" # gpg: aka "Cornelia Huck <huckc@linux.vnet.ibm.com>" # gpg: aka "Cornelia Huck <cornelia.huck@de.ibm.com>" # gpg: aka "Cornelia Huck <cohuck@kernel.org>" # gpg: aka "Cornelia Huck <cohuck@redhat.com>" # Primary key fingerprint: C3D0 D66D C362 4FF6 A8C0 18CE DECF 6B93 C6F0 2FAF * remotes/cohuck/tags/s390x-20180829: target/s390x: use regular spaces in translate.c hw/s390x: Move virtio-ccw-blk code to a separate file hw/s390x: Move virtio-ccw-net code to a separate file hw/s390x: Move virtio-ccw-input code to a separate file hw/s390x: Move virtio-ccw-gpu code to a separate file hw/s390x: Move vhost-vsock-ccw code to a separate file hw/s390x: Move virtio-ccw-crypto code to a separate file hw/s390x: Move virtio-ccw-9p code to a separate file hw/s390x: Move virtio-ccw-rng code to a separate file hw/s390x: Move virtio-ccw-scsi code to a separate file hw/s390x: Move virtio-ccw-balloon code to a separate file hw/s390x: Move virtio-ccw-serial code to a separate file hw/s390x/virtio-ccw: Consolidate calls to virtio_ccw_unrealize() target/s390x: fix PACK reading 1 byte less and writing 1 byte more target/s390x: add EX support for TRT and TRTR target/s390x: fix IPM polluting irrelevant bits target/s390x: fix CSST decoding and runtime alignment check target/s390x: add BAL and BALR instructions tests/tcg: add a simple s390x test Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
2fde22f8ae
|
@ -253,6 +253,7 @@ S: Maintained
|
|||
F: target/s390x/
|
||||
F: hw/s390x/
|
||||
F: disas/s390.c
|
||||
F: tests/tcg/s390x/
|
||||
L: qemu-s390x@nongnu.org
|
||||
|
||||
SH4
|
||||
|
@ -1236,7 +1237,8 @@ virtio-ccw
|
|||
M: Cornelia Huck <cohuck@redhat.com>
|
||||
M: Christian Borntraeger <borntraeger@de.ibm.com>
|
||||
S: Supported
|
||||
F: hw/s390x/virtio-ccw.[hc]
|
||||
F: hw/s390x/virtio-ccw*.[hc]
|
||||
F: hw/s390x/vhost-vsock-ccw.c
|
||||
T: git git://github.com/cohuck/qemu.git s390-next
|
||||
T: git git://github.com/borntraeger/qemu.git s390-next
|
||||
L: qemu-s390x@nongnu.org
|
||||
|
|
|
@ -8,6 +8,17 @@ obj-y += css.o
|
|||
obj-y += s390-virtio-ccw.o
|
||||
obj-y += 3270-ccw.o
|
||||
obj-y += virtio-ccw.o
|
||||
obj-$(CONFIG_VIRTIO_SERIAL) += virtio-ccw-serial.o
|
||||
obj-$(CONFIG_VIRTIO_BALLOON) += virtio-ccw-balloon.o
|
||||
obj-$(CONFIG_VIRTIO_SCSI) += virtio-ccw-scsi.o
|
||||
obj-$(CONFIG_VIRTIO_RNG) += virtio-ccw-rng.o
|
||||
obj-$(CONFIG_VIRTIO_CRYPTO) += virtio-ccw-crypto.o
|
||||
obj-$(CONFIG_VIRTIO_GPU) += virtio-ccw-gpu.o
|
||||
obj-$(CONFIG_VIRTIO_INPUT) += virtio-ccw-input.o
|
||||
obj-$(CONFIG_VIRTIO_NET) += virtio-ccw-net.o
|
||||
obj-$(CONFIG_VIRTIO_BLK) += virtio-ccw-blk.o
|
||||
obj-$(call land,$(CONFIG_VIRTIO_9P),$(CONFIG_VIRTFS)) += virtio-ccw-9p.o
|
||||
obj-$(CONFIG_VHOST_VSOCK) += vhost-vsock-ccw.o
|
||||
obj-y += css-bridge.o
|
||||
obj-y += ccw-device.o
|
||||
obj-$(CONFIG_PCI) += s390-pci-bus.o s390-pci-inst.o
|
||||
|
|
|
@ -0,0 +1,60 @@
|
|||
/*
|
||||
* vhost vsock ccw implementation
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static Property vhost_vsock_ccw_properties[] = {
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void vhost_vsock_ccw_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VHostVSockCCWState *dev = VHOST_VSOCK_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void vhost_vsock_ccw_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = vhost_vsock_ccw_realize;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
dc->props = vhost_vsock_ccw_properties;
|
||||
}
|
||||
|
||||
static void vhost_vsock_ccw_instance_init(Object *obj)
|
||||
{
|
||||
VHostVSockCCWState *dev = VHOST_VSOCK_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VHOST_VSOCK);
|
||||
}
|
||||
|
||||
static const TypeInfo vhost_vsock_ccw_info = {
|
||||
.name = TYPE_VHOST_VSOCK_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VHostVSockCCWState),
|
||||
.instance_init = vhost_vsock_ccw_instance_init,
|
||||
.class_init = vhost_vsock_ccw_class_init,
|
||||
};
|
||||
|
||||
static void vhost_vsock_ccw_register(void)
|
||||
{
|
||||
type_register_static(&vhost_vsock_ccw_info);
|
||||
}
|
||||
|
||||
type_init(vhost_vsock_ccw_register)
|
|
@ -0,0 +1,65 @@
|
|||
/*
|
||||
* virtio ccw 9p implementation
|
||||
*
|
||||
* Copyright 2012, 2015 IBM Corp.
|
||||
* Author(s): Pierre Morel <pmorel@linux.vnet.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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_9p_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
V9fsCCWState *dev = VIRTIO_9P_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_9p_instance_init(Object *obj)
|
||||
{
|
||||
V9fsCCWState *dev = VIRTIO_9P_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_9P);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_9p_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_9p_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_9p_realize;
|
||||
dc->props = virtio_ccw_9p_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_9p_info = {
|
||||
.name = TYPE_VIRTIO_9P_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(V9fsCCWState),
|
||||
.instance_init = virtio_ccw_9p_instance_init,
|
||||
.class_init = virtio_ccw_9p_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_9p_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_9p_info);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_9p_register)
|
|
@ -0,0 +1,70 @@
|
|||
/*
|
||||
* virtio ccw balloon implementation
|
||||
*
|
||||
* Copyright 2012, 2015 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_balloon_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOBalloonCcw *dev = VIRTIO_BALLOON_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_balloon_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOBalloonCcw *dev = VIRTIO_BALLOON_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_BALLOON);
|
||||
object_property_add_alias(obj, "guest-stats", OBJECT(&dev->vdev),
|
||||
"guest-stats", &error_abort);
|
||||
object_property_add_alias(obj, "guest-stats-polling-interval",
|
||||
OBJECT(&dev->vdev),
|
||||
"guest-stats-polling-interval", &error_abort);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_balloon_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_balloon_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_balloon_realize;
|
||||
dc->props = virtio_ccw_balloon_properties;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_balloon = {
|
||||
.name = TYPE_VIRTIO_BALLOON_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOBalloonCcw),
|
||||
.instance_init = virtio_ccw_balloon_instance_init,
|
||||
.class_init = virtio_ccw_balloon_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_balloon_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_balloon);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_balloon_register)
|
|
@ -0,0 +1,67 @@
|
|||
/*
|
||||
* virtio ccw block implementation
|
||||
*
|
||||
* Copyright 2012, 2015 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_blk_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOBlkCcw *dev = VIRTIO_BLK_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_blk_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOBlkCcw *dev = VIRTIO_BLK_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_BLK);
|
||||
object_property_add_alias(obj, "bootindex", OBJECT(&dev->vdev),
|
||||
"bootindex", &error_abort);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_blk_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_blk_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_blk_realize;
|
||||
dc->props = virtio_ccw_blk_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_blk = {
|
||||
.name = TYPE_VIRTIO_BLK_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOBlkCcw),
|
||||
.instance_init = virtio_ccw_blk_instance_init,
|
||||
.class_init = virtio_ccw_blk_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_blk_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_blk);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_blk_register)
|
|
@ -0,0 +1,75 @@
|
|||
/*
|
||||
* virtio ccw crypto implementation
|
||||
*
|
||||
* Copyright 2012, 2015 IBM Corp.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_crypto_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOCryptoCcw *dev = VIRTIO_CRYPTO_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
Error *err = NULL;
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", &err);
|
||||
if (err) {
|
||||
error_propagate(errp, err);
|
||||
return;
|
||||
}
|
||||
|
||||
object_property_set_link(OBJECT(vdev),
|
||||
OBJECT(dev->vdev.conf.cryptodev), "cryptodev",
|
||||
NULL);
|
||||
}
|
||||
|
||||
static void virtio_ccw_crypto_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOCryptoCcw *dev = VIRTIO_CRYPTO_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_CRYPTO);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_crypto_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_crypto_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_crypto_realize;
|
||||
dc->props = virtio_ccw_crypto_properties;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_crypto = {
|
||||
.name = TYPE_VIRTIO_CRYPTO_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOCryptoCcw),
|
||||
.instance_init = virtio_ccw_crypto_instance_init,
|
||||
.class_init = virtio_ccw_crypto_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_crypto_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_crypto);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_crypto_register)
|
|
@ -0,0 +1,67 @@
|
|||
/*
|
||||
* virtio ccw gpu implementation
|
||||
*
|
||||
* Copyright 2012, 2015 IBM Corp.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_gpu_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOGPUCcw *dev = VIRTIO_GPU_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_gpu_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOGPUCcw *dev = VIRTIO_GPU_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_GPU);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_gpu_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_gpu_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_gpu_realize;
|
||||
dc->props = virtio_ccw_gpu_properties;
|
||||
dc->hotpluggable = false;
|
||||
set_bit(DEVICE_CATEGORY_DISPLAY, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_gpu = {
|
||||
.name = TYPE_VIRTIO_GPU_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOGPUCcw),
|
||||
.instance_init = virtio_ccw_gpu_instance_init,
|
||||
.class_init = virtio_ccw_gpu_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_gpu_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_gpu);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_gpu_register)
|
|
@ -0,0 +1,118 @@
|
|||
/*
|
||||
* virtio ccw scsi implementation
|
||||
*
|
||||
* Copyright 2012, 2015 IBM Corp.
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_input_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOInputCcw *dev = VIRTIO_INPUT_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_input_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_input_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_input_realize;
|
||||
dc->props = virtio_ccw_input_properties;
|
||||
set_bit(DEVICE_CATEGORY_INPUT, dc->categories);
|
||||
}
|
||||
|
||||
static void virtio_ccw_keyboard_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOInputHIDCcw *dev = VIRTIO_INPUT_HID_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_KEYBOARD);
|
||||
}
|
||||
|
||||
static void virtio_ccw_mouse_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOInputHIDCcw *dev = VIRTIO_INPUT_HID_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_MOUSE);
|
||||
}
|
||||
|
||||
static void virtio_ccw_tablet_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOInputHIDCcw *dev = VIRTIO_INPUT_HID_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_TABLET);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_input = {
|
||||
.name = TYPE_VIRTIO_INPUT_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOInputCcw),
|
||||
.class_init = virtio_ccw_input_class_init,
|
||||
.abstract = true,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_input_hid = {
|
||||
.name = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.abstract = true,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_keyboard = {
|
||||
.name = TYPE_VIRTIO_KEYBOARD_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.instance_init = virtio_ccw_keyboard_instance_init,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_mouse = {
|
||||
.name = TYPE_VIRTIO_MOUSE_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.instance_init = virtio_ccw_mouse_instance_init,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_tablet = {
|
||||
.name = TYPE_VIRTIO_TABLET_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.instance_init = virtio_ccw_tablet_instance_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_input_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_input);
|
||||
type_register_static(&virtio_ccw_input_hid);
|
||||
type_register_static(&virtio_ccw_keyboard);
|
||||
type_register_static(&virtio_ccw_mouse);
|
||||
type_register_static(&virtio_ccw_tablet);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_input_register)
|
|
@ -0,0 +1,70 @@
|
|||
/*
|
||||
* virtio ccw net implementation
|
||||
*
|
||||
* Copyright 2012, 2015 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_net_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
DeviceState *qdev = DEVICE(ccw_dev);
|
||||
VirtIONetCcw *dev = VIRTIO_NET_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
virtio_net_set_netclient_name(&dev->vdev, qdev->id,
|
||||
object_get_typename(OBJECT(qdev)));
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_net_instance_init(Object *obj)
|
||||
{
|
||||
VirtIONetCcw *dev = VIRTIO_NET_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_NET);
|
||||
object_property_add_alias(obj, "bootindex", OBJECT(&dev->vdev),
|
||||
"bootindex", &error_abort);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_net_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_net_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_net_realize;
|
||||
dc->props = virtio_ccw_net_properties;
|
||||
set_bit(DEVICE_CATEGORY_NETWORK, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_net = {
|
||||
.name = TYPE_VIRTIO_NET_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIONetCcw),
|
||||
.instance_init = virtio_ccw_net_instance_init,
|
||||
.class_init = virtio_ccw_net_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_net_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_net);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_net_register)
|
|
@ -0,0 +1,74 @@
|
|||
/*
|
||||
* virtio ccw random number generator implementation
|
||||
*
|
||||
* Copyright 2012, 2015 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_rng_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIORNGCcw *dev = VIRTIO_RNG_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
Error *err = NULL;
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", &err);
|
||||
if (err) {
|
||||
error_propagate(errp, err);
|
||||
return;
|
||||
}
|
||||
|
||||
object_property_set_link(OBJECT(dev),
|
||||
OBJECT(dev->vdev.conf.rng), "rng",
|
||||
NULL);
|
||||
}
|
||||
|
||||
static void virtio_ccw_rng_instance_init(Object *obj)
|
||||
{
|
||||
VirtIORNGCcw *dev = VIRTIO_RNG_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_RNG);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_rng_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_rng_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_rng_realize;
|
||||
dc->props = virtio_ccw_rng_properties;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_rng = {
|
||||
.name = TYPE_VIRTIO_RNG_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIORNGCcw),
|
||||
.instance_init = virtio_ccw_rng_instance_init,
|
||||
.class_init = virtio_ccw_rng_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_rng_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_rng);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_rng_register)
|
|
@ -0,0 +1,125 @@
|
|||
/*
|
||||
* virtio ccw scsi implementation
|
||||
*
|
||||
* Copyright 2012, 2015 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "qapi/error.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_scsi_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOSCSICcw *dev = VIRTIO_SCSI_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
DeviceState *qdev = DEVICE(ccw_dev);
|
||||
char *bus_name;
|
||||
|
||||
/*
|
||||
* For command line compatibility, this sets the virtio-scsi-device bus
|
||||
* name as before.
|
||||
*/
|
||||
if (qdev->id) {
|
||||
bus_name = g_strdup_printf("%s.0", qdev->id);
|
||||
virtio_device_set_child_bus_name(VIRTIO_DEVICE(vdev), bus_name);
|
||||
g_free(bus_name);
|
||||
}
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_scsi_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOSCSICcw *dev = VIRTIO_SCSI_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_SCSI);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_scsi_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_scsi_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_scsi_realize;
|
||||
dc->props = virtio_ccw_scsi_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_scsi = {
|
||||
.name = TYPE_VIRTIO_SCSI_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOSCSICcw),
|
||||
.instance_init = virtio_ccw_scsi_instance_init,
|
||||
.class_init = virtio_ccw_scsi_class_init,
|
||||
};
|
||||
|
||||
#ifdef CONFIG_VHOST_SCSI
|
||||
|
||||
static void vhost_ccw_scsi_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VHostSCSICcw *dev = VHOST_SCSI_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void vhost_ccw_scsi_instance_init(Object *obj)
|
||||
{
|
||||
VHostSCSICcw *dev = VHOST_SCSI_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VHOST_SCSI);
|
||||
}
|
||||
|
||||
static Property vhost_ccw_scsi_properties[] = {
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void vhost_ccw_scsi_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = vhost_ccw_scsi_realize;
|
||||
dc->props = vhost_ccw_scsi_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo vhost_ccw_scsi = {
|
||||
.name = TYPE_VHOST_SCSI_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VHostSCSICcw),
|
||||
.instance_init = vhost_ccw_scsi_instance_init,
|
||||
.class_init = vhost_ccw_scsi_class_init,
|
||||
};
|
||||
|
||||
#endif
|
||||
|
||||
static void virtio_ccw_scsi_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_scsi);
|
||||
#ifdef CONFIG_VHOST_SCSI
|
||||
type_register_static(&vhost_ccw_scsi);
|
||||
#endif
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_scsi_register)
|
|
@ -0,0 +1,78 @@
|
|||
/*
|
||||
* virtio ccw serial implementation
|
||||
*
|
||||
* Copyright 2012, 2015 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.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "hw/virtio/virtio-serial.h"
|
||||
#include "virtio-ccw.h"
|
||||
|
||||
static void virtio_ccw_serial_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtioSerialCcw *dev = VIRTIO_SERIAL_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
DeviceState *proxy = DEVICE(ccw_dev);
|
||||
char *bus_name;
|
||||
|
||||
/*
|
||||
* For command line compatibility, this sets the virtio-serial-device bus
|
||||
* name as before.
|
||||
*/
|
||||
if (proxy->id) {
|
||||
bus_name = g_strdup_printf("%s.0", proxy->id);
|
||||
virtio_device_set_child_bus_name(VIRTIO_DEVICE(vdev), bus_name);
|
||||
g_free(bus_name);
|
||||
}
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
|
||||
static void virtio_ccw_serial_instance_init(Object *obj)
|
||||
{
|
||||
VirtioSerialCcw *dev = VIRTIO_SERIAL_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_SERIAL);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_serial_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_serial_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_serial_realize;
|
||||
dc->props = virtio_ccw_serial_properties;
|
||||
set_bit(DEVICE_CATEGORY_INPUT, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_serial = {
|
||||
.name = TYPE_VIRTIO_SERIAL_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtioSerialCcw),
|
||||
.instance_init = virtio_ccw_serial_instance_init,
|
||||
.class_init = virtio_ccw_serial_class_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_serial_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_serial);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_serial_register)
|
|
@ -17,7 +17,6 @@
|
|||
#include "sysemu/kvm.h"
|
||||
#include "net/net.h"
|
||||
#include "hw/virtio/virtio.h"
|
||||
#include "hw/virtio/virtio-serial.h"
|
||||
#include "hw/virtio/virtio-net.h"
|
||||
#include "hw/sysbus.h"
|
||||
#include "qemu/bitops.h"
|
||||
|
@ -747,11 +746,16 @@ out_err:
|
|||
g_free(sch);
|
||||
}
|
||||
|
||||
static void virtio_ccw_unrealize(VirtioCcwDevice *dev, Error **errp)
|
||||
static void virtio_ccw_device_unrealize(VirtioCcwDevice *dev, Error **errp)
|
||||
{
|
||||
VirtIOCCWDeviceClass *dc = VIRTIO_CCW_DEVICE_GET_CLASS(dev);
|
||||
CcwDevice *ccw_dev = CCW_DEVICE(dev);
|
||||
SubchDev *sch = ccw_dev->sch;
|
||||
|
||||
if (dc->unrealize) {
|
||||
dc->unrealize(dev, errp);
|
||||
}
|
||||
|
||||
if (sch) {
|
||||
css_subch_assign(sch->cssid, sch->ssid, sch->schid, sch->devno, NULL);
|
||||
g_free(sch);
|
||||
|
@ -763,201 +767,6 @@ static void virtio_ccw_unrealize(VirtioCcwDevice *dev, Error **errp)
|
|||
}
|
||||
}
|
||||
|
||||
static void virtio_ccw_net_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
DeviceState *qdev = DEVICE(ccw_dev);
|
||||
VirtIONetCcw *dev = VIRTIO_NET_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
virtio_net_set_netclient_name(&dev->vdev, qdev->id,
|
||||
object_get_typename(OBJECT(qdev)));
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_net_instance_init(Object *obj)
|
||||
{
|
||||
VirtIONetCcw *dev = VIRTIO_NET_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_NET);
|
||||
object_property_add_alias(obj, "bootindex", OBJECT(&dev->vdev),
|
||||
"bootindex", &error_abort);
|
||||
}
|
||||
|
||||
static void virtio_ccw_blk_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOBlkCcw *dev = VIRTIO_BLK_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_blk_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOBlkCcw *dev = VIRTIO_BLK_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_BLK);
|
||||
object_property_add_alias(obj, "bootindex", OBJECT(&dev->vdev),
|
||||
"bootindex", &error_abort);
|
||||
}
|
||||
|
||||
static void virtio_ccw_serial_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtioSerialCcw *dev = VIRTIO_SERIAL_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
DeviceState *proxy = DEVICE(ccw_dev);
|
||||
char *bus_name;
|
||||
|
||||
/*
|
||||
* For command line compatibility, this sets the virtio-serial-device bus
|
||||
* name as before.
|
||||
*/
|
||||
if (proxy->id) {
|
||||
bus_name = g_strdup_printf("%s.0", proxy->id);
|
||||
virtio_device_set_child_bus_name(VIRTIO_DEVICE(vdev), bus_name);
|
||||
g_free(bus_name);
|
||||
}
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
|
||||
static void virtio_ccw_serial_instance_init(Object *obj)
|
||||
{
|
||||
VirtioSerialCcw *dev = VIRTIO_SERIAL_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_SERIAL);
|
||||
}
|
||||
|
||||
static void virtio_ccw_balloon_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOBalloonCcw *dev = VIRTIO_BALLOON_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_balloon_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOBalloonCcw *dev = VIRTIO_BALLOON_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_BALLOON);
|
||||
object_property_add_alias(obj, "guest-stats", OBJECT(&dev->vdev),
|
||||
"guest-stats", &error_abort);
|
||||
object_property_add_alias(obj, "guest-stats-polling-interval",
|
||||
OBJECT(&dev->vdev),
|
||||
"guest-stats-polling-interval", &error_abort);
|
||||
}
|
||||
|
||||
static void virtio_ccw_scsi_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOSCSICcw *dev = VIRTIO_SCSI_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
DeviceState *qdev = DEVICE(ccw_dev);
|
||||
char *bus_name;
|
||||
|
||||
/*
|
||||
* For command line compatibility, this sets the virtio-scsi-device bus
|
||||
* name as before.
|
||||
*/
|
||||
if (qdev->id) {
|
||||
bus_name = g_strdup_printf("%s.0", qdev->id);
|
||||
virtio_device_set_child_bus_name(VIRTIO_DEVICE(vdev), bus_name);
|
||||
g_free(bus_name);
|
||||
}
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_scsi_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOSCSICcw *dev = VIRTIO_SCSI_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_SCSI);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_VHOST_SCSI
|
||||
static void vhost_ccw_scsi_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VHostSCSICcw *dev = VHOST_SCSI_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void vhost_ccw_scsi_instance_init(Object *obj)
|
||||
{
|
||||
VHostSCSICcw *dev = VHOST_SCSI_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VHOST_SCSI);
|
||||
}
|
||||
#endif
|
||||
|
||||
static void virtio_ccw_rng_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIORNGCcw *dev = VIRTIO_RNG_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
Error *err = NULL;
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", &err);
|
||||
if (err) {
|
||||
error_propagate(errp, err);
|
||||
return;
|
||||
}
|
||||
|
||||
object_property_set_link(OBJECT(dev),
|
||||
OBJECT(dev->vdev.conf.rng), "rng",
|
||||
NULL);
|
||||
}
|
||||
|
||||
static void virtio_ccw_crypto_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOCryptoCcw *dev = VIRTIO_CRYPTO_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
Error *err = NULL;
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", &err);
|
||||
if (err) {
|
||||
error_propagate(errp, err);
|
||||
return;
|
||||
}
|
||||
|
||||
object_property_set_link(OBJECT(vdev),
|
||||
OBJECT(dev->vdev.conf.cryptodev), "cryptodev",
|
||||
NULL);
|
||||
}
|
||||
|
||||
static void virtio_ccw_gpu_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOGPUCcw *dev = VIRTIO_GPU_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_input_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VirtIOInputCcw *dev = VIRTIO_INPUT_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
/* DeviceState to VirtioCcwDevice. Note: used on datapath,
|
||||
* be careful and test performance if you change this.
|
||||
*/
|
||||
|
@ -1332,363 +1141,6 @@ static void virtio_ccw_device_unplugged(DeviceState *d)
|
|||
}
|
||||
/**************** Virtio-ccw Bus Device Descriptions *******************/
|
||||
|
||||
static Property virtio_ccw_net_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_net_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_net_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_net_properties;
|
||||
set_bit(DEVICE_CATEGORY_NETWORK, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_net = {
|
||||
.name = TYPE_VIRTIO_NET_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIONetCcw),
|
||||
.instance_init = virtio_ccw_net_instance_init,
|
||||
.class_init = virtio_ccw_net_class_init,
|
||||
};
|
||||
|
||||
static Property virtio_ccw_blk_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_blk_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_blk_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_blk_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_blk = {
|
||||
.name = TYPE_VIRTIO_BLK_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOBlkCcw),
|
||||
.instance_init = virtio_ccw_blk_instance_init,
|
||||
.class_init = virtio_ccw_blk_class_init,
|
||||
};
|
||||
|
||||
static Property virtio_ccw_serial_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_serial_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_serial_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_serial_properties;
|
||||
set_bit(DEVICE_CATEGORY_INPUT, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_serial = {
|
||||
.name = TYPE_VIRTIO_SERIAL_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtioSerialCcw),
|
||||
.instance_init = virtio_ccw_serial_instance_init,
|
||||
.class_init = virtio_ccw_serial_class_init,
|
||||
};
|
||||
|
||||
static Property virtio_ccw_balloon_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_balloon_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_balloon_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_balloon_properties;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_balloon = {
|
||||
.name = TYPE_VIRTIO_BALLOON_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOBalloonCcw),
|
||||
.instance_init = virtio_ccw_balloon_instance_init,
|
||||
.class_init = virtio_ccw_balloon_class_init,
|
||||
};
|
||||
|
||||
static Property virtio_ccw_scsi_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_scsi_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_scsi_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_scsi_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_scsi = {
|
||||
.name = TYPE_VIRTIO_SCSI_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOSCSICcw),
|
||||
.instance_init = virtio_ccw_scsi_instance_init,
|
||||
.class_init = virtio_ccw_scsi_class_init,
|
||||
};
|
||||
|
||||
#ifdef CONFIG_VHOST_SCSI
|
||||
static Property vhost_ccw_scsi_properties[] = {
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void vhost_ccw_scsi_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = vhost_ccw_scsi_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = vhost_ccw_scsi_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo vhost_ccw_scsi = {
|
||||
.name = TYPE_VHOST_SCSI_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VHostSCSICcw),
|
||||
.instance_init = vhost_ccw_scsi_instance_init,
|
||||
.class_init = vhost_ccw_scsi_class_init,
|
||||
};
|
||||
#endif
|
||||
|
||||
static void virtio_ccw_rng_instance_init(Object *obj)
|
||||
{
|
||||
VirtIORNGCcw *dev = VIRTIO_RNG_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_RNG);
|
||||
}
|
||||
|
||||
static Property virtio_ccw_rng_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_rng_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_rng_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_rng_properties;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_rng = {
|
||||
.name = TYPE_VIRTIO_RNG_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIORNGCcw),
|
||||
.instance_init = virtio_ccw_rng_instance_init,
|
||||
.class_init = virtio_ccw_rng_class_init,
|
||||
};
|
||||
|
||||
static Property virtio_ccw_crypto_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_crypto_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOCryptoCcw *dev = VIRTIO_CRYPTO_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_CRYPTO);
|
||||
}
|
||||
|
||||
static void virtio_ccw_crypto_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_crypto_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_crypto_properties;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_crypto = {
|
||||
.name = TYPE_VIRTIO_CRYPTO_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOCryptoCcw),
|
||||
.instance_init = virtio_ccw_crypto_instance_init,
|
||||
.class_init = virtio_ccw_crypto_class_init,
|
||||
};
|
||||
|
||||
static Property virtio_ccw_gpu_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_gpu_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOGPUCcw *dev = VIRTIO_GPU_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_GPU);
|
||||
}
|
||||
|
||||
static void virtio_ccw_gpu_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_gpu_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_gpu_properties;
|
||||
dc->hotpluggable = false;
|
||||
set_bit(DEVICE_CATEGORY_DISPLAY, dc->categories);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_gpu = {
|
||||
.name = TYPE_VIRTIO_GPU_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOGPUCcw),
|
||||
.instance_init = virtio_ccw_gpu_instance_init,
|
||||
.class_init = virtio_ccw_gpu_class_init,
|
||||
};
|
||||
|
||||
static Property virtio_ccw_input_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_input_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = virtio_ccw_input_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
dc->props = virtio_ccw_input_properties;
|
||||
set_bit(DEVICE_CATEGORY_INPUT, dc->categories);
|
||||
}
|
||||
|
||||
static void virtio_ccw_keyboard_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOInputHIDCcw *dev = VIRTIO_INPUT_HID_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_KEYBOARD);
|
||||
}
|
||||
|
||||
static void virtio_ccw_mouse_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOInputHIDCcw *dev = VIRTIO_INPUT_HID_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_MOUSE);
|
||||
}
|
||||
|
||||
static void virtio_ccw_tablet_instance_init(Object *obj)
|
||||
{
|
||||
VirtIOInputHIDCcw *dev = VIRTIO_INPUT_HID_CCW(obj);
|
||||
VirtioCcwDevice *ccw_dev = VIRTIO_CCW_DEVICE(obj);
|
||||
|
||||
ccw_dev->force_revision_1 = true;
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_TABLET);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_input = {
|
||||
.name = TYPE_VIRTIO_INPUT_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VirtIOInputCcw),
|
||||
.class_init = virtio_ccw_input_class_init,
|
||||
.abstract = true,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_input_hid = {
|
||||
.name = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.abstract = true,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_keyboard = {
|
||||
.name = TYPE_VIRTIO_KEYBOARD_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.instance_init = virtio_ccw_keyboard_instance_init,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_mouse = {
|
||||
.name = TYPE_VIRTIO_MOUSE_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.instance_init = virtio_ccw_mouse_instance_init,
|
||||
};
|
||||
|
||||
static const TypeInfo virtio_ccw_tablet = {
|
||||
.name = TYPE_VIRTIO_TABLET_CCW,
|
||||
.parent = TYPE_VIRTIO_INPUT_HID_CCW,
|
||||
.instance_size = sizeof(VirtIOInputHIDCcw),
|
||||
.instance_init = virtio_ccw_tablet_instance_init,
|
||||
};
|
||||
|
||||
static void virtio_ccw_busdev_realize(DeviceState *dev, Error **errp)
|
||||
{
|
||||
VirtioCcwDevice *_dev = (VirtioCcwDevice *)dev;
|
||||
|
@ -1700,9 +1152,8 @@ static void virtio_ccw_busdev_realize(DeviceState *dev, Error **errp)
|
|||
static void virtio_ccw_busdev_unrealize(DeviceState *dev, Error **errp)
|
||||
{
|
||||
VirtioCcwDevice *_dev = (VirtioCcwDevice *)dev;
|
||||
VirtIOCCWDeviceClass *_info = VIRTIO_CCW_DEVICE_GET_CLASS(dev);
|
||||
|
||||
_info->unrealize(_dev, errp);
|
||||
virtio_ccw_device_unrealize(_dev, errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_busdev_unplug(HotplugHandler *hotplug_dev,
|
||||
|
@ -1775,123 +1226,10 @@ static const TypeInfo virtio_ccw_bus_info = {
|
|||
.class_init = virtio_ccw_bus_class_init,
|
||||
};
|
||||
|
||||
#ifdef CONFIG_VIRTFS
|
||||
static Property virtio_ccw_9p_properties[] = {
|
||||
DEFINE_PROP_BIT("ioeventfd", VirtioCcwDevice, flags,
|
||||
VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT, true),
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void virtio_ccw_9p_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
V9fsCCWState *dev = VIRTIO_9P_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void virtio_ccw_9p_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
k->realize = virtio_ccw_9p_realize;
|
||||
dc->props = virtio_ccw_9p_properties;
|
||||
set_bit(DEVICE_CATEGORY_STORAGE, dc->categories);
|
||||
}
|
||||
|
||||
static void virtio_ccw_9p_instance_init(Object *obj)
|
||||
{
|
||||
V9fsCCWState *dev = VIRTIO_9P_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VIRTIO_9P);
|
||||
}
|
||||
|
||||
static const TypeInfo virtio_ccw_9p_info = {
|
||||
.name = TYPE_VIRTIO_9P_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(V9fsCCWState),
|
||||
.instance_init = virtio_ccw_9p_instance_init,
|
||||
.class_init = virtio_ccw_9p_class_init,
|
||||
};
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_VHOST_VSOCK
|
||||
|
||||
static Property vhost_vsock_ccw_properties[] = {
|
||||
DEFINE_PROP_UINT32("max_revision", VirtioCcwDevice, max_rev,
|
||||
VIRTIO_CCW_MAX_REV),
|
||||
DEFINE_PROP_END_OF_LIST(),
|
||||
};
|
||||
|
||||
static void vhost_vsock_ccw_realize(VirtioCcwDevice *ccw_dev, Error **errp)
|
||||
{
|
||||
VHostVSockCCWState *dev = VHOST_VSOCK_CCW(ccw_dev);
|
||||
DeviceState *vdev = DEVICE(&dev->vdev);
|
||||
|
||||
qdev_set_parent_bus(vdev, BUS(&ccw_dev->bus));
|
||||
object_property_set_bool(OBJECT(vdev), true, "realized", errp);
|
||||
}
|
||||
|
||||
static void vhost_vsock_ccw_class_init(ObjectClass *klass, void *data)
|
||||
{
|
||||
DeviceClass *dc = DEVICE_CLASS(klass);
|
||||
VirtIOCCWDeviceClass *k = VIRTIO_CCW_DEVICE_CLASS(klass);
|
||||
|
||||
k->realize = vhost_vsock_ccw_realize;
|
||||
k->unrealize = virtio_ccw_unrealize;
|
||||
set_bit(DEVICE_CATEGORY_MISC, dc->categories);
|
||||
dc->props = vhost_vsock_ccw_properties;
|
||||
}
|
||||
|
||||
static void vhost_vsock_ccw_instance_init(Object *obj)
|
||||
{
|
||||
VHostVSockCCWState *dev = VHOST_VSOCK_CCW(obj);
|
||||
|
||||
virtio_instance_init_common(obj, &dev->vdev, sizeof(dev->vdev),
|
||||
TYPE_VHOST_VSOCK);
|
||||
}
|
||||
|
||||
static const TypeInfo vhost_vsock_ccw_info = {
|
||||
.name = TYPE_VHOST_VSOCK_CCW,
|
||||
.parent = TYPE_VIRTIO_CCW_DEVICE,
|
||||
.instance_size = sizeof(VHostVSockCCWState),
|
||||
.instance_init = vhost_vsock_ccw_instance_init,
|
||||
.class_init = vhost_vsock_ccw_class_init,
|
||||
};
|
||||
#endif
|
||||
|
||||
static void virtio_ccw_register(void)
|
||||
{
|
||||
type_register_static(&virtio_ccw_bus_info);
|
||||
type_register_static(&virtio_ccw_device_info);
|
||||
type_register_static(&virtio_ccw_serial);
|
||||
type_register_static(&virtio_ccw_blk);
|
||||
type_register_static(&virtio_ccw_net);
|
||||
type_register_static(&virtio_ccw_balloon);
|
||||
type_register_static(&virtio_ccw_scsi);
|
||||
#ifdef CONFIG_VHOST_SCSI
|
||||
type_register_static(&vhost_ccw_scsi);
|
||||
#endif
|
||||
type_register_static(&virtio_ccw_rng);
|
||||
#ifdef CONFIG_VIRTFS
|
||||
type_register_static(&virtio_ccw_9p_info);
|
||||
#endif
|
||||
#ifdef CONFIG_VHOST_VSOCK
|
||||
type_register_static(&vhost_vsock_ccw_info);
|
||||
#endif
|
||||
type_register_static(&virtio_ccw_crypto);
|
||||
type_register_static(&virtio_ccw_gpu);
|
||||
type_register_static(&virtio_ccw_input);
|
||||
type_register_static(&virtio_ccw_input_hid);
|
||||
type_register_static(&virtio_ccw_keyboard);
|
||||
type_register_static(&virtio_ccw_mouse);
|
||||
type_register_static(&virtio_ccw_tablet);
|
||||
}
|
||||
|
||||
type_init(virtio_ccw_register)
|
||||
|
|
|
@ -102,6 +102,9 @@
|
|||
D(0x9400, NI, SI, Z, la1, i2_8u, new, 0, ni, nz64, MO_UB)
|
||||
D(0xeb54, NIY, SIY, LD, la1, i2_8u, new, 0, ni, nz64, MO_UB)
|
||||
|
||||
/* BRANCH AND LINK */
|
||||
C(0x0500, BALR, RR_a, Z, 0, r2_nz, r1, 0, bal, 0)
|
||||
C(0x4500, BAL, RX_a, Z, 0, a2, r1, 0, bal, 0)
|
||||
/* BRANCH AND SAVE */
|
||||
C(0x0d00, BASR, RR_a, Z, 0, r2_nz, r1, 0, bas, 0)
|
||||
C(0x4d00, BAS, RX_a, Z, 0, a2, r1, 0, bas, 0)
|
||||
|
|
|
@ -1019,15 +1019,15 @@ void HELPER(pack)(CPUS390XState *env, uint32_t len, uint64_t dest, uint64_t src)
|
|||
len_src--;
|
||||
|
||||
/* now pack every value */
|
||||
while (len_dest >= 0) {
|
||||
while (len_dest > 0) {
|
||||
b = 0;
|
||||
|
||||
if (len_src > 0) {
|
||||
if (len_src >= 0) {
|
||||
b = cpu_ldub_data_ra(env, src, ra) & 0x0f;
|
||||
src--;
|
||||
len_src--;
|
||||
}
|
||||
if (len_src > 0) {
|
||||
if (len_src >= 0) {
|
||||
b |= cpu_ldub_data_ra(env, src, ra) << 4;
|
||||
src--;
|
||||
len_src--;
|
||||
|
@ -1299,12 +1299,26 @@ static inline uint32_t do_helper_trt(CPUS390XState *env, int len,
|
|||
return 0;
|
||||
}
|
||||
|
||||
static uint32_t do_helper_trt_fwd(CPUS390XState *env, uint32_t len,
|
||||
uint64_t array, uint64_t trans,
|
||||
uintptr_t ra)
|
||||
{
|
||||
return do_helper_trt(env, len, array, trans, 1, ra);
|
||||
}
|
||||
|
||||
uint32_t HELPER(trt)(CPUS390XState *env, uint32_t len, uint64_t array,
|
||||
uint64_t trans)
|
||||
{
|
||||
return do_helper_trt(env, len, array, trans, 1, GETPC());
|
||||
}
|
||||
|
||||
static uint32_t do_helper_trt_bkwd(CPUS390XState *env, uint32_t len,
|
||||
uint64_t array, uint64_t trans,
|
||||
uintptr_t ra)
|
||||
{
|
||||
return do_helper_trt(env, len, array, trans, -1, ra);
|
||||
}
|
||||
|
||||
uint32_t HELPER(trtr)(CPUS390XState *env, uint32_t len, uint64_t array,
|
||||
uint64_t trans)
|
||||
{
|
||||
|
@ -1442,7 +1456,7 @@ static uint32_t do_csst(CPUS390XState *env, uint32_t r3, uint64_t a1,
|
|||
}
|
||||
|
||||
/* Sanity check the alignments. */
|
||||
if (extract32(a1, 0, 4 << fc) || extract32(a2, 0, 1 << sc)) {
|
||||
if (extract32(a1, 0, fc + 2) || extract32(a2, 0, sc)) {
|
||||
goto spec_exception;
|
||||
}
|
||||
|
||||
|
@ -2193,12 +2207,14 @@ void HELPER(ex)(CPUS390XState *env, uint32_t ilen, uint64_t r1, uint64_t addr)
|
|||
typedef uint32_t (*dx_helper)(CPUS390XState *, uint32_t, uint64_t,
|
||||
uint64_t, uintptr_t);
|
||||
static const dx_helper dx[16] = {
|
||||
[0x0] = do_helper_trt_bkwd,
|
||||
[0x2] = do_helper_mvc,
|
||||
[0x4] = do_helper_nc,
|
||||
[0x5] = do_helper_clc,
|
||||
[0x6] = do_helper_oc,
|
||||
[0x7] = do_helper_xc,
|
||||
[0xc] = do_helper_tr,
|
||||
[0xd] = do_helper_trt_fwd,
|
||||
};
|
||||
dx_helper helper = dx[opc & 0xf];
|
||||
|
||||
|
|
|
@ -84,14 +84,21 @@ static uint64_t inline_branch_hit[CC_OP_MAX];
|
|||
static uint64_t inline_branch_miss[CC_OP_MAX];
|
||||
#endif
|
||||
|
||||
static uint64_t pc_to_link_info(DisasContext *s, uint64_t pc)
|
||||
static void pc_to_link_info(TCGv_i64 out, DisasContext *s, uint64_t pc)
|
||||
{
|
||||
if (!(s->base.tb->flags & FLAG_MASK_64)) {
|
||||
if (s->base.tb->flags & FLAG_MASK_32) {
|
||||
return pc | 0x80000000;
|
||||
TCGv_i64 tmp;
|
||||
|
||||
if (s->base.tb->flags & FLAG_MASK_32) {
|
||||
if (s->base.tb->flags & FLAG_MASK_64) {
|
||||
tcg_gen_movi_i64(out, pc);
|
||||
return;
|
||||
}
|
||||
pc |= 0x80000000;
|
||||
}
|
||||
return pc;
|
||||
assert(!(s->base.tb->flags & FLAG_MASK_64));
|
||||
tmp = tcg_const_i64(pc);
|
||||
tcg_gen_deposit_i64(out, out, tmp, 0, 32);
|
||||
tcg_temp_free_i64(tmp);
|
||||
}
|
||||
|
||||
static TCGv_i64 psw_addr;
|
||||
|
@ -835,7 +842,7 @@ static void disas_jcc(DisasContext *s, DisasCompare *c, uint32_t mask)
|
|||
cond = TCG_COND_NE;
|
||||
c->u.s32.b = tcg_const_i32(1);
|
||||
break;
|
||||
case 0x8 | 0x2: /* cc == 0 || cc == 2 => (cc & 1) == 0 */
|
||||
case 0x8 | 0x2: /* cc == 0 || cc == 2 => (cc & 1) == 0 */
|
||||
cond = TCG_COND_EQ;
|
||||
c->g1 = false;
|
||||
c->u.s32.a = tcg_temp_new_i32();
|
||||
|
@ -854,7 +861,7 @@ static void disas_jcc(DisasContext *s, DisasCompare *c, uint32_t mask)
|
|||
cond = TCG_COND_NE;
|
||||
c->u.s32.b = tcg_const_i32(0);
|
||||
break;
|
||||
case 0x4 | 0x1: /* cc == 1 || cc == 3 => (cc & 1) != 0 */
|
||||
case 0x4 | 0x1: /* cc == 1 || cc == 3 => (cc & 1) != 0 */
|
||||
cond = TCG_COND_NE;
|
||||
c->g1 = false;
|
||||
c->u.s32.a = tcg_temp_new_i32();
|
||||
|
@ -1453,7 +1460,40 @@ static DisasJumpType op_ni(DisasContext *s, DisasOps *o)
|
|||
|
||||
static DisasJumpType op_bas(DisasContext *s, DisasOps *o)
|
||||
{
|
||||
tcg_gen_movi_i64(o->out, pc_to_link_info(s, s->pc_tmp));
|
||||
pc_to_link_info(o->out, s, s->pc_tmp);
|
||||
if (o->in2) {
|
||||
tcg_gen_mov_i64(psw_addr, o->in2);
|
||||
per_branch(s, false);
|
||||
return DISAS_PC_UPDATED;
|
||||
} else {
|
||||
return DISAS_NEXT;
|
||||
}
|
||||
}
|
||||
|
||||
static void save_link_info(DisasContext *s, DisasOps *o)
|
||||
{
|
||||
TCGv_i64 t;
|
||||
|
||||
if (s->base.tb->flags & (FLAG_MASK_32 | FLAG_MASK_64)) {
|
||||
pc_to_link_info(o->out, s, s->pc_tmp);
|
||||
return;
|
||||
}
|
||||
gen_op_calc_cc(s);
|
||||
tcg_gen_andi_i64(o->out, o->out, 0xffffffff00000000ull);
|
||||
tcg_gen_ori_i64(o->out, o->out, ((s->ilen / 2) << 30) | s->pc_tmp);
|
||||
t = tcg_temp_new_i64();
|
||||
tcg_gen_shri_i64(t, psw_mask, 16);
|
||||
tcg_gen_andi_i64(t, t, 0x0f000000);
|
||||
tcg_gen_or_i64(o->out, o->out, t);
|
||||
tcg_gen_extu_i32_i64(t, cc_op);
|
||||
tcg_gen_shli_i64(t, t, 28);
|
||||
tcg_gen_or_i64(o->out, o->out, t);
|
||||
tcg_temp_free_i64(t);
|
||||
}
|
||||
|
||||
static DisasJumpType op_bal(DisasContext *s, DisasOps *o)
|
||||
{
|
||||
save_link_info(s, o);
|
||||
if (o->in2) {
|
||||
tcg_gen_mov_i64(psw_addr, o->in2);
|
||||
per_branch(s, false);
|
||||
|
@ -1465,7 +1505,7 @@ static DisasJumpType op_bas(DisasContext *s, DisasOps *o)
|
|||
|
||||
static DisasJumpType op_basi(DisasContext *s, DisasOps *o)
|
||||
{
|
||||
tcg_gen_movi_i64(o->out, pc_to_link_info(s, s->pc_tmp));
|
||||
pc_to_link_info(o->out, s, s->pc_tmp);
|
||||
return help_goto_direct(s, s->base.pc_next + 2 * get_field(s->fields, i2));
|
||||
}
|
||||
|
||||
|
@ -2018,9 +2058,9 @@ static DisasJumpType op_csst(DisasContext *s, DisasOps *o)
|
|||
TCGv_i32 t_r3 = tcg_const_i32(r3);
|
||||
|
||||
if (tb_cflags(s->base.tb) & CF_PARALLEL) {
|
||||
gen_helper_csst_parallel(cc_op, cpu_env, t_r3, o->in1, o->in2);
|
||||
gen_helper_csst_parallel(cc_op, cpu_env, t_r3, o->addr1, o->in2);
|
||||
} else {
|
||||
gen_helper_csst(cc_op, cpu_env, t_r3, o->in1, o->in2);
|
||||
gen_helper_csst(cc_op, cpu_env, t_r3, o->addr1, o->in2);
|
||||
}
|
||||
tcg_temp_free_i32(t_r3);
|
||||
|
||||
|
@ -2404,20 +2444,17 @@ static DisasJumpType op_insi(DisasContext *s, DisasOps *o)
|
|||
|
||||
static DisasJumpType op_ipm(DisasContext *s, DisasOps *o)
|
||||
{
|
||||
TCGv_i64 t1;
|
||||
TCGv_i64 t1, t2;
|
||||
|
||||
gen_op_calc_cc(s);
|
||||
tcg_gen_andi_i64(o->out, o->out, ~0xff000000ull);
|
||||
|
||||
t1 = tcg_temp_new_i64();
|
||||
tcg_gen_shli_i64(t1, psw_mask, 20);
|
||||
tcg_gen_shri_i64(t1, t1, 36);
|
||||
tcg_gen_or_i64(o->out, o->out, t1);
|
||||
|
||||
tcg_gen_extu_i32_i64(t1, cc_op);
|
||||
tcg_gen_shli_i64(t1, t1, 28);
|
||||
tcg_gen_or_i64(o->out, o->out, t1);
|
||||
tcg_gen_extract_i64(t1, psw_mask, 40, 4);
|
||||
t2 = tcg_temp_new_i64();
|
||||
tcg_gen_extu_i32_i64(t2, cc_op);
|
||||
tcg_gen_deposit_i64(t1, t1, t2, 4, 60);
|
||||
tcg_gen_deposit_i64(o->out, o->out, t1, 24, 8);
|
||||
tcg_temp_free_i64(t1);
|
||||
tcg_temp_free_i64(t2);
|
||||
return DISAS_NEXT;
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,8 @@
|
|||
VPATH+=$(SRC_PATH)/tests/tcg/s390x
|
||||
CFLAGS+=-march=zEC12 -m64
|
||||
TESTS+=hello-s390x
|
||||
TESTS+=csst
|
||||
TESTS+=ipm
|
||||
TESTS+=exrl-trt
|
||||
TESTS+=exrl-trtr
|
||||
TESTS+=pack
|
|
@ -0,0 +1,43 @@
|
|||
#include <stdint.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main(void)
|
||||
{
|
||||
uint64_t parmlist[] = {
|
||||
0xfedcba9876543210ull,
|
||||
0,
|
||||
0x7777777777777777ull,
|
||||
0,
|
||||
};
|
||||
uint64_t op1 = 0x0123456789abcdefull;
|
||||
uint64_t op2 = 0;
|
||||
uint64_t op3 = op1;
|
||||
uint64_t cc;
|
||||
|
||||
asm volatile(
|
||||
" lghi %%r0,%[flags]\n"
|
||||
" la %%r1,%[parmlist]\n"
|
||||
" csst %[op1],%[op2],%[op3]\n"
|
||||
" ipm %[cc]\n"
|
||||
: [op1] "+m" (op1),
|
||||
[op2] "+m" (op2),
|
||||
[op3] "+r" (op3),
|
||||
[cc] "=r" (cc)
|
||||
: [flags] "K" (0x0301),
|
||||
[parmlist] "m" (parmlist)
|
||||
: "r0", "r1", "cc", "memory");
|
||||
cc = (cc >> 28) & 3;
|
||||
if (cc) {
|
||||
write(1, "bad cc\n", 7);
|
||||
return 1;
|
||||
}
|
||||
if (op1 != parmlist[0]) {
|
||||
write(1, "bad op1\n", 8);
|
||||
return 1;
|
||||
}
|
||||
if (op2 != parmlist[2]) {
|
||||
write(1, "bad op2\n", 8);
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,48 @@
|
|||
#include <stdint.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main(void)
|
||||
{
|
||||
char op1[] = "hello";
|
||||
char op2[256];
|
||||
uint64_t r1 = 0xffffffffffffffffull;
|
||||
uint64_t r2 = 0xffffffffffffffffull;
|
||||
uint64_t cc;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < 256; i++) {
|
||||
if (i == 0) {
|
||||
op2[i] = 0xaa;
|
||||
} else {
|
||||
op2[i] = 0;
|
||||
}
|
||||
}
|
||||
asm volatile(
|
||||
" j 2f\n"
|
||||
"1: trt 0(1,%[op1]),0(%[op2])\n"
|
||||
"2: exrl %[op1_len],1b\n"
|
||||
" lgr %[r1],%%r1\n"
|
||||
" lgr %[r2],%%r2\n"
|
||||
" ipm %[cc]\n"
|
||||
: [r1] "+r" (r1),
|
||||
[r2] "+r" (r2),
|
||||
[cc] "=r" (cc)
|
||||
: [op1] "r" (&op1),
|
||||
[op1_len] "r" (5),
|
||||
[op2] "r" (&op2)
|
||||
: "r1", "r2", "cc");
|
||||
cc = (cc >> 28) & 3;
|
||||
if (cc != 2) {
|
||||
write(1, "bad cc\n", 7);
|
||||
return 1;
|
||||
}
|
||||
if ((char *)r1 != &op1[5]) {
|
||||
write(1, "bad r1\n", 7);
|
||||
return 1;
|
||||
}
|
||||
if (r2 != 0xffffffffffffffaaull) {
|
||||
write(1, "bad r2\n", 7);
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,48 @@
|
|||
#include <stdint.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main(void)
|
||||
{
|
||||
char op1[] = {0, 1, 2, 3};
|
||||
char op2[256];
|
||||
uint64_t r1 = 0xffffffffffffffffull;
|
||||
uint64_t r2 = 0xffffffffffffffffull;
|
||||
uint64_t cc;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < 256; i++) {
|
||||
if (i == 1) {
|
||||
op2[i] = 0xbb;
|
||||
} else {
|
||||
op2[i] = 0;
|
||||
}
|
||||
}
|
||||
asm volatile(
|
||||
" j 2f\n"
|
||||
"1: trtr 3(1,%[op1]),0(%[op2])\n"
|
||||
"2: exrl %[op1_len],1b\n"
|
||||
" lgr %[r1],%%r1\n"
|
||||
" lgr %[r2],%%r2\n"
|
||||
" ipm %[cc]\n"
|
||||
: [r1] "+r" (r1),
|
||||
[r2] "+r" (r2),
|
||||
[cc] "=r" (cc)
|
||||
: [op1] "r" (&op1),
|
||||
[op1_len] "r" (3),
|
||||
[op2] "r" (&op2)
|
||||
: "r1", "r2", "cc");
|
||||
cc = (cc >> 28) & 3;
|
||||
if (cc != 1) {
|
||||
write(1, "bad cc\n", 7);
|
||||
return 1;
|
||||
}
|
||||
if ((char *)r1 != &op1[1]) {
|
||||
write(1, "bad r1\n", 7);
|
||||
return 1;
|
||||
}
|
||||
if (r2 != 0xffffffffffffffbbull) {
|
||||
write(1, "bad r2\n", 7);
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,7 @@
|
|||
#include <unistd.h>
|
||||
|
||||
int main(void)
|
||||
{
|
||||
write(1, "hello\n", 6);
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,22 @@
|
|||
#include <stdint.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main(void)
|
||||
{
|
||||
uint32_t op1 = 0x55555555;
|
||||
uint32_t op2 = 0x44444444;
|
||||
uint64_t cc = 0xffffffffffffffffull;
|
||||
|
||||
asm volatile(
|
||||
" clc 0(4,%[op1]),0(%[op2])\n"
|
||||
" ipm %[cc]\n"
|
||||
: [cc] "+r" (cc)
|
||||
: [op1] "r" (&op1),
|
||||
[op2] "r" (&op2)
|
||||
: "cc");
|
||||
if (cc != 0xffffffff20ffffffull) {
|
||||
write(1, "bad cc\n", 7);
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,21 @@
|
|||
#include <unistd.h>
|
||||
|
||||
int main(void)
|
||||
{
|
||||
char data[] = {0xaa, 0xaa, 0xf1, 0xf2, 0xf3, 0xc4, 0xaa, 0xaa};
|
||||
char exp[] = {0xaa, 0xaa, 0x00, 0x01, 0x23, 0x4c, 0xaa, 0xaa};
|
||||
int i;
|
||||
|
||||
asm volatile(
|
||||
" pack 2(4,%[data]),2(4,%[data])\n"
|
||||
:
|
||||
: [data] "r" (&data[0])
|
||||
: "memory");
|
||||
for (i = 0; i < 8; i++) {
|
||||
if (data[i] != exp[i]) {
|
||||
write(1, "bad data\n", 9);
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
Loading…
Reference in New Issue