xref: /openbmc/qemu/hw/virtio/vhost-user-snd.c (revision dc203a598765b11bd667ae925c2953443f7a60ee)
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