提交 1ab461b5 编写于 作者: K KONRAD Frederic 提交者: Anthony Liguori

virtio-balloon: add the virtio-balloon device.

Create virtio-balloon which extends virtio-device, so it can be connected on
virtio-bus.
Signed-off-by: NKONRAD Frederic <fred.konrad@greensocs.com>
Reviewed-by: NCornelia Huck <cornelia.huck@de.ibm.com>
Reviewed-by: NPeter Maydell <peter.maydell@linaro.org>
Tested-by: NCornelia Huck <cornelia.huck@de.ibm.com>
Message-id: 1364377755-15508-2-git-send-email-fred.konrad@greensocs.com
Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
上级 fde245ca
...@@ -29,6 +29,11 @@ ...@@ -29,6 +29,11 @@
#include <sys/mman.h> #include <sys/mman.h>
#endif #endif
#include "hw/virtio-bus.h"
/*
* Will be modified later in the serie.
*/
static VirtIOBalloon *to_virtio_balloon(VirtIODevice *vdev) static VirtIOBalloon *to_virtio_balloon(VirtIODevice *vdev)
{ {
return (VirtIOBalloon *)vdev; return (VirtIOBalloon *)vdev;
...@@ -334,14 +339,27 @@ static int virtio_balloon_load(QEMUFile *f, void *opaque, int version_id) ...@@ -334,14 +339,27 @@ static int virtio_balloon_load(QEMUFile *f, void *opaque, int version_id)
return 0; return 0;
} }
VirtIODevice *virtio_balloon_init(DeviceState *dev) static VirtIODevice *virtio_balloon_common_init(DeviceState *dev,
VirtIOBalloon **ps)
{ {
VirtIOBalloon *s; VirtIOBalloon *s = *ps;
int ret; int ret;
/*
* We have two cases here: the old virtio-balloon-x device, and the
* refactored virtio-balloon.
* This will disappear later in the serie.
*/
int old_device = (s == NULL);
if (s == NULL) {
/* old virtio-balloon-pci or virtio-balloon-s390, no memory allocated */
s = (VirtIOBalloon *)virtio_common_init("virtio-balloon", s = (VirtIOBalloon *)virtio_common_init("virtio-balloon",
VIRTIO_ID_BALLOON, VIRTIO_ID_BALLOON,
8, sizeof(VirtIOBalloon)); 8, sizeof(VirtIOBalloon));
} else {
/* new API virtio-balloon. (memory allocated by qdev) */
virtio_init(VIRTIO_DEVICE(s), "virtio-balloon", VIRTIO_ID_BALLOON, 8);
}
s->vdev.get_config = virtio_balloon_get_config; s->vdev.get_config = virtio_balloon_get_config;
s->vdev.set_config = virtio_balloon_set_config; s->vdev.set_config = virtio_balloon_set_config;
...@@ -349,10 +367,14 @@ VirtIODevice *virtio_balloon_init(DeviceState *dev) ...@@ -349,10 +367,14 @@ VirtIODevice *virtio_balloon_init(DeviceState *dev)
ret = qemu_add_balloon_handler(virtio_balloon_to_target, ret = qemu_add_balloon_handler(virtio_balloon_to_target,
virtio_balloon_stat, s); virtio_balloon_stat, s);
if (ret < 0) { if ((ret < 0) && (old_device)) {
virtio_cleanup(&s->vdev); virtio_cleanup(&s->vdev);
return NULL; return NULL;
} }
if (ret < 0) {
virtio_common_cleanup(VIRTIO_DEVICE(s));
return NULL;
}
s->ivq = virtio_add_queue(&s->vdev, 128, virtio_balloon_handle_output); s->ivq = virtio_add_queue(&s->vdev, 128, virtio_balloon_handle_output);
s->dvq = virtio_add_queue(&s->vdev, 128, virtio_balloon_handle_output); s->dvq = virtio_add_queue(&s->vdev, 128, virtio_balloon_handle_output);
...@@ -373,6 +395,15 @@ VirtIODevice *virtio_balloon_init(DeviceState *dev) ...@@ -373,6 +395,15 @@ VirtIODevice *virtio_balloon_init(DeviceState *dev)
return &s->vdev; return &s->vdev;
} }
/*
* This two functions will be removed later in the serie.
*/
VirtIODevice *virtio_balloon_init(DeviceState *dev)
{
VirtIOBalloon *s = NULL;
return virtio_balloon_common_init(dev, &s);
}
void virtio_balloon_exit(VirtIODevice *vdev) void virtio_balloon_exit(VirtIODevice *vdev)
{ {
VirtIOBalloon *s = DO_UPCAST(VirtIOBalloon, vdev, vdev); VirtIOBalloon *s = DO_UPCAST(VirtIOBalloon, vdev, vdev);
...@@ -382,3 +413,55 @@ void virtio_balloon_exit(VirtIODevice *vdev) ...@@ -382,3 +413,55 @@ void virtio_balloon_exit(VirtIODevice *vdev)
unregister_savevm(s->qdev, "virtio-balloon", s); unregister_savevm(s->qdev, "virtio-balloon", s);
virtio_cleanup(vdev); virtio_cleanup(vdev);
} }
static int virtio_balloon_device_init(VirtIODevice *vdev)
{
DeviceState *qdev = DEVICE(vdev);
VirtIOBalloon *s = VIRTIO_BALLOON(vdev);
if (virtio_balloon_common_init(qdev, &s) == NULL) {
return -1;
}
return 0;
}
static int virtio_balloon_device_exit(DeviceState *qdev)
{
VirtIOBalloon *s = VIRTIO_BALLOON(qdev);
VirtIODevice *vdev = VIRTIO_DEVICE(qdev);
balloon_stats_destroy_timer(s);
qemu_remove_balloon_handler(s);
unregister_savevm(qdev, "virtio-balloon", s);
virtio_common_cleanup(vdev);
return 0;
}
static Property virtio_balloon_properties[] = {
DEFINE_PROP_END_OF_LIST(),
};
static void virtio_balloon_class_init(ObjectClass *klass, void *data)
{
DeviceClass *dc = DEVICE_CLASS(klass);
VirtioDeviceClass *vdc = VIRTIO_DEVICE_CLASS(klass);
dc->exit = virtio_balloon_device_exit;
dc->props = virtio_balloon_properties;
vdc->init = virtio_balloon_device_init;
vdc->get_config = virtio_balloon_get_config;
vdc->set_config = virtio_balloon_set_config;
vdc->get_features = virtio_balloon_get_features;
}
static const TypeInfo virtio_balloon_info = {
.name = TYPE_VIRTIO_BALLOON,
.parent = TYPE_VIRTIO_DEVICE,
.instance_size = sizeof(VirtIOBalloon),
.class_init = virtio_balloon_class_init,
};
static void virtio_register_types(void)
{
type_register_static(&virtio_balloon_info);
}
type_init(virtio_register_types)
...@@ -18,6 +18,10 @@ ...@@ -18,6 +18,10 @@
#include "hw/virtio.h" #include "hw/virtio.h"
#include "hw/pci/pci.h" #include "hw/pci/pci.h"
#define TYPE_VIRTIO_BALLOON "virtio-balloon"
#define VIRTIO_BALLOON(obj) \
OBJECT_CHECK(VirtIOBalloon, (obj), TYPE_VIRTIO_BALLOON)
/* from Linux's linux/virtio_balloon.h */ /* from Linux's linux/virtio_balloon.h */
/* The ID for virtio_balloon */ /* The ID for virtio_balloon */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册