mixer: merged methods "init" and "configure"
Both methods are always called together. There is no point in having them separate. This simplifies the code, because the old configure() method could be called more than once, and had to free old allocations.
This commit is contained in:
parent
db2058a265
commit
dc575106c2
@ -36,16 +36,19 @@ struct alsa_mixer {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct mixer_data *
|
static struct mixer_data *
|
||||||
alsa_mixer_init(void)
|
alsa_mixer_init(const struct config_param *param)
|
||||||
{
|
{
|
||||||
struct alsa_mixer *am = g_malloc(sizeof(struct alsa_mixer));
|
struct alsa_mixer *am = g_malloc(sizeof(struct alsa_mixer));
|
||||||
am->device = NULL;
|
|
||||||
am->control = NULL;
|
am->device = config_dup_block_string(param, "mixer_device", NULL);
|
||||||
|
am->control = config_dup_block_string(param, "mixer_control", NULL);
|
||||||
|
|
||||||
am->handle = NULL;
|
am->handle = NULL;
|
||||||
am->elem = NULL;
|
am->elem = NULL;
|
||||||
am->volume_min = 0;
|
am->volume_min = 0;
|
||||||
am->volume_max = 0;
|
am->volume_max = 0;
|
||||||
am->volume_set = -1;
|
am->volume_set = -1;
|
||||||
|
|
||||||
return (struct mixer_data *)am;
|
return (struct mixer_data *)am;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -59,25 +62,6 @@ alsa_mixer_finish(struct mixer_data *data)
|
|||||||
g_free(am);
|
g_free(am);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
alsa_mixer_configure(struct mixer_data *data, const struct config_param *param)
|
|
||||||
{
|
|
||||||
struct alsa_mixer *am = (struct alsa_mixer *)data;
|
|
||||||
const char *value;
|
|
||||||
|
|
||||||
value = config_get_block_string(param, "mixer_device", NULL);
|
|
||||||
if (value != NULL) {
|
|
||||||
g_free(am->device);
|
|
||||||
am->device = g_strdup(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
value = config_get_block_string(param, "mixer_control", NULL);
|
|
||||||
if (value != NULL) {
|
|
||||||
g_free(am->control);
|
|
||||||
am->control = g_strdup(value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
alsa_mixer_close(struct mixer_data *data)
|
alsa_mixer_close(struct mixer_data *data)
|
||||||
{
|
{
|
||||||
@ -235,7 +219,6 @@ alsa_mixer_control(struct mixer_data *data, int cmd, void *arg)
|
|||||||
const struct mixer_plugin alsa_mixer = {
|
const struct mixer_plugin alsa_mixer = {
|
||||||
.init = alsa_mixer_init,
|
.init = alsa_mixer_init,
|
||||||
.finish = alsa_mixer_finish,
|
.finish = alsa_mixer_finish,
|
||||||
.configure = alsa_mixer_configure,
|
|
||||||
.open = alsa_mixer_open,
|
.open = alsa_mixer_open,
|
||||||
.control = alsa_mixer_control,
|
.control = alsa_mixer_control,
|
||||||
.close = alsa_mixer_close
|
.close = alsa_mixer_close
|
||||||
|
@ -43,13 +43,16 @@ struct oss_mixer {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct mixer_data *
|
static struct mixer_data *
|
||||||
oss_mixer_init(void)
|
oss_mixer_init(const struct config_param *param)
|
||||||
{
|
{
|
||||||
struct oss_mixer *om = g_malloc(sizeof(struct oss_mixer));
|
struct oss_mixer *om = g_malloc(sizeof(struct oss_mixer));
|
||||||
om->device = NULL;
|
|
||||||
om->control = NULL;
|
om->device = config_dup_block_string(param, "mixer_device", NULL);
|
||||||
|
om->control = config_dup_block_string(param, "mixer_control", NULL);
|
||||||
|
|
||||||
om->device_fd = -1;
|
om->device_fd = -1;
|
||||||
om->volume_control = SOUND_MIXER_PCM;
|
om->volume_control = SOUND_MIXER_PCM;
|
||||||
|
|
||||||
return (struct mixer_data *)om;
|
return (struct mixer_data *)om;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -63,25 +66,6 @@ oss_mixer_finish(struct mixer_data *data)
|
|||||||
g_free(om);
|
g_free(om);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
oss_mixer_configure(struct mixer_data *data, const struct config_param *param)
|
|
||||||
{
|
|
||||||
struct oss_mixer *om = (struct oss_mixer *) data;
|
|
||||||
const char *value;
|
|
||||||
|
|
||||||
value = config_get_block_string(param, "mixer_device", NULL);
|
|
||||||
if (value != NULL) {
|
|
||||||
g_free(om->device);
|
|
||||||
om->device = g_strdup(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
value = config_get_block_string(param, "mixer_control", NULL);
|
|
||||||
if (value != NULL) {
|
|
||||||
g_free(om->control);
|
|
||||||
om->control = g_strdup(value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
oss_mixer_close(struct mixer_data *data)
|
oss_mixer_close(struct mixer_data *data)
|
||||||
{
|
{
|
||||||
@ -215,7 +199,6 @@ oss_mixer_control(struct mixer_data *data, int cmd, void *arg)
|
|||||||
const struct mixer_plugin oss_mixer = {
|
const struct mixer_plugin oss_mixer = {
|
||||||
.init = oss_mixer_init,
|
.init = oss_mixer_init,
|
||||||
.finish = oss_mixer_finish,
|
.finish = oss_mixer_finish,
|
||||||
.configure = oss_mixer_configure,
|
|
||||||
.open = oss_mixer_open,
|
.open = oss_mixer_open,
|
||||||
.control = oss_mixer_control,
|
.control = oss_mixer_control,
|
||||||
.close = oss_mixer_close
|
.close = oss_mixer_close
|
||||||
|
@ -21,14 +21,6 @@
|
|||||||
|
|
||||||
#include "mixer_api.h"
|
#include "mixer_api.h"
|
||||||
|
|
||||||
void mixer_init(struct mixer *mixer, const struct mixer_plugin *plugin)
|
|
||||||
{
|
|
||||||
assert(plugin != NULL);
|
|
||||||
assert(mixer != NULL);
|
|
||||||
mixer->plugin = plugin;
|
|
||||||
mixer->data = mixer->plugin->init();
|
|
||||||
}
|
|
||||||
|
|
||||||
void mixer_finish(struct mixer *mixer)
|
void mixer_finish(struct mixer *mixer)
|
||||||
{
|
{
|
||||||
assert(mixer != NULL && mixer->plugin != NULL);
|
assert(mixer != NULL && mixer->plugin != NULL);
|
||||||
@ -40,11 +32,13 @@ void mixer_finish(struct mixer *mixer)
|
|||||||
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 = g_new(struct mixer, 1);
|
struct mixer *mixer;
|
||||||
|
|
||||||
mixer_init(mixer, plugin);
|
assert(plugin != NULL);
|
||||||
plugin->configure(mixer->data, param);
|
|
||||||
|
|
||||||
|
mixer = g_new(struct mixer, 1);
|
||||||
|
mixer->plugin = plugin;
|
||||||
|
mixer->data = mixer->plugin->init(param);
|
||||||
return mixer;
|
return mixer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,23 +31,16 @@ extern const struct mixer_plugin oss_mixer;
|
|||||||
struct mixer_data;
|
struct mixer_data;
|
||||||
|
|
||||||
struct mixer_plugin {
|
struct mixer_plugin {
|
||||||
|
/**
|
||||||
/**
|
* Alocates and configures a mixer device.
|
||||||
* Allocate and initialize mixer data
|
|
||||||
*/
|
*/
|
||||||
struct mixer_data *(*init)(void);
|
struct mixer_data *(*init)(const struct config_param *param);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Finish and free mixer data
|
* Finish and free mixer data
|
||||||
*/
|
*/
|
||||||
void (*finish)(struct mixer_data *data);
|
void (*finish)(struct mixer_data *data);
|
||||||
|
|
||||||
/**
|
|
||||||
* Setup and configure mixer
|
|
||||||
*/
|
|
||||||
void (*configure)(struct mixer_data *data,
|
|
||||||
const struct config_param *param);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Open mixer device
|
* Open mixer device
|
||||||
*/
|
*/
|
||||||
@ -69,7 +62,6 @@ struct mixer {
|
|||||||
struct mixer_data *data;
|
struct mixer_data *data;
|
||||||
};
|
};
|
||||||
|
|
||||||
void mixer_init(struct mixer *mixer, const struct mixer_plugin *plugin);
|
|
||||||
void mixer_finish(struct mixer *mixer);
|
void mixer_finish(struct mixer *mixer);
|
||||||
|
|
||||||
struct mixer *
|
struct mixer *
|
||||||
|
Loading…
Reference in New Issue
Block a user