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
19*dc203a59SMatias Ezequiel Vara Larsen static const VirtIOFeature feature_sizes[] = {
20*dc203a59SMatias Ezequiel Vara Larsen {.flags = 1ULL << VIRTIO_SND_F_CTLS,
21*dc203a59SMatias Ezequiel Vara Larsen .end = endof(struct virtio_snd_config, controls)},
22*dc203a59SMatias Ezequiel Vara Larsen {}
23*dc203a59SMatias Ezequiel Vara Larsen };
24*dc203a59SMatias Ezequiel Vara Larsen
25*dc203a59SMatias Ezequiel Vara Larsen static const VirtIOConfigSizeParams cfg_size_params = {
26*dc203a59SMatias Ezequiel Vara Larsen .min_size = endof(struct virtio_snd_config, chmaps),
27*dc203a59SMatias Ezequiel Vara Larsen .max_size = sizeof(struct virtio_snd_config),
28*dc203a59SMatias Ezequiel Vara Larsen .feature_sizes = feature_sizes
vu_snd_base_realize(DeviceState * dev,Error ** errp)29*dc203a59SMatias Ezequiel Vara Larsen };
30*dc203a59SMatias 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
364ae0fc18SManos Pitsidianakis static Property vsnd_properties[] = {
374ae0fc18SManos Pitsidianakis DEFINE_PROP_CHR("chardev", VHostUserBase, chardev),
38*dc203a59SMatias Ezequiel Vara Larsen DEFINE_PROP_BIT64("controls", VHostUserBase,
39*dc203a59SMatias Ezequiel Vara Larsen parent_obj.host_features, VIRTIO_SND_F_CTLS, false),
404ae0fc18SManos Pitsidianakis DEFINE_PROP_END_OF_LIST(),
414ae0fc18SManos Pitsidianakis };
vu_snd_class_init(ObjectClass * klass,void * data)424ae0fc18SManos Pitsidianakis
434ae0fc18SManos Pitsidianakis static void vu_snd_base_realize(DeviceState *dev, Error **errp)
444ae0fc18SManos Pitsidianakis {
454ae0fc18SManos Pitsidianakis VHostUserBase *vub = VHOST_USER_BASE(dev);
464ae0fc18SManos Pitsidianakis VHostUserBaseClass *vubs = VHOST_USER_BASE_GET_CLASS(dev);
47*dc203a59SMatias Ezequiel Vara Larsen VirtIODevice *vdev = &vub->parent_obj;
484ae0fc18SManos Pitsidianakis
494ae0fc18SManos Pitsidianakis vub->virtio_id = VIRTIO_ID_SOUND;
504ae0fc18SManos Pitsidianakis vub->num_vqs = 4;
51*dc203a59SMatias Ezequiel Vara Larsen vub->config_size = virtio_get_config_size(&cfg_size_params,
52*dc203a59SMatias Ezequiel Vara Larsen vdev->host_features);
534ae0fc18SManos Pitsidianakis vub->vq_size = 64;
544ae0fc18SManos Pitsidianakis
554ae0fc18SManos Pitsidianakis vubs->parent_realize(dev, errp);
564ae0fc18SManos Pitsidianakis }
574ae0fc18SManos Pitsidianakis
584ae0fc18SManos Pitsidianakis static void vu_snd_class_init(ObjectClass *klass, void *data)
594ae0fc18SManos Pitsidianakis {
604ae0fc18SManos Pitsidianakis DeviceClass *dc = DEVICE_CLASS(klass);
614ae0fc18SManos Pitsidianakis VHostUserBaseClass *vubc = VHOST_USER_BASE_CLASS(klass);
vu_snd_register_types(void)624ae0fc18SManos Pitsidianakis
634ae0fc18SManos Pitsidianakis dc->vmsd = &vu_snd_vmstate;
644ae0fc18SManos Pitsidianakis device_class_set_props(dc, vsnd_properties);
654ae0fc18SManos Pitsidianakis device_class_set_parent_realize(dc, vu_snd_base_realize,
664ae0fc18SManos Pitsidianakis &vubc->parent_realize);
674ae0fc18SManos Pitsidianakis
684ae0fc18SManos Pitsidianakis set_bit(DEVICE_CATEGORY_SOUND, dc->categories);
694ae0fc18SManos Pitsidianakis }
704ae0fc18SManos Pitsidianakis
714ae0fc18SManos Pitsidianakis static const TypeInfo vu_snd_info = {
724ae0fc18SManos Pitsidianakis .name = TYPE_VHOST_USER_SND,
734ae0fc18SManos Pitsidianakis .parent = TYPE_VHOST_USER_BASE,
744ae0fc18SManos Pitsidianakis .instance_size = sizeof(VHostUserSound),
754ae0fc18SManos Pitsidianakis .class_init = vu_snd_class_init,
764ae0fc18SManos Pitsidianakis };
774ae0fc18SManos Pitsidianakis
784ae0fc18SManos Pitsidianakis static void vu_snd_register_types(void)
794ae0fc18SManos Pitsidianakis {
804ae0fc18SManos Pitsidianakis type_register_static(&vu_snd_info);
814ae0fc18SManos Pitsidianakis }
824ae0fc18SManos Pitsidianakis
834ae0fc18SManos Pitsidianakis type_init(vu_snd_register_types)
84