summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/modules/module-alsa-sink.c10
-rw-r--r--src/modules/module-alsa-source.c8
-rw-r--r--src/modules/module-oss.c18
3 files changed, 21 insertions, 15 deletions
diff --git a/src/modules/module-alsa-sink.c b/src/modules/module-alsa-sink.c
index 2d90afaf..ad6bbb70 100644
--- a/src/modules/module-alsa-sink.c
+++ b/src/modules/module-alsa-sink.c
@@ -342,13 +342,17 @@ int pa__init(pa_core *c, pa_module*m) {
frame_size = pa_frame_size(&ss);
+ /* Fix latency to 100ms */
periods = 8;
- fragsize = 1024;
+ fragsize = pa_bytes_per_second(&ss)/128;
+
+ pa_log("req: %i %i", periods, fragsize);
+
if (pa_modargs_get_value_u32(ma, "fragments", &periods) < 0 || pa_modargs_get_value_u32(ma, "fragment_size", &fragsize) < 0) {
pa_log(__FILE__": failed to parse buffer metrics");
goto fail;
}
- period_size = fragsize;
+ period_size = fragsize/frame_size;
u = pa_xmalloc0(sizeof(struct userdata));
m->userdata = u;
@@ -431,7 +435,7 @@ int pa__init(pa_core *c, pa_module*m) {
}
u->frame_size = frame_size;
- u->fragment_size = period_size;
+ u->fragment_size = period_size * frame_size;
pa_log_info(__FILE__": using %u fragments of size %lu bytes.", periods, (long unsigned)u->fragment_size);
diff --git a/src/modules/module-alsa-source.c b/src/modules/module-alsa-source.c
index a47e0bc6..660bc83b 100644
--- a/src/modules/module-alsa-source.c
+++ b/src/modules/module-alsa-source.c
@@ -333,9 +333,11 @@ int pa__init(pa_core *c, pa_module*m) {
}
frame_size = pa_frame_size(&ss);
-
+
+ /* Fix latency to 100ms */
periods = 12;
- fragsize = frame_size*1024;
+ fragsize = pa_bytes_per_second(&ss)/128;
+
if (pa_modargs_get_value_u32(ma, "fragments", &periods) < 0 || pa_modargs_get_value_u32(ma, "fragment_size", &fragsize) < 0) {
pa_log(__FILE__": failed to parse buffer metrics");
goto fail;
@@ -425,7 +427,7 @@ int pa__init(pa_core *c, pa_module*m) {
u->frame_size = frame_size;
u->fragment_size = period_size * frame_size;
- pa_log(__FILE__": using %u fragments of size %lu bytes.", periods, (long unsigned) u->fragment_size);
+ pa_log_info(__FILE__": using %u fragments of size %lu bytes.", periods, (long unsigned) u->fragment_size);
u->memchunk.memblock = NULL;
u->memchunk.index = u->memchunk.length = 0;
diff --git a/src/modules/module-oss.c b/src/modules/module-oss.c
index 0795ae39..4d811a76 100644
--- a/src/modules/module-oss.c
+++ b/src/modules/module-oss.c
@@ -97,8 +97,6 @@ static const char* const valid_modargs[] = {
#define DEFAULT_SINK_NAME "oss_output"
#define DEFAULT_SOURCE_NAME "oss_input"
#define DEFAULT_DEVICE "/dev/dsp"
-#define DEFAULT_NFRAGS 12
-#define DEFAULT_FRAGSIZE 1024
static void update_usage(struct userdata *u) {
pa_module_set_used(u->module,
@@ -348,19 +346,21 @@ int pa__init(pa_core *c, pa_module*m) {
mode = (playback&&record) ? O_RDWR : (playback ? O_WRONLY : (record ? O_RDONLY : 0));
- nfrags = DEFAULT_NFRAGS;
- frag_size = DEFAULT_FRAGSIZE;
- if (pa_modargs_get_value_s32(ma, "fragments", &nfrags) < 0 || pa_modargs_get_value_s32(ma, "fragment_size", &frag_size) < 0) {
- pa_log(__FILE__": failed to parse fragments arguments");
- goto fail;
- }
-
ss = c->default_sample_spec;
if (pa_modargs_get_sample_spec_and_channel_map(ma, &ss, &map) < 0) {
pa_log(__FILE__": failed to parse sample specification or channel map");
goto fail;
}
+ /* Fix latency to 100ms */
+ nfrags = 12;
+ frag_size = pa_bytes_per_second(&ss)/128;
+
+ if (pa_modargs_get_value_s32(ma, "fragments", &nfrags) < 0 || pa_modargs_get_value_s32(ma, "fragment_size", &frag_size) < 0) {
+ pa_log(__FILE__": failed to parse fragments arguments");
+ goto fail;
+ }
+
if ((fd = pa_oss_open(p = pa_modargs_get_value(ma, "device", DEFAULT_DEVICE), &mode, NULL)) < 0)
goto fail;