reserve-device: allow building without D-Bus

Lennart Poettering <lennart@poettering.net> wrote:

> On Wed, 15.04.09 16:26, Erich Boleyn (erich@uruk.org) wrote:
>
> > Just noticed the new 0.9.15 release, got it building on Gentoo, and then
> > found that the non-dbus build's ALSA modules appear to be broken:
...
> > Is this something that can stubbed out (relatively) safely?
>
> Hmm, yes. As it seems I broke the build for non-dbus builds. Should be
> easy to fix. Best way is probably to make the reserver wrapper mostly
> a noop if D-Bus is not available.
>
> Please understand that I don't really focus on making every weird
> combination of build deps work. So I won't fix this for you. But I am
> happy to merge good patches!

No problem, I was mainly looking for a hint that to your knowledge there
should be no wierd side-effects from stubbing out the reserve and dbus
functions inside reserve_wrapper.  Thanks for said hint.  ;-)

Attached is a patch to include "reserve_wrapper.[ch]" in the non-dbus
builds, and do said stubbing when HAVE_DBUS is not defined.  It has
passed moderate testing:  built both versions, both pass
"pulseaudio --dump-modules" with no weird messages, and the
"--disable-dbus" build works and produces audio as expected in some
simple tests including RTP.
This commit is contained in:
Erich Boleyn 2009-04-15 23:02:59 -07:00 committed by Lennart Poettering
parent 1c0667de21
commit b03a650160
2 changed files with 25 additions and 9 deletions

View file

@ -1315,7 +1315,7 @@ module_oss_la_LIBADD = $(AM_LIBADD) liboss-util.la libpulsecore-@PA_MAJORMINORMI
# ALSA # ALSA
libalsa_util_la_SOURCES = modules/alsa/alsa-util.c modules/alsa/alsa-util.h modules/alsa/alsa-sink.c modules/alsa/alsa-sink.h modules/alsa/alsa-source.c modules/alsa/alsa-source.h libalsa_util_la_SOURCES = modules/alsa/alsa-util.c modules/alsa/alsa-util.h modules/alsa/alsa-sink.c modules/alsa/alsa-sink.h modules/alsa/alsa-source.c modules/alsa/alsa-source.h modules/reserve-wrap.c modules/reserve-wrap.h
libalsa_util_la_LDFLAGS = -avoid-version libalsa_util_la_LDFLAGS = -avoid-version
libalsa_util_la_LIBADD = $(AM_LIBADD) $(ASOUNDLIB_LIBS) libpulsecore-@PA_MAJORMINORMICRO@.la libpulsecommon-@PA_MAJORMINORMICRO@.la libpulse.la libalsa_util_la_LIBADD = $(AM_LIBADD) $(ASOUNDLIB_LIBS) libpulsecore-@PA_MAJORMINORMICRO@.la libpulsecommon-@PA_MAJORMINORMICRO@.la libpulse.la
libalsa_util_la_CFLAGS = $(AM_CFLAGS) $(ASOUNDLIB_CFLAGS) libalsa_util_la_CFLAGS = $(AM_CFLAGS) $(ASOUNDLIB_CFLAGS)
@ -1333,7 +1333,7 @@ libalsa_util_la_CFLAGS += $(UDEV_CFLAGS)
endif endif
if HAVE_DBUS if HAVE_DBUS
libalsa_util_la_SOURCES += modules/reserve.h modules/reserve.c modules/reserve-wrap.c modules/reserve-wrap.h libalsa_util_la_SOURCES += modules/reserve.h modules/reserve.c
libalsa_util_la_LIBADD += $(DBUS_LIBS) libalsa_util_la_LIBADD += $(DBUS_LIBS)
libalsa_util_la_CFLAGS += $(DBUS_CFLAGS) libalsa_util_la_CFLAGS += $(DBUS_CFLAGS)
endif endif

View file

