diff options
Diffstat (limited to 'src/modules/module-solaris.c')
| -rw-r--r-- | src/modules/module-solaris.c | 20 | 
1 files changed, 18 insertions, 2 deletions
diff --git a/src/modules/module-solaris.c b/src/modules/module-solaris.c index 3f46406a..5cfa97a7 100644 --- a/src/modules/module-solaris.c +++ b/src/modules/module-solaris.c @@ -68,7 +68,9 @@ PA_MODULE_DESCRIPTION("Solaris Sink/Source");  PA_MODULE_VERSION(PACKAGE_VERSION);  PA_MODULE_USAGE(      "sink_name=<name for the sink> " +    "sink_properties=<properties for the sink> "      "source_name=<name for the source> " +    "source_properties=<properties for the source> "      "device=<audio device file name> "      "record=<enable source?> "      "playback=<enable sink?> " @@ -112,7 +114,9 @@ struct userdata {  static const char* const valid_modargs[] = {      "sink_name", +    "sink_properties",      "source_name", +    "source_properties",      "device",      "record",      "playback", @@ -897,10 +901,16 @@ int pa__init(pa_module *m) {          pa_source_new_data_set_channel_map(&source_new_data, &map);          pa_proplist_sets(source_new_data.proplist, PA_PROP_DEVICE_STRING, u->device_name);          pa_proplist_sets(source_new_data.proplist, PA_PROP_DEVICE_API, "solaris"); -        pa_proplist_setf(source_new_data.proplist, PA_PROP_DEVICE_DESCRIPTION, "Solaris PCM source"); +        pa_proplist_sets(source_new_data.proplist, PA_PROP_DEVICE_DESCRIPTION, "Solaris PCM source");          pa_proplist_sets(source_new_data.proplist, PA_PROP_DEVICE_ACCESS_MODE, "serial");          pa_proplist_setf(source_new_data.proplist, PA_PROP_DEVICE_BUFFERING_BUFFER_SIZE, "%lu", (unsigned long) u->buffer_size); +        if (pa_modargs_get_proplist(ma, "source_properties", source_new_data.proplist, PA_UPDATE_REPLACE) < 0) { +            pa_log("Invalid properties"); +            pa_source_new_data_done(&source_new_data); +            goto fail; +        } +          u->source = pa_source_new(m->core, &source_new_data, PA_SOURCE_HARDWARE|PA_SOURCE_LATENCY|PA_SOURCE_HW_VOLUME_CTRL);          pa_source_new_data_done(&source_new_data);          pa_xfree(name_buf); @@ -939,9 +949,15 @@ int pa__init(pa_module *m) {          pa_sink_new_data_set_channel_map(&sink_new_data, &map);          pa_proplist_sets(sink_new_data.proplist, PA_PROP_DEVICE_STRING, u->device_name);          pa_proplist_sets(sink_new_data.proplist, PA_PROP_DEVICE_API, "solaris"); -        pa_proplist_setf(sink_new_data.proplist, PA_PROP_DEVICE_DESCRIPTION, "Solaris PCM sink"); +        pa_proplist_sets(sink_new_data.proplist, PA_PROP_DEVICE_DESCRIPTION, "Solaris PCM sink");          pa_proplist_sets(sink_new_data.proplist, PA_PROP_DEVICE_ACCESS_MODE, "serial"); +        if (pa_modargs_get_proplist(ma, "sink_properties", sink_new_data.proplist, PA_UPDATE_REPLACE) < 0) { +            pa_log("Invalid properties"); +            pa_sink_new_data_done(&sink_new_data); +            goto fail; +        } +          u->sink = pa_sink_new(m->core, &sink_new_data, PA_SINK_HARDWARE|PA_SINK_LATENCY|PA_SINK_HW_VOLUME_CTRL|PA_SINK_HW_MUTE_CTRL);          pa_sink_new_data_done(&sink_new_data);  | 
