After an evaluation, GNOME has moved from Bugzilla to GitLab. Learn more about GitLab.
No new issues can be reported in GNOME Bugzilla anymore.
To report an issue in a GNOME project, go to GNOME GitLab.
Do not go to GNOME Gitlab for: Bluefish, Doxygen, GnuCash, GStreamer, java-gnome, LDTP, NetworkManager, Tomboy.
Bug 681630 - [0.11] audiodecoder: abort when shutting down during reverse playback: GST_BUFFER_DURATION_IS_VALID (buf)
[0.11] audiodecoder: abort when shutting down during reverse playback: GST_BU...
Status: RESOLVED OBSOLETE
Product: GStreamer
Classification: Platform
Component: gst-plugins-base
0.11.x
Other Linux
: Normal critical
: NONE
Assigned To: GStreamer Maintainers
GStreamer Maintainers
Depends on:
Blocks:
 
 
Reported: 2012-08-10 22:19 UTC by Tim-Philipp Müller
Modified: 2012-10-26 10:14 UTC
See Also:
GNOME target: ---
GNOME version: ---



Description Tim-Philipp Müller 2012-08-10 22:19:56 UTC
Steps to reproduce:

-base/tests/examples/playback$ ./playback-test 0 file:///HE_v2_AAC_44kHz_400kbps_ABR_Work_Ya_Body.m4a 

1) start playback
2) seek to middle of file
3) pause
4) open 'seek options'
5) go to speed/rate box entry and change 1.000 to -1.000 and hit Enter
6) press play (reverse playback starts up)
7) click STOP button

ERROR:gstaudiodecoder.c:1484:gst_audio_decoder_flush_decode: assertion failed: (GST_BUFFER_DURATION_IS_VALID (buf))

Program received signal SIGABRT, Aborted.

Thread 140737049249536 (LWP 8696)

  • #0 *__GI_raise
    at ../nptl/sysdeps/unix/sysv/linux/raise.c line 64
  • #1 *__GI_abort
    at abort.c line 92
  • #2 g_assertion_message
    at /tmp/buildd/glib2.0-2.32.3/./glib/gtestutils.c line 1861
  • #3 g_assertion_message_expr
    at /tmp/buildd/glib2.0-2.32.3/./glib/gtestutils.c line 1872
  • #4 gst_audio_decoder_flush_decode
    at gstaudiodecoder.c line 1484
  • #5 gst_audio_decoder_chain_reverse
    at gstaudiodecoder.c line 1541
  • #6 gst_audio_decoder_drain
    at gstaudiodecoder.c line 1281
  • #7 gst_audio_decoder_flush
    at gstaudiodecoder.c line 1313
  • #8 gst_audio_decoder_chain
    at gstaudiodecoder.c line 1596
  • #9 gst_pad_chain_data_unchecked
    at gstpad.c line 3587
  • #10 gst_pad_push_data
    at gstpad.c line 3800
  • #11 gst_pad_push
    at gstpad.c line 3903
  • #12 gst_base_parse_push_frame
    at gstbaseparse.c line 2073
  • #13 gst_base_parse_chain
    at gstbaseparse.c line 2532
  • #14 gst_pad_chain_data_unchecked
    at gstpad.c line 3587
  • #15 gst_pad_push_data
    at gstpad.c line 3800
  • #16 gst_pad_push
    at gstpad.c line 3903
  • #17 gst_single_queue_push_one
    at gstmultiqueue.c line 1057
  • #18 gst_multi_queue_loop
    at gstmultiqueue.c line 1303
  • #19 gst_task_func
    at gsttask.c line 316
  • #20 g_thread_pool_thread_proxy
    at /tmp/buildd/glib2.0-2.32.3/./glib/gthreadpool.c line 309
  • #21 g_thread_proxy
    at /tmp/buildd/glib2.0-2.32.3/./glib/gthread.c line 801
  • #22 start_thread
    at pthread_create.c line 304
  • #23 clone
    at ../sysdeps/unix/sysv/linux/x86_64/clone.S line 112
  • #24 ??
  • #4 gst_audio_decoder_flush_decode
    at gstaudiodecoder.c line 1484
$1 = {mini_object = {type = 6526224, refcount = 1, lockstate = 0, flags = 0, copy = 0x7ffff78de530 <_gst_buffer_copy>, dispose = 0x7ffff78dcca0 <_gst_buffer_dispose>, free = 0x7ffff78dcaa0 <_gst_buffer_free>, n_qdata = 0, qdata = 0x0}, 
  pool = 0x0, pts = 18446744073709551615, dts = 18446744073709551615, duration = 18446744073709551615, offset = 18446744073709551615, offset_end = 18446744073709551615}


So buffer appears to be valid, but duration is not set.
Comment 1 Mark Nauwelaerts 2012-10-26 09:58:34 UTC
Have not been able to reproduce, albeit with other clip(s).  Is this still the case nowadays ?
Comment 2 Tim-Philipp Müller 2012-10-26 10:14:34 UTC
Nope, don't seem to be able to reproduce this any more, though I'm not sure what would've fixed it.