summaryrefslogtreecommitdiffstats
path: root/src/module-oss.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2004-06-18 17:12:50 +0000
committerLennart Poettering <lennart@poettering.net>2004-06-18 17:12:50 +0000
commit382e7aefd471a4600010a04e6497d4bfd2fd8663 (patch)
treeadd805dc36fdc446c11a46a0e598e8053ebd8c77 /src/module-oss.c
parent993d1bce74f4cc5be2bfa69a467aae106e2194ab (diff)
some more work
git-svn-id: file:///home/lennart/svn/public/pulseaudio/trunk@23 fefdeb5f-60dc-0310-8127-8f9354f1896f
Diffstat (limited to 'src/module-oss.c')
-rw-r--r--src/module-oss.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/src/module-oss.c b/src/module-oss.c
index 170d864d..fab5c8c5 100644
--- a/src/module-oss.c
+++ b/src/module-oss.c
@@ -25,7 +25,7 @@ struct userdata {
struct memchunk memchunk, silence;
- uint32_t in_fragment_size, out_fragment_size, sample_size, sample_usec;
+ uint32_t in_fragment_size, out_fragment_size, sample_size;
int fd;
};
@@ -99,7 +99,7 @@ static void io_callback(struct iochannel *io, void*userdata) {
static uint32_t sink_get_latency_cb(struct sink *s) {
int arg;
struct userdata *u = s->userdata;
- assert(s && u);
+ assert(s && u && u->sink);
if (ioctl(u->fd, SNDCTL_DSP_GETODELAY, &arg) < 0) {
fprintf(stderr, "module-oss: device doesn't support SNDCTL_DSP_GETODELAY.\n");
@@ -107,7 +107,7 @@ static uint32_t sink_get_latency_cb(struct sink *s) {
return 0;
}
- return arg/u->sample_size*u->sample_usec;
+ return samples_usec(arg, &s->sample_spec);
}
int module_init(struct core *c, struct module*m) {
@@ -204,7 +204,6 @@ int module_init(struct core *c, struct module*m) {
u->memchunk.memblock = NULL;
u->memchunk.length = 0;
u->sample_size = sample_size(&ss);
- u->sample_usec = 1000000/ss.rate;
u->out_fragment_size = out_frag_size;
u->in_fragment_size = in_frag_size;