xref: /qemu/hw/virtio/vhost-user-snd.c (revision 12d1a768bdfea6e27a3a829228840d72507613a1)
14ae0fc18SManos Pitsidianakis /*
24ae0fc18SManos Pitsidianakis  * Vhost-user snd virtio device
34ae0fc18SManos Pitsidianakis  *
44ae0fc18SManos Pitsidianakis  * Copyright (c) 2023 Manos Pitsidianakis <manos.pitsidianakis@linaro.org>
54ae0fc18SManos Pitsidianakis  *
64ae0fc18SManos Pitsidianakis  * Simple wrapper of the generic vhost-user-device.
74ae0fc18SManos Pitsidianakis  *
84ae0fc18SManos Pitsidianakis  * SPDX-License-Identifier: GPL-2.0-or-later
94ae0fc18SManos Pitsidianakis  */
104ae0fc18SManos Pitsidianakis 
114ae0fc18SManos Pitsidianakis #include "qemu/osdep.h"
124ae0fc18SManos Pitsidianakis #include "qapi/error.h"
134ae0fc18SManos Pitsidianakis #include "hw/qdev-properties.h"
144ae0fc18SManos Pitsidianakis #include "hw/virtio/virtio-bus.h"
154ae0fc18SManos Pitsidianakis #include "hw/virtio/vhost-user-snd.h"
164ae0fc18SManos Pitsidianakis #include "standard-headers/linux/virtio_ids.h"
174ae0fc18SManos Pitsidianakis #include "standard-headers/linux/virtio_snd.h"
184ae0fc18SManos Pitsidianakis 
19e87b6efbSMatias Ezequiel Vara Larsen static const VirtIOFeature feature_sizes[] = {
20e87b6efbSMatias Ezequiel Vara Larsen     {.flags = 1ULL << VIRTIO_SND_F_CTLS,
21e87b6efbSMatias Ezequiel Vara Larsen     .end = endof(struct virtio_snd_config, controls)},
22e87b6efbSMatias Ezequiel Vara Larsen     {}
23e87b6efbSMatias Ezequiel Vara Larsen };
24e87b6efbSMatias Ezequiel Vara Larsen 
25e87b6efbSMatias Ezequiel Vara Larsen static const VirtIOConfigSizeParams cfg_size_params = {
26e87b6efbSMatias Ezequiel Vara Larsen     .min_size = endof(struct virtio_snd_config, chmaps),
27e87b6efbSMatias Ezequiel Vara Larsen     .max_size = sizeof(struct virtio_snd_config),
28e87b6efbSMatias Ezequiel Vara Larsen     .feature_sizes = feature_sizes
29e87b6efbSMatias Ezequiel Vara Larsen };
30e87b6efbSMatias Ezequiel Vara Larsen 
314ae0fc18SManos Pitsidianakis static const VMStateDescription vu_snd_vmstate = {
324ae0fc18SManos Pitsidianakis     .name = "vhost-user-snd",
334ae0fc18SManos Pitsidianakis     .unmigratable = 1,
344ae0fc18SManos Pitsidianakis };
354ae0fc18SManos Pitsidianakis 
361577a918SRichard Henderson static const Property vsnd_properties[] = {
374ae0fc18SManos Pitsidianakis     DEFINE_PROP_CHR("chardev", VHostUserBase, chardev),
38e87b6efbSMatias Ezequiel Vara Larsen     DEFINE_PROP_BIT64("controls", VHostUserBase,
39e87b6efbSMatias Ezequiel Vara Larsen                       parent_obj.host_features, VIRTIO_SND_F_CTLS, false),
404ae0fc18SManos Pitsidianakis };
414ae0fc18SManos Pitsidianakis 
424ae0fc18SManos Pitsidianakis static void vu_snd_base_realize(DeviceState *dev, Error **errp)
434ae0fc18SManos Pitsidianakis {
444ae0fc18SManos Pitsidianakis     VHostUserBase *vub = VHOST_USER_BASE(dev);
454ae0fc18SManos Pitsidianakis     VHostUserBaseClass *vubs = VHOST_USER_BASE_GET_CLASS(dev);
46e87b6efbSMatias Ezequiel Vara Larsen     VirtIODevice *vdev = &vub->parent_obj;
474ae0fc18SManos Pitsidianakis 
484ae0fc18SManos Pitsidianakis     vub->virtio_id = VIRTIO_ID_SOUND;
494ae0fc18SManos Pitsidianakis     vub->num_vqs = 4;
50e87b6efbSMatias Ezequiel Vara Larsen     vub->config_size = virtio_get_config_size(&cfg_size_params,
51e87b6efbSMatias Ezequiel Vara Larsen                                               vdev->host_features);
524ae0fc18SManos Pitsidianakis     vub->vq_size = 64;
534ae0fc18SManos Pitsidianakis 
544ae0fc18SManos Pitsidianakis     vubs->parent_realize(dev, errp);
554ae0fc18SManos Pitsidianakis }
564ae0fc18SManos Pitsidianakis 
57*12d1a768SPhilippe Mathieu-Daudé static void vu_snd_class_init(ObjectClass *klass, const void *data)
584ae0fc18SManos Pitsidianakis {
594ae0fc18SManos Pitsidianakis     DeviceClass *dc = DEVICE_CLASS(klass);
604ae0fc18SManos Pitsidianakis     VHostUserBaseClass *vubc = VHOST_USER_BASE_CLASS(klass);
614ae0fc18SManos Pitsidianakis 
624ae0fc18SManos Pitsidianakis     dc->vmsd = &vu_snd_vmstate;
634ae0fc18SManos Pitsidianakis     device_class_set_props(dc, vsnd_properties);
644ae0fc18SManos Pitsidianakis     device_class_set_parent_realize(dc, vu_snd_base_realize,
654ae0fc18SManos Pitsidianakis                                     &vubc->parent_realize);
664ae0fc18SManos Pitsidianakis 
674ae0fc18SManos Pitsidianakis     set_bit(DEVICE_CATEGORY_SOUND, dc->categories);
684ae0fc18SManos Pitsidianakis }
694ae0fc18SManos Pitsidianakis 
704ae0fc18SManos Pitsidianakis static const TypeInfo vu_snd_info = {
714ae0fc18SManos Pitsidianakis     .name = TYPE_VHOST_USER_SND,
724ae0fc18SManos Pitsidianakis     .parent = TYPE_VHOST_USER_BASE,
734ae0fc18SManos Pitsidianakis     .instance_size = sizeof(VHostUserSound),
744ae0fc18SManos Pitsidianakis     .class_init = vu_snd_class_init,
754ae0fc18SManos Pitsidianakis };
764ae0fc18SManos Pitsidianakis 
774ae0fc18SManos Pitsidianakis static void vu_snd_register_types(void)
784ae0fc18SManos Pitsidianakis {
794ae0fc18SManos Pitsidianakis     type_register_static(&vu_snd_info);
804ae0fc18SManos Pitsidianakis }
814ae0fc18SManos Pitsidianakis 
824ae0fc18SManos Pitsidianakis type_init(vu_snd_register_types)
83