Commit 406b0403 authored by Viliam Mateicka's avatar Viliam Mateicka Committed by Max Kellermann

mixer: adding code to optionally disable all hw mixers

parent 2f438e5d
...@@ -19,13 +19,30 @@ ...@@ -19,13 +19,30 @@
#include <stdio.h> #include <stdio.h>
#include <assert.h> #include <assert.h>
#include <glib.h>
#include "mixer_api.h" #include "mixer_api.h"
#undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "mixer"
static bool mixers_enabled = true;
void mixer_disable_all(void)
{
g_debug("mixer api is disabled\n");
mixers_enabled = false;
}
struct mixer * struct mixer *
mixer_new(const struct mixer_plugin *plugin, const struct config_param *param) mixer_new(const struct mixer_plugin *plugin, const struct config_param *param)
{ {
struct mixer *mixer; struct mixer *mixer;
//mixers are disabled (by using software volume)
if (!mixers_enabled) {
return NULL;
}
assert(plugin != NULL); assert(plugin != NULL);
mixer = plugin->init(param); mixer = plugin->init(param);
...@@ -38,7 +55,9 @@ mixer_new(const struct mixer_plugin *plugin, const struct config_param *param) ...@@ -38,7 +55,9 @@ mixer_new(const struct mixer_plugin *plugin, const struct config_param *param)
void void
mixer_free(struct mixer *mixer) mixer_free(struct mixer *mixer)
{ {
assert(mixer != NULL); if (!mixer) {
return;
}
assert(mixer->plugin != NULL); assert(mixer->plugin != NULL);
mixer->plugin->finish(mixer); mixer->plugin->finish(mixer);
...@@ -46,12 +65,18 @@ mixer_free(struct mixer *mixer) ...@@ -46,12 +65,18 @@ mixer_free(struct mixer *mixer)
bool mixer_open(struct mixer *mixer) bool mixer_open(struct mixer *mixer)
{ {
assert(mixer != NULL && mixer->plugin != NULL); if (!mixer) {
return false;
}
assert(mixer->plugin != NULL);
return mixer->plugin->open(mixer); return mixer->plugin->open(mixer);
} }
void mixer_close(struct mixer *mixer) void mixer_close(struct mixer *mixer)
{ {
assert(mixer != NULL && mixer->plugin != NULL); if (!mixer) {
return;
}
assert(mixer->plugin != NULL);
mixer->plugin->close(mixer); mixer->plugin->close(mixer);
} }
...@@ -99,4 +99,6 @@ mixer_set_volume(struct mixer *mixer, unsigned volume) ...@@ -99,4 +99,6 @@ mixer_set_volume(struct mixer *mixer, unsigned volume)
return mixer->plugin->set_volume(mixer, volume); return mixer->plugin->set_volume(mixer, volume);
} }
void mixer_disable_all(void);
#endif #endif
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include "config.h" #include "config.h"
#include "audio.h" #include "audio.h"
#include "output_all.h" #include "output_all.h"
#include "mixer_api.h"
#include <glib.h> #include <glib.h>
...@@ -140,8 +141,10 @@ void volume_init(void) ...@@ -140,8 +141,10 @@ void volume_init(void)
if (param) { if (param) {
if (strcmp(param->value, VOLUME_MIXER_SOFTWARE) == 0) { if (strcmp(param->value, VOLUME_MIXER_SOFTWARE) == 0) {
volume_mixer_type = VOLUME_MIXER_TYPE_SOFTWARE; volume_mixer_type = VOLUME_MIXER_TYPE_SOFTWARE;
mixer_disable_all();
} else if (strcmp(param->value, VOLUME_MIXER_DISABLED) == 0) { } else if (strcmp(param->value, VOLUME_MIXER_DISABLED) == 0) {
volume_mixer_type = VOLUME_MIXER_TYPE_DISABLED; volume_mixer_type = VOLUME_MIXER_TYPE_DISABLED;
mixer_disable_all();
} else if (strcmp(param->value, VOLUME_MIXER_HARDWARE) == 0) { } else if (strcmp(param->value, VOLUME_MIXER_HARDWARE) == 0) {
//nothing to do //nothing to do
} else { } else {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment