From nobody Sun May 19 11:31:11 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1614707853; cv=none; d=zohomail.com; s=zohoarc; b=Tq/VBzX6W9JhHFkZJ+IDAXyFTZVhU4P3YhCE5S6Eg3qsVPev9Ok7nhHTr75EHPbG3guWn2vcqxSHHMnaxxl99DA3RXyI8oi7sJ8QXRSM46zfvgp+tC6nUFKgEtmHom1+evkbbsjq4qFUT3q1zETN+j7wwjZvhFYDqrAmKW26fO0= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1614707853; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=+w1TdHsL+zCM/F/WczjhsSCYLbBjWjKeCO0aIS2FI2I=; b=QiYKABMdU3CXCJLEdTIynrEIAFpv8NLVp6QWsIzDoCvIC/jWJ/j0XPFHlppk+v71RIxmZ5L9kGPwGI411SI4FnxG7nDmwMSSxkSoeS23i6wC7vv7sJpJMPzl6xa/8dA+B7R6xhPtKbqU45eHku3FqxclyXtDjrQ872Bl6eZEzzE= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail header.from= (p=none dis=none) header.from= Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 161470785389296.50672941650987; Tue, 2 Mar 2021 09:57:33 -0800 (PST) Received: from localhost ([::1]:51574 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1lH9H2-0001KC-T0 for importer@patchew.org; Tue, 02 Mar 2021 12:57:32 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]:58330) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1lH9FE-00082z-E0 for qemu-devel@nongnu.org; Tue, 02 Mar 2021 12:55:40 -0500 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:51868) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.90_1) (envelope-from ) id 1lH9FA-0007IN-Kk for qemu-devel@nongnu.org; Tue, 02 Mar 2021 12:55:40 -0500 Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-48-H6RgHmGgNaewRf5pSdav0g-1; Tue, 02 Mar 2021 12:55:33 -0500 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id E8D1E80402C; Tue, 2 Mar 2021 17:55:32 +0000 (UTC) Received: from localhost.localdomain.com (ovpn-113-132.ams2.redhat.com [10.36.113.132]) by smtp.corp.redhat.com (Postfix) with ESMTP id 2A37C62665; Tue, 2 Mar 2021 17:55:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1614707735; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=+w1TdHsL+zCM/F/WczjhsSCYLbBjWjKeCO0aIS2FI2I=; b=PSo8dat8Ob+UyCBQGR0ClTe8MliIS7QeBmjmE06l2s3a1n5jb/Q7ePISixHD+J6hLh7EW/ wRa7z6yMwSfmOsnI8ObHEI4zgRc++8Ci6MkdjcgVA7KG7kr70AZ4afpdZwiM18hD77Um13 XSbpKd23RNT0iFOXCO0NTRVG8/24wGA= X-MC-Unique: H6RgHmGgNaewRf5pSdav0g-1 From: =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= To: qemu-devel@nongnu.org Subject: [PATCH 1/3] qapi, audio: add query-audiodev command Date: Tue, 2 Mar 2021 17:55:22 +0000 Message-Id: <20210302175524.1290840-2-berrange@redhat.com> In-Reply-To: <20210302175524.1290840-1-berrange@redhat.com> References: <20210302175524.1290840-1-berrange@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=berrange@redhat.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.133.124; envelope-from=berrange@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -27 X-Spam_score: -2.8 X-Spam_bar: -- X-Spam_report: (-2.8 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_LOW=-0.7, RCVD_IN_MSPIKE_H4=0.001, RCVD_IN_MSPIKE_WL=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Michael Roth , =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= , Markus Armbruster , Gerd Hoffmann Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) Way back in QEMU 4.0, the -audiodev command line option was introduced for configuring audio backends. This CLI option does not use QemuOpts so it is not visible for introspection in 'query-command-line-options', instead using the QAPI Audiodev type. Unfortunately there is also no QMP command that uses the Audiodev type, so it is not introspectable with 'query-qmp-schema' either. This introduces a 'query-audiodev' command that simply reflects back the list of configured -audiodev command line options. This in turn makes Audiodev introspectable via 'query-qmp-schema'. Signed-off-by: Daniel P. Berrang=C3=A9 --- audio/audio.c | 19 +++++++++++++++++++ qapi/audio.json | 13 +++++++++++++ 2 files changed, 32 insertions(+) diff --git a/audio/audio.c b/audio/audio.c index 6734c8af70..40a4bbd7ce 100644 --- a/audio/audio.c +++ b/audio/audio.c @@ -28,8 +28,10 @@ #include "monitor/monitor.h" #include "qemu/timer.h" #include "qapi/error.h" +#include "qapi/clone-visitor.h" #include "qapi/qobject-input-visitor.h" #include "qapi/qapi-visit-audio.h" +#include "qapi/qapi-commands-audio.h" #include "qemu/cutils.h" #include "qemu/module.h" #include "sysemu/replay.h" @@ -2201,3 +2203,20 @@ size_t audio_rate_get_bytes(struct audio_pcm_info *i= nfo, RateCtl *rate, rate->bytes_sent +=3D ret; return ret; } + +AudiodevList *qmp_query_audiodevs(Error **errp) +{ + AudiodevList *ret =3D NULL, *prev =3D NULL, *curr; + AudiodevListEntry *e; + QSIMPLEQ_FOREACH(e, &audiodevs, next) { + curr =3D g_new0(AudiodevList, 1); + curr->value =3D QAPI_CLONE(Audiodev, e->dev); + if (prev) { + prev->next =3D curr; + prev =3D curr; + } else { + ret =3D prev =3D curr; + } + } + return ret; +} diff --git a/qapi/audio.json b/qapi/audio.json index 9cba0df8a4..d7b91230d7 100644 --- a/qapi/audio.json +++ b/qapi/audio.json @@ -419,3 +419,16 @@ 'sdl': 'AudiodevSdlOptions', 'spice': 'AudiodevGenericOptions', 'wav': 'AudiodevWavOptions' } } + +## +# @query-audiodevs: +# +# Returns information about audiodev configuration +# +# Returns: array of @Audiodev +# +# Since: 6.0 +# +## +{ 'command': 'query-audiodevs', + 'returns': ['Audiodev'] } --=20 2.29.2 From nobody Sun May 19 11:31:11 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1614707849; cv=none; d=zohomail.com; s=zohoarc; b=InA8MoEJFeTRywlU7TG1zNsnIo0sGujcCfWHKW+NWJW8Y3e3IPpeUYgl48Jdx8MGyc4/eIaFQw+ZzeM5nJ+v7/prppG2bC7a8zFD+l31wDka6DI/PFoVsP7RnmBtEIjDxuihF51TI3LRcjm29YJiVBXktMhoB/aIJjEUpA9GV14= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1614707849; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=h5wgqQ2MKFsH6SKvQh9dI8OWHwiMyOOhm9YG0anuJPw=; b=iU+l9FNS4ssY61NjhyrrkkcGbhq6ewyfyTcmcIKBdsCw2cbjdnqorpTe5uQe96+z5a5w25m7UHwMv/ueywJSN1PyrLmqoSNeSYM6HhMCwI4avIEDdocyrNkacQzwmMNUPN5+Son3t04UXssTdMVTrt3SzgE75KqfIIoSy9IAh9E= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail header.from= (p=none dis=none) header.from= Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1614707849518975.4684850441006; Tue, 2 Mar 2021 09:57:29 -0800 (PST) Received: from localhost ([::1]:51464 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1lH9Gy-0001HT-4z for importer@patchew.org; Tue, 02 Mar 2021 12:57:28 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]:58362) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1lH9FH-00084n-9Z for qemu-devel@nongnu.org; Tue, 02 Mar 2021 12:55:43 -0500 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:42250) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.90_1) (envelope-from ) id 1lH9FE-0007Ig-5q for qemu-devel@nongnu.org; Tue, 02 Mar 2021 12:55:43 -0500 Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-84-UPXuV7-yNWG-Wfaxr_V1mA-1; Tue, 02 Mar 2021 12:55:36 -0500 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 0CBDB107ACC7; Tue, 2 Mar 2021 17:55:35 +0000 (UTC) Received: from localhost.localdomain.com (ovpn-113-132.ams2.redhat.com [10.36.113.132]) by smtp.corp.redhat.com (Postfix) with ESMTP id 52BBE62665; Tue, 2 Mar 2021 17:55:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1614707739; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=h5wgqQ2MKFsH6SKvQh9dI8OWHwiMyOOhm9YG0anuJPw=; b=UNIdYjvS5UFbLwk5XSNhRhaFEBlRaNqDNAMbjkIAnnWvD+OMZMsj1FlPyDfpWjODJHmqbd HAyRJVTigSU98J12ufMYaGn9heBGJ+HTy4wcbov2rdf3yz65WbdXolJwSw98jWPRwWpSNG ZnsRWE70vEE4QT/JYdFSoFYp9MBtidE= X-MC-Unique: UPXuV7-yNWG-Wfaxr_V1mA-1 From: =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= To: qemu-devel@nongnu.org Subject: [PATCH 2/3] qapi, audio: respect build time conditions in audio schema Date: Tue, 2 Mar 2021 17:55:23 +0000 Message-Id: <20210302175524.1290840-3-berrange@redhat.com> In-Reply-To: <20210302175524.1290840-1-berrange@redhat.com> References: <20210302175524.1290840-1-berrange@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=berrange@redhat.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=170.10.133.124; envelope-from=berrange@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -27 X-Spam_score: -2.8 X-Spam_bar: -- X-Spam_report: (-2.8 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_LOW=-0.7, RCVD_IN_MSPIKE_H4=0.001, RCVD_IN_MSPIKE_WL=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Michael Roth , =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= , Markus Armbruster , Gerd Hoffmann Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) Currently the -audiodev accepts any audiodev type regardless of what is built in to QEMU. An error only occurs later at runtime when a sound device tries to use the audio backend. With this change QEMU will immediately reject -audiodev args that are not compiled into the binary. The QMP schema will also be introspectable to identify what is compiled in. Signed-off-by: Daniel P. Berrang=C3=A9 Acked-by: Markus Armbruster Reviewed-by: Eric Blake --- audio/audio.c | 16 +++++++++++++++ audio/audio_legacy.c | 41 ++++++++++++++++++++++++++++++++++++++- audio/audio_template.h | 16 +++++++++++++++ qapi/audio.json | 44 ++++++++++++++++++++++++++++++++---------- 4 files changed, 106 insertions(+), 11 deletions(-) diff --git a/audio/audio.c b/audio/audio.c index 40a4bbd7ce..53434fc674 100644 --- a/audio/audio.c +++ b/audio/audio.c @@ -1989,14 +1989,30 @@ void audio_create_pdos(Audiodev *dev) break =20 CASE(NONE, none, ); +#ifdef CONFIG_AUDIO_ALSA CASE(ALSA, alsa, Alsa); +#endif +#ifdef CONFIG_AUDIO_COREAUDIO CASE(COREAUDIO, coreaudio, Coreaudio); +#endif +#ifdef CONFIG_AUDIO_DSOUND CASE(DSOUND, dsound, ); +#endif +#ifdef CONFIG_AUDIO_JACK CASE(JACK, jack, Jack); +#endif +#ifdef CONFIG_AUDIO_OSS CASE(OSS, oss, Oss); +#endif +#ifdef CONFIG_AUDIO_PA CASE(PA, pa, Pa); +#endif +#ifdef CONFIG_AUDIO_SDL CASE(SDL, sdl, Sdl); +#endif +#ifdef CONFIG_SPICE CASE(SPICE, spice, ); +#endif CASE(WAV, wav, ); =20 case AUDIODEV_DRIVER__MAX: diff --git a/audio/audio_legacy.c b/audio/audio_legacy.c index 0fe827b057..bb2268f2b2 100644 --- a/audio/audio_legacy.c +++ b/audio/audio_legacy.c @@ -93,6 +93,7 @@ static void get_fmt(const char *env, AudioFormat *dst, bo= ol *has_dst) } =20 =20 +#if defined(CONFIG_AUDIO_ALSA) || defined(CONFIG_AUDIO_DSOUND) static void get_millis_to_usecs(const char *env, uint32_t *dst, bool *has_= dst) { const char *val =3D getenv(env); @@ -101,15 +102,20 @@ static void get_millis_to_usecs(const char *env, uint= 32_t *dst, bool *has_dst) *has_dst =3D true; } } +#endif =20 +#if defined(CONFIG_AUDIO_ALSA) || defined(CONFIG_AUDIO_COREAUDIO) || \ + defined(CONFIG_AUDIO_PA) || defined(CONFIG_AUDIO_SDL) || \ + defined(CONFIG_AUDIO_DSOUND) || defined(CONFIG_AUDIO_OSS) static uint32_t frames_to_usecs(uint32_t frames, AudiodevPerDirectionOptions *pdo) { uint32_t freq =3D pdo->has_frequency ? pdo->frequency : 44100; return (frames * 1000000 + freq / 2) / freq; } +#endif =20 - +#ifdef CONFIG_AUDIO_COREAUDIO static void get_frames_to_usecs(const char *env, uint32_t *dst, bool *has_= dst, AudiodevPerDirectionOptions *pdo) { @@ -119,14 +125,19 @@ static void get_frames_to_usecs(const char *env, uint= 32_t *dst, bool *has_dst, *has_dst =3D true; } } +#endif =20 +#if defined(CONFIG_AUDIO_PA) || defined(CONFIG_AUDIO_SDL) || \ + defined(CONFIG_AUDIO_DSOUND) || defined(CONFIG_AUDIO_OSS) static uint32_t samples_to_usecs(uint32_t samples, AudiodevPerDirectionOptions *pdo) { uint32_t channels =3D pdo->has_channels ? pdo->channels : 2; return frames_to_usecs(samples / channels, pdo); } +#endif =20 +#if defined(CONFIG_AUDIO_PA) || defined(CONFIG_AUDIO_SDL) static void get_samples_to_usecs(const char *env, uint32_t *dst, bool *has= _dst, AudiodevPerDirectionOptions *pdo) { @@ -136,7 +147,9 @@ static void get_samples_to_usecs(const char *env, uint3= 2_t *dst, bool *has_dst, *has_dst =3D true; } } +#endif =20 +#if defined(CONFIG_AUDIO_DSOUND) || defined(CONFIG_AUDIO_OSS) static uint32_t bytes_to_usecs(uint32_t bytes, AudiodevPerDirectionOptions= *pdo) { AudioFormat fmt =3D pdo->has_format ? pdo->format : AUDIO_FORMAT_S16; @@ -153,8 +166,11 @@ static void get_bytes_to_usecs(const char *env, uint32= _t *dst, bool *has_dst, *has_dst =3D true; } } +#endif =20 /* backend specific functions */ + +#ifdef CONFIG_AUDIO_ALSA /* ALSA */ static void handle_alsa_per_direction( AudiodevAlsaPerDirectionOptions *apdo, const char *prefix) @@ -200,7 +216,9 @@ static void handle_alsa(Audiodev *dev) get_millis_to_usecs("QEMU_ALSA_THRESHOLD", &aopt->threshold, &aopt->has_threshold); } +#endif =20 +#ifdef CONFIG_AUDIO_COREAUDIO /* coreaudio */ static void handle_coreaudio(Audiodev *dev) { @@ -213,7 +231,9 @@ static void handle_coreaudio(Audiodev *dev) &dev->u.coreaudio.out->buffer_count, &dev->u.coreaudio.out->has_buffer_count); } +#endif =20 +#ifdef CONFIG_AUDIO_DSOUND /* dsound */ static void handle_dsound(Audiodev *dev) { @@ -228,7 +248,9 @@ static void handle_dsound(Audiodev *dev) &dev->u.dsound.in->has_buffer_length, dev->u.dsound.in); } +#endif =20 +#ifdef CONFIG_AUDIO_OSS /* OSS */ static void handle_oss_per_direction( AudiodevOssPerDirectionOptions *opdo, const char *try_poll_env, @@ -256,7 +278,9 @@ static void handle_oss(Audiodev *dev) get_bool("QEMU_OSS_EXCLUSIVE", &oopt->exclusive, &oopt->has_exclusive); get_int("QEMU_OSS_POLICY", &oopt->dsp_policy, &oopt->has_dsp_policy); } +#endif =20 +#ifdef CONFIG_AUDIO_PA /* pulseaudio */ static void handle_pa_per_direction( AudiodevPaPerDirectionOptions *ppdo, const char *env) @@ -280,7 +304,9 @@ static void handle_pa(Audiodev *dev) =20 get_str("QEMU_PA_SERVER", &dev->u.pa.server, &dev->u.pa.has_server); } +#endif =20 +#ifdef CONFIG_AUDIO_SDL /* SDL */ static void handle_sdl(Audiodev *dev) { @@ -289,6 +315,7 @@ static void handle_sdl(Audiodev *dev) &dev->u.sdl.out->has_buffer_length, qapi_AudiodevSdlPerDirectionOptions_base(dev->u.sdl.out)); } +#endif =20 /* wav */ static void handle_wav(Audiodev *dev) @@ -348,29 +375,41 @@ static AudiodevListEntry *legacy_opt(const char *drvn= ame) } =20 switch (e->dev->driver) { +#ifdef CONFIG_AUDIO_ALSA case AUDIODEV_DRIVER_ALSA: handle_alsa(e->dev); break; +#endif =20 +#ifdef CONFIG_AUDIO_COREAUDIO case AUDIODEV_DRIVER_COREAUDIO: handle_coreaudio(e->dev); break; +#endif =20 +#ifdef CONFIG_AUDIO_DSOUND case AUDIODEV_DRIVER_DSOUND: handle_dsound(e->dev); break; +#endif =20 +#ifdef CONFIG_AUDIO_OSS case AUDIODEV_DRIVER_OSS: handle_oss(e->dev); break; +#endif =20 +#ifdef CONFIG_AUDIO_PA case AUDIODEV_DRIVER_PA: handle_pa(e->dev); break; +#endif =20 +#ifdef CONFIG_AUDIO_SDL case AUDIODEV_DRIVER_SDL: handle_sdl(e->dev); break; +#endif =20 case AUDIODEV_DRIVER_WAV: handle_wav(e->dev); diff --git a/audio/audio_template.h b/audio/audio_template.h index c6714946aa..0847b643be 100644 --- a/audio/audio_template.h +++ b/audio/audio_template.h @@ -322,23 +322,39 @@ AudiodevPerDirectionOptions *glue(audio_get_pdo_, TYP= E)(Audiodev *dev) switch (dev->driver) { case AUDIODEV_DRIVER_NONE: return dev->u.none.TYPE; +#ifdef CONFIG_AUDIO_ALSA case AUDIODEV_DRIVER_ALSA: return qapi_AudiodevAlsaPerDirectionOptions_base(dev->u.alsa.TYPE); +#endif +#ifdef CONFIG_AUDIO_COREAUDIO case AUDIODEV_DRIVER_COREAUDIO: return qapi_AudiodevCoreaudioPerDirectionOptions_base( dev->u.coreaudio.TYPE); +#endif +#ifdef CONFIG_AUDIO_DSOUND case AUDIODEV_DRIVER_DSOUND: return dev->u.dsound.TYPE; +#endif +#ifdef CONFIG_AUDIO_JACK case AUDIODEV_DRIVER_JACK: return qapi_AudiodevJackPerDirectionOptions_base(dev->u.jack.TYPE); +#endif +#ifdef CONFIG_AUDIO_OSS case AUDIODEV_DRIVER_OSS: return qapi_AudiodevOssPerDirectionOptions_base(dev->u.oss.TYPE); +#endif +#ifdef CONFIG_AUDIO_PA case AUDIODEV_DRIVER_PA: return qapi_AudiodevPaPerDirectionOptions_base(dev->u.pa.TYPE); +#endif +#ifdef CONFIG_AUDIO_SDL case AUDIODEV_DRIVER_SDL: return qapi_AudiodevSdlPerDirectionOptions_base(dev->u.sdl.TYPE); +#endif +#ifdef CONFIG_SPICE case AUDIODEV_DRIVER_SPICE: return dev->u.spice.TYPE; +#endif case AUDIODEV_DRIVER_WAV: return dev->u.wav.TYPE; =20 diff --git a/qapi/audio.json b/qapi/audio.json index d7b91230d7..9af1b8140c 100644 --- a/qapi/audio.json +++ b/qapi/audio.json @@ -386,8 +386,24 @@ # Since: 4.0 ## { 'enum': 'AudiodevDriver', - 'data': [ 'none', 'alsa', 'coreaudio', 'dsound', 'jack', 'oss', 'pa', - 'sdl', 'spice', 'wav' ] } + 'data': [ 'none', + { 'name': 'alsa', + 'if': 'defined(CONFIG_AUDIO_ALSA)' }, + { 'name': 'coreaudio', + 'if': 'defined(CONFIG_AUDIO_COREAUDIO)' }, + { 'name': 'dsound', + 'if': 'defined(CONFIG_AUDIO_DSOUND)' }, + { 'name': 'jack', + 'if': 'defined(CONFIG_AUDIO_JACK)' }, + { 'name': 'oss', + 'if': 'defined(CONFIG_AUDIO_OSS)' }, + { 'name': 'pa', + 'if': 'defined(CONFIG_AUDIO_PA)' }, + { 'name': 'sdl', + 'if': 'defined(CONFIG_AUDIO_SDL)' }, + { 'name': 'spice', + 'if': 'defined(CONFIG_SPICE)' }, + 'wav' ] } =20 ## # @Audiodev: @@ -410,14 +426,22 @@ 'discriminator': 'driver', 'data': { 'none': 'AudiodevGenericOptions', - 'alsa': 'AudiodevAlsaOptions', - 'coreaudio': 'AudiodevCoreaudioOptions', - 'dsound': 'AudiodevDsoundOptions', - 'jack': 'AudiodevJackOptions', - 'oss': 'AudiodevOssOptions', - 'pa': 'AudiodevPaOptions', - 'sdl': 'AudiodevSdlOptions', - 'spice': 'AudiodevGenericOptions', + 'alsa': { 'type': 'AudiodevAlsaOptions', + 'if': 'defined(CONFIG_AUDIO_ALSA)' }, + 'coreaudio': { 'type': 'AudiodevCoreaudioOptions', + 'if': 'defined(CONFIG_AUDIO_COREAUDIO)' }, + 'dsound': { 'type': 'AudiodevDsoundOptions', + 'if': 'defined(CONFIG_AUDIO_DSOUND)' }, + 'jack': { 'type': 'AudiodevJackOptions', + 'if': 'defined(CONFIG_AUDIO_JACK)' }, + 'oss': { 'type': 'AudiodevOssOptions', + 'if': 'defined(CONFIG_AUDIO_OSS)' }, + 'pa': { 'type': 'AudiodevPaOptions', + 'if': 'defined(CONFIG_AUDIO_PA)' }, + 'sdl': { 'type': 'AudiodevSdlOptions', + 'if': 'defined(CONFIG_AUDIO_SDL)' }, + 'spice': { 'type': 'AudiodevGenericOptions', + 'if': 'defined(CONFIG_SPICE)' }, 'wav': 'AudiodevWavOptions' } } =20 ## --=20 2.29.2 From nobody Sun May 19 11:31:11 2024 Delivered-To: importer@patchew.org Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail(p=none dis=none) header.from=redhat.com ARC-Seal: i=1; a=rsa-sha256; t=1614707849; cv=none; d=zohomail.com; s=zohoarc; b=aBf8dkBTYkQUaHhU6qcEQDsWFgjUICWXxqe/jrivOboZ10BdWnNDL5AD49Zp5Wn1v/+1IFjDycWlbSUtWvG9xd+4LdVOTHobhvZF9XDod2+SFlJl2ao786KgFS9opTNTyYAbNi0zHzvhqw6rbR/lvVQ/k1aphE22cny6J4yaGuo= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1614707849; h=Content-Type:Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Post:List-Id:List-Archive:List-Help:List-Unsubscribe:MIME-Version:Message-ID:References:Sender:Subject:To; bh=mkyA6PfUKQ6UmH8hWO5zQVnWleHEh3yaKVrpMsl/pEE=; b=kxOAmByR0IC/85q9wVapg3wCvZL6YtD6tqc+xGaN4LqlY0GpsUTkiE3btHe3c+khoteAHA9v8LY+/UCg4PsoWHZmUd8HzLK1U1v4Uyh8HEUdpxjv4NWLGIyWlQlKvMQaPyeCRncblmuFXZdiJ1cbguCG8Pzh4cTsCCnKYQd7bMs= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) smtp.mailfrom=qemu-devel-bounces+importer=patchew.org@nongnu.org; dmarc=fail header.from= (p=none dis=none) header.from= Return-Path: Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) by mx.zohomail.com with SMTPS id 1614707849551260.3432507390112; Tue, 2 Mar 2021 09:57:29 -0800 (PST) Received: from localhost ([::1]:51542 helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1lH9Gy-0001JN-7o for importer@patchew.org; Tue, 02 Mar 2021 12:57:28 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]:58364) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1lH9FH-00084w-HZ for qemu-devel@nongnu.org; Tue, 02 Mar 2021 12:55:44 -0500 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:32509) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_CBC_SHA1:256) (Exim 4.90_1) (envelope-from ) id 1lH9FE-0007Ir-Vl for qemu-devel@nongnu.org; Tue, 02 Mar 2021 12:55:43 -0500 Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-27-RUfV0iDgOkm5xpSrsgrtsw-1; Tue, 02 Mar 2021 12:55:38 -0500 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 3D46B804036; Tue, 2 Mar 2021 17:55:37 +0000 (UTC) Received: from localhost.localdomain.com (ovpn-113-132.ams2.redhat.com [10.36.113.132]) by smtp.corp.redhat.com (Postfix) with ESMTP id 70B0961F20; Tue, 2 Mar 2021 17:55:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1614707740; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=mkyA6PfUKQ6UmH8hWO5zQVnWleHEh3yaKVrpMsl/pEE=; b=HA77FEXDXD/0d064AeT+8LETk34GxVKXoqE9IMC9wNnGoUGDmikuE9QdFV9mSKUS8YuECp VCCbE7x6DGvFrDYcVHWJOHOvPs49cESA09g9vZ3oPb8pNqiJiQv8YWeVB8iNP4cE8trRny IVXyRRy188Y0DhqzaBuEPcgsvrkYK7g= X-MC-Unique: RUfV0iDgOkm5xpSrsgrtsw-1 From: =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= To: qemu-devel@nongnu.org Subject: [PATCH 3/3] qapi: provide a friendly string representation of QAPI classes Date: Tue, 2 Mar 2021 17:55:24 +0000 Message-Id: <20210302175524.1290840-4-berrange@redhat.com> In-Reply-To: <20210302175524.1290840-1-berrange@redhat.com> References: <20210302175524.1290840-1-berrange@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 Authentication-Results: relay.mimecast.com; auth=pass smtp.auth=CUSA124A263 smtp.mailfrom=berrange@redhat.com X-Mimecast-Spam-Score: 0 X-Mimecast-Originator: redhat.com Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Received-SPF: pass (zohomail.com: domain of gnu.org designates 209.51.188.17 as permitted sender) client-ip=209.51.188.17; envelope-from=qemu-devel-bounces+importer=patchew.org@nongnu.org; helo=lists.gnu.org; Received-SPF: pass client-ip=216.205.24.124; envelope-from=berrange@redhat.com; helo=us-smtp-delivery-124.mimecast.com X-Spam_score_int: -27 X-Spam_score: -2.8 X-Spam_bar: -- X-Spam_report: (-2.8 / 5.0 requ) BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_LOW=-0.7, RCVD_IN_MSPIKE_H3=0.001, RCVD_IN_MSPIKE_WL=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Michael Roth , =?UTF-8?q?Daniel=20P=2E=20Berrang=C3=A9?= , Markus Armbruster , Gerd Hoffmann Errors-To: qemu-devel-bounces+importer=patchew.org@nongnu.org Sender: "Qemu-devel" X-ZohoMail-DKIM: fail (Header signature does not verify) If printing a QAPI schema object for debugging we get the classname and a hex value for the instance. With this change we instead get the classname and the human friendly name of the QAPI type instance. Signed-off-by: Daniel P. Berrang=C3=A9 Reviewed-by: Eric Blake Reviewed-by: Philippe Mathieu-Daud=C3=A9 --- scripts/qapi/schema.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/scripts/qapi/schema.py b/scripts/qapi/schema.py index ff16578f6d..800bc5994b 100644 --- a/scripts/qapi/schema.py +++ b/scripts/qapi/schema.py @@ -46,6 +46,9 @@ def __init__(self, name: str, info, doc, ifcond=3DNone, f= eatures=3DNone): self.features =3D features or [] self._checked =3D False =20 + def __repr__(self): + return "%s<%s>" % (type(self).__name__, self.name) + def c_name(self): return c_name(self.name) =20 --=20 2.29.2