summaryrefslogtreecommitdiff
path: root/src/audio_out/audio_sun_out.c
diff options
context:
space:
mode:
authorJuergen Keil <jkeil@users.sourceforge.net>2002-03-11 19:58:00 +0000
committerJuergen Keil <jkeil@users.sourceforge.net>2002-03-11 19:58:00 +0000
commita1bc7578243bd93e106fc426374363da16652797 (patch)
tree616d2ae6848b68cc9cc0e152184c916e12d14fcf /src/audio_out/audio_sun_out.c
parent619e78fc07c1b8622eb4f8f43d979fab476c24a2 (diff)
downloadxine-lib-a1bc7578243bd93e106fc426374363da16652797.tar.gz
xine-lib-a1bc7578243bd93e106fc426374363da16652797.tar.bz2
Add a "control" method to the audio drivers, to allow pause/resume of the
playback stream and to flush buffered samples from from the audio driver. (Currently implemented in the 'Sun' audio driver, + some untested code in the alsa 0.9 driver). The pause/resume method can be used by the engine to immediatelly stop playing buffered audio samples when the video is paused. Flushing buffered samples is useful when a video is stopped. And it'll be useful for better seeking support, too. CVS patchset: 1556 CVS date: 2002/03/11 19:58:00
Diffstat (limited to 'src/audio_out/audio_sun_out.c')
-rw-r--r--src/audio_out/audio_sun_out.c54
1 files changed, 52 insertions, 2 deletions
diff --git a/src/audio_out/audio_sun_out.c b/src/audio_out/audio_sun_out.c
index f4fb5ec00..9250e2228 100644
--- a/src/audio_out/audio_sun_out.c
+++ b/src/audio_out/audio_sun_out.c
@@ -17,7 +17,7 @@
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*
- * $Id: audio_sun_out.c,v 1.17 2002/02/23 17:22:09 jkeil Exp $
+ * $Id: audio_sun_out.c,v 1.18 2002/03/11 19:58:01 jkeil Exp $
*/
#ifdef HAVE_CONFIG_H
@@ -56,7 +56,7 @@
#define AUDIO_PRECISION_16 16
#endif
-#define AO_SUN_IFACE_VERSION 3
+#define AO_SUN_IFACE_VERSION 4
#define GAP_TOLERANCE 5000
#define GAP_NONRT_TOLERANCE 15000
@@ -598,6 +598,55 @@ static int ao_sun_set_property (ao_driver_t *this_gen, int property, int value)
return ~value;
}
+static int ao_sun_ctrl(ao_driver_t *this_gen, int cmd, ...) {
+ sun_driver_t *this = (sun_driver_t *) this_gen;
+ audio_info_t info;
+
+ switch (cmd) {
+
+ case AO_CTRL_PLAY_PAUSE:
+ AUDIO_INITINFO(&info);
+ info.play.pause = 1;
+ ioctl(this->audio_fd, AUDIO_SETINFO, &info);
+ break;
+
+ case AO_CTRL_PLAY_RESUME:
+ AUDIO_INITINFO(&info);
+ info.play.pause = 0;
+ ioctl(this->audio_fd, AUDIO_SETINFO, &info);
+ break;
+
+ case AO_CTRL_FLUSH_BUFFERS:
+#ifdef __svr4__
+ /* flush buffered STEAMS data first */
+ ioctl(this->audio_fd, I_FLUSH, FLUSHW);
+
+ /*
+ * the flush above discarded an unknown amount of data from the
+ * audio device. To get the "*_delay" computation in sync again,
+ * reset the audio device's sample counter to 0, after waiting
+ * that all samples still active playing on the sound hardware
+ * have finished playing.
+ */
+ AUDIO_INITINFO(&info);
+ info.play.pause = 0;
+ ioctl(this->audio_fd, AUDIO_SETINFO, &info);
+
+ ioctl(this->audio_fd, AUDIO_DRAIN);
+
+ AUDIO_INITINFO(&info);
+ info.play.samples = 0;
+ ioctl(this->audio_fd, AUDIO_SETINFO, &info);
+
+ this->frames_in_buffer = 0;
+ this->last_samplecnt = 0;
+#endif
+ break;
+ }
+
+ return 0;
+}
+
ao_driver_t *init_audio_out_plugin (config_values_t *config) {
sun_driver_t *this;
@@ -683,6 +732,7 @@ ao_driver_t *init_audio_out_plugin (config_values_t *config) {
this->ao_driver.close = ao_sun_close;
this->ao_driver.exit = ao_sun_exit;
this->ao_driver.get_gap_tolerance = ao_sun_get_gap_tolerance;
+ this->ao_driver.control = ao_sun_ctrl;
return &this->ao_driver;
}