@ -31,30 +31,37 @@
#include <pulsecore/core-error.h> #include <pulsecore/core-error.h>
#include <pulsecore/core-util.h> #include <pulsecore/core-util.h>
#include <pulsecore/shared.h> #include <pulsecore/shared.h>
#include <pulsecore/dbus-shared.h>
#ifdef HAVE_DBUS
#include <pulsecore/dbus-shared.h>
#include "reserve.h" #include "reserve.h"
#endif
#include "reserve-wrap.h" #include "reserve-wrap.h"
struct pa_reserve_wrapper { struct pa_reserve_wrapper {
PA_REFCNT_DECLARE; PA_REFCNT_DECLARE;
pa_core *core; pa_core *core;
pa_dbus_connection *connection;
pa_hook hook; pa_hook hook;
struct rd_device *device;
char *shared_name; char *shared_name;
#ifdef HAVE_DBUS
pa_dbus_connection *connection;
struct rd_device *device;
#endif
}; };
static void reserve_wrapper_free(pa_reserve_wrapper *r) { static void reserve_wrapper_free(pa_reserve_wrapper *r) {
pa_assert(r); pa_assert(r);
#ifdef HAVE_DBUS
if (r->device) if (r->device)
rd_release(r->device); rd_release(r->device);
pa_hook_done(&r->hook);
if (r->connection) if (r->connection)
pa_dbus_connection_unref(r->connection); pa_dbus_connection_unref(r->connection);
#endif
pa_hook_done(&r->hook);
if (r->shared_name) { if (r->shared_name) {
pa_assert_se(pa_shared_remove(r->core, r->shared_name) >= 0); pa_assert_se(pa_shared_remove(r->core, r->shared_name) >= 0);
@ -64,6 +71,7 @@ static void reserve_wrapper_free(pa_reserve_wrapper *r) {
pa_xfree(r); pa_xfree(r);
} }
#ifdef HAVE_DBUS
static int request_cb(rd_device *d, int forced) { static int request_cb(rd_device *d, int forced) {
pa_reserve_wrapper *r; pa_reserve_wrapper *r;
int k; int k;
@ -81,14 +89,17 @@ static int request_cb(rd_device *d, int forced) {
return k < 0 ? -1 : 1; return k < 0 ? -1 : 1;
} }
#endif
pa_reserve_wrapper* pa_reserve_wrapper_get(pa_core *c, const char *device_name) { pa_reserve_wrapper* pa_reserve_wrapper_get(pa_core *c, const char *device_name) {
pa_reserve_wrapper *r; pa_reserve_wrapper *r;
DBusError error;
int k; int k;
char *t; char *t;
#ifdef HAVE_DBUS
DBusError error;
dbus_error_init(&error); dbus_error_init(&error);
#endif
pa_assert(c); pa_assert(c);
pa_assert(device_name); pa_assert(device_name);
@ -112,6 +123,7 @@ pa_reserve_wrapper* pa_reserve_wrapper_get(pa_core *c, const char *device_name)
pa_assert_se(pa_shared_set(c, r->shared_name, r) >= 0); pa_assert_se(pa_shared_set(c, r->shared_name, r) >= 0);
#ifdef HAVE_DBUS
if (!(r->connection = pa_dbus_bus_get(c, DBUS_BUS_SESSION, &error)) || dbus_error_is_set(&error)) { if (!(r->connection = pa_dbus_bus_get(c, DBUS_BUS_SESSION, &error)) || dbus_error_is_set(&error)) {
pa_log_warn("Unable to contact D-Bus session bus: %s: %s", error.name, error.message); pa_log_warn("Unable to contact D-Bus session bus: %s: %s", error.name, error.message);
@ -143,13 +155,15 @@ pa_reserve_wrapper* pa_reserve_wrapper_get(pa_core *c, const char *device_name)
rd_set_userdata(r->device, r); rd_set_userdata(r->device, r);
return r; return r;
fail: fail:
dbus_error_free(&error); dbus_error_free(&error);
reserve_wrapper_free(r); reserve_wrapper_free(r);
return NULL; return NULL;
#else
return r;
#endif
} }
void pa_reserve_wrapper_unref(pa_reserve_wrapper *r) { void pa_reserve_wrapper_unref(pa_reserve_wrapper *r) {
@ -173,5 +187,7 @@ void pa_reserve_wrapper_set_application_device_name(pa_reserve_wrapper *r, const
pa_assert(r); pa_assert(r);
pa_assert(PA_REFCNT_VALUE(r) >= 1); pa_assert(PA_REFCNT_VALUE(r) >= 1);
#ifdef HAVE_DBUS
rd_set_application_device_name(r->device, name); rd_set_application_device_name(r->device, name);
#endif
} }