virtio-rng: cleanup: use QOM casts.
As the virtio-rng-pci, virtio-rng-s390 and virtio-rng-ccw are switched to the new API, we can use QOM casts. Signed-off-by: KONRAD Frederic <fred.konrad@greensocs.com> Reviewed-by: Andreas Färber <afaerber@suse.de> Reviewed-by: Andreas Färber <afaerber@suse.de> Tested-by: Cornelia Huck <cornelia.huck@de.ibm.com> Acked-by: Amit Shah <amit.shah@redhat.com> Message-id: 1366790881-3026-9-git-send-email-fred.konrad@greensocs.com Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
65f3b678f5
commit
611aa333b4
@ -18,8 +18,9 @@
|
|||||||
|
|
||||||
static bool is_guest_ready(VirtIORNG *vrng)
|
static bool is_guest_ready(VirtIORNG *vrng)
|
||||||
{
|
{
|
||||||
|
VirtIODevice *vdev = VIRTIO_DEVICE(vrng);
|
||||||
if (virtio_queue_ready(vrng->vq)
|
if (virtio_queue_ready(vrng->vq)
|
||||||
&& (vrng->vdev.status & VIRTIO_CONFIG_S_DRIVER_OK)) {
|
&& (vdev->status & VIRTIO_CONFIG_S_DRIVER_OK)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -39,6 +40,7 @@ static void virtio_rng_process(VirtIORNG *vrng);
|
|||||||
static void chr_read(void *opaque, const void *buf, size_t size)
|
static void chr_read(void *opaque, const void *buf, size_t size)
|
||||||
{
|
{
|
||||||
VirtIORNG *vrng = opaque;
|
VirtIORNG *vrng = opaque;
|
||||||
|
VirtIODevice *vdev = VIRTIO_DEVICE(vrng);
|
||||||
VirtQueueElement elem;
|
VirtQueueElement elem;
|
||||||
size_t len;
|
size_t len;
|
||||||
int offset;
|
int offset;
|
||||||
@ -60,7 +62,7 @@ static void chr_read(void *opaque, const void *buf, size_t size)
|
|||||||
|
|
||||||
virtqueue_push(vrng->vq, &elem, len);
|
virtqueue_push(vrng->vq, &elem, len);
|
||||||
}
|
}
|
||||||
virtio_notify(&vrng->vdev, vrng->vq);
|
virtio_notify(vdev, vrng->vq);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void virtio_rng_process(VirtIORNG *vrng)
|
static void virtio_rng_process(VirtIORNG *vrng)
|
||||||
@ -86,7 +88,7 @@ static void virtio_rng_process(VirtIORNG *vrng)
|
|||||||
|
|
||||||
static void handle_input(VirtIODevice *vdev, VirtQueue *vq)
|
static void handle_input(VirtIODevice *vdev, VirtQueue *vq)
|
||||||
{
|
{
|
||||||
VirtIORNG *vrng = DO_UPCAST(VirtIORNG, vdev, vdev);
|
VirtIORNG *vrng = VIRTIO_RNG(vdev);
|
||||||
virtio_rng_process(vrng);
|
virtio_rng_process(vrng);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,19 +99,20 @@ static uint32_t get_features(VirtIODevice *vdev, uint32_t f)
|
|||||||
|
|
||||||
static void virtio_rng_save(QEMUFile *f, void *opaque)
|
static void virtio_rng_save(QEMUFile *f, void *opaque)
|
||||||
{
|
{
|
||||||
VirtIORNG *vrng = opaque;
|
VirtIODevice *vdev = opaque;
|
||||||
|
|
||||||
virtio_save(&vrng->vdev, f);
|
virtio_save(vdev, f);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int virtio_rng_load(QEMUFile *f, void *opaque, int version_id)
|
static int virtio_rng_load(QEMUFile *f, void *opaque, int version_id)
|
||||||
{
|
{
|
||||||
VirtIORNG *vrng = opaque;
|
VirtIORNG *vrng = opaque;
|
||||||
|
VirtIODevice *vdev = VIRTIO_DEVICE(vrng);
|
||||||
|
|
||||||
if (version_id != 1) {
|
if (version_id != 1) {
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
virtio_load(&vrng->vdev, f);
|
virtio_load(vdev, f);
|
||||||
|
|
||||||
/* We may have an element ready but couldn't process it due to a quota
|
/* We may have an element ready but couldn't process it due to a quota
|
||||||
* limit. Make sure to try again after live migration when the quota may
|
* limit. Make sure to try again after live migration when the quota may
|
||||||
@ -122,12 +125,12 @@ static int virtio_rng_load(QEMUFile *f, void *opaque, int version_id)
|
|||||||
|
|
||||||
static void check_rate_limit(void *opaque)
|
static void check_rate_limit(void *opaque)
|
||||||
{
|
{
|
||||||
VirtIORNG *s = opaque;
|
VirtIORNG *vrng = opaque;
|
||||||
|
|
||||||
s->quota_remaining = s->conf.max_bytes;
|
vrng->quota_remaining = vrng->conf.max_bytes;
|
||||||
virtio_rng_process(s);
|
virtio_rng_process(vrng);
|
||||||
qemu_mod_timer(s->rate_limit_timer,
|
qemu_mod_timer(vrng->rate_limit_timer,
|
||||||
qemu_get_clock_ms(vm_clock) + s->conf.period_ms);
|
qemu_get_clock_ms(vm_clock) + vrng->conf.period_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int virtio_rng_device_init(VirtIODevice *vdev)
|
static int virtio_rng_device_init(VirtIODevice *vdev)
|
||||||
@ -166,7 +169,7 @@ static int virtio_rng_device_init(VirtIODevice *vdev)
|
|||||||
|
|
||||||
vrng->vq = virtio_add_queue(vdev, 8, handle_input);
|
vrng->vq = virtio_add_queue(vdev, 8, handle_input);
|
||||||
|
|
||||||
vrng->vdev.get_features = get_features;
|
vdev->get_features = get_features;
|
||||||
|
|
||||||
assert(vrng->conf.max_bytes <= INT64_MAX);
|
assert(vrng->conf.max_bytes <= INT64_MAX);
|
||||||
vrng->quota_remaining = vrng->conf.max_bytes;
|
vrng->quota_remaining = vrng->conf.max_bytes;
|
||||||
|
@ -30,7 +30,7 @@ struct VirtIORNGConf {
|
|||||||
};
|
};
|
||||||
|
|
||||||
typedef struct VirtIORNG {
|
typedef struct VirtIORNG {
|
||||||
VirtIODevice vdev;
|
VirtIODevice parent_obj;
|
||||||
|
|
||||||
/* Only one vq - guest puts buffer(s) on it when it needs entropy */
|
/* Only one vq - guest puts buffer(s) on it when it needs entropy */
|
||||||
VirtQueue *vq;
|
VirtQueue *vq;
|
||||||
|
Loading…
Reference in New Issue
Block a user