Original commit message from CVS: Fix some clocking issue in OSS. The issue is that if we seek forward (note: specifically forward-only), then we call handle_discont() before re-setting the clock to active. However, gstclock.c tells us that handle_discont only succeeds if allow_discont=TRUE, which is set in... set_active(TRUE). So, we first need to re-activate the clock and *then* call handle_discont(). More importantly, though, we should **NEVER EVER EVER EVER EVER** **NEVER EVER EVER EVER EVER** call clock_wait() after a forward discont without first having called handle_discont(). I don't know who added that code, but it's beyond fundamentally broken. clock_wait() **WAITS** until we're at the new given buftime, so if we do that on a forward-seek buffer, we... yes! we wait the amount of time that we seeked forward. Anyway, Apparently this code has been in here for quite a long time so I don't get how this can ever have worked...
GStreamer (------------------------------------) ! ! sink GstOss src ! ! ! ! (------------------------------------) ! ^ ! 500 ! 501 V ! (------------------------------------) ! GstOssHelper ! (------------------------------------) ! Native OSS APP ! ! ! (------------------------------------) Port 500 protocol ----------------- nothing yet port 501 protocol ----------------- 1 <N> <N-bytes> N bytes of raw audio data following 2 <OSS format>