[gstreamer-bugs] [Bug 619204] New: Framestepping backwards sometimes doesn't work on MPEG-2 files.

GStreamer (bugzilla.gnome.org) bugzilla at gnome.org
Thu May 20 08:21:08 PDT 2010


https://bugzilla.gnome.org/show_bug.cgi?id=619204
  GStreamer | gst-plugins-bad | 0.10.29

           Summary: Framestepping backwards sometimes doesn't work on
                    MPEG-2 files.
    Classification: Desktop
           Product: GStreamer
           Version: 0.10.29
        OS/Version: Windows
            Status: UNCONFIRMED
          Severity: normal
          Priority: Normal
         Component: gst-plugins-bad
        AssignedTo: gstreamer-bugs at lists.sourceforge.net
        ReportedBy: wl2776 at gmail.com
         QAContact: gstreamer-bugs at lists.sourceforge.net
      GNOME target: ---
     GNOME version: ---


The playbin2 doesn't react on the new_step events when paused. 
Current playing position, reported by _query_position doesn't change. The
displayed picture doesn't change also. 

Framestepping forward is OK. 

0. GStreamer is initialized with the keys --gst-debug=player:5,mpegpsdemux:3 
where player is my private debug category. 

1. My application creates the playbin2 instance to play the file. 
It successfully opens and plays. 

2. I pause the playbin2. 

3. I position a playbin2 somewhere in the movie by clicking on a movie progress
bar on my form. 
This issues the call 

r=gst_element_seek_simple(GST_ELEMENT(m_player), 
        GST_FORMAT_TIME, 
        (GstSeekFlags)(GST_SEEK_FLAG_FLUSH|GST_SEEK_FLAG_KEY_UNIT), 
        pos*GST_MSECOND); 

where pos is the seek position. 

GST_DEBUG rigth after this shows that r=1 (seek is successful), I also observe
the changing picture. 

Debug shows the following. 

0:00:11.316272000  3952   003D9118 INFO             mpegpsdemux
gstmpegdemux.c:1060:gst_flups_demux_do_seek:<mpegpsdemux0> sink segment
configured 0409D880, trying to go at SCR: 5535000
0:00:11.326286000  3952   003D9118 INFO             mpegpsdemux
gstmpegdemux.c:1082:gst_flups_demux_do_seek:<mpegpsdemux0> doing seek at offset
42065920 SCR: 5534990 0:01:01.499888888
0:00:11.346315000  3952   003D9118 DEBUG                 player
gst_player.cpp:911:gst_player::set_position: direction=1, seek to 61500 msec,
r=1
0:00:11.356329000  3952   040A06C0 INFO             mpegpsdemux
gstmpegdemux.c:533:gst_flups_demux_send_data:<mpegpsdemux0> sending new
segment: rate 1 applied_rate 1 start: 0:01:01.500011111, stop:
99:99:99.999999999, time: 0:01:01.500000000 to pad 0401E668
0:00:11.356329000  3952   040A06C0 INFO             mpegpsdemux
gstmpegdemux.c:533:gst_flups_demux_send_data:<mpegpsdemux0> sending new
segment: rate 1 applied_rate 1 start: 0:01:01.500011111, stop:
99:99:99.999999999, time: 0:01:01.500000000 to pad 0401EA50
0:00:11.486517000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:330:gst_player::bus_watch: message async-done(2097152) from
playbin0
0:00:11.486517000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:334:gst_player::bus_watch: current player position 61500ms
0:00:11.526574000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:341:gst_player::bus_watch: current segment: rate 1.000000 fmt 3
start 61500011111 stop -1 direction 1


4. I press "step left" button on my player's window. 
This issues the call to my step_left() function 

void gst_player::step_left(void)
{GstFormat fmt=GST_FORMAT_TIME;
 gboolean rb;

   if(m_player){
     if(m_current_position>=40*GST_MSECOND){
       if(m_direction>0) {
        m_direction=-1;
        flag_set(FLAG_STEP_LEFT1);
        rb=gst_element_seek(m_player,-1.0,GST_FORMAT_TIME,
                       
(GstSeekFlags)(GST_SEEK_FLAG_FLUSH|GST_SEEK_FLAG_ACCURATE),
                       
GST_SEEK_TYPE_SET,0,GST_SEEK_TYPE_SET,m_current_position);
        GST_DEBUG("seek backwards: %d",rb);
       }else{
        rb=gst_element_send_event (m_player, 
                                 gst_event_new_step (GST_FORMAT_BUFFERS, 1,
1.0, TRUE, FALSE));
        GST_DEBUG("send step event: %d",rb);
       }
     }
   }
}


This function tracks current playback direction, if it doesn't match, it sends
the seek event to turn the player to backwards playback. 
The bus_watch watches for the async-done messages, checks the application's
internal flags and basing on them decides what caused the async-done message
and what to do next. 

Here is the relevant code from my bus-watch. 

case GST_MESSAGE_ASYNC_DONE:{
    GST_DEBUG("message %s(%d) from %s",
       
GST_MESSAGE_TYPE_NAME(msg),GST_MESSAGE_TYPE(msg),GST_MESSAGE_SRC_NAME(msg));
    GstFormat fmt=GST_FORMAT_TIME;

    gst_element_query_position(m_player,&fmt,&m_current_position);
    GST_DEBUG("current player position
%dms",GST_TIME_AS_MSECONDS(m_current_position));

    GstQuery *query=gst_query_new_segment(GST_FORMAT_TIME);
    gst_element_query(GST_ELEMENT(m_player),query);
    gdouble rate;
    gint64 start=-1,stop=-1;
    gst_query_parse_segment(query,&rate,&fmt,&start,&stop);
    GST_DEBUG("current segment: rate %lf fmt %d start %"G_GINT64_FORMAT
                       " stop %"G_GINT64_FORMAT" direction
%d",rate,fmt,start,stop,m_direction);
    gst_query_unref(query);

    if(m_flags & FLAG_GO_END){
      flag_unset(FLAG_GO_END);
     /* ... */
    }else if(m_flags & FLAG_STEP_LEFT1){
      flag_unset(FLAG_STEP_LEFT1);
      GST_DEBUG("flag_unset(FLAG_STEP_LEFT1);");
      rb=gst_element_send_event (m_player,
                  gst_event_new_step (GST_FORMAT_BUFFERS, 1, 1.0, TRUE,
FALSE));
      GST_DEBUG("send step event: %d",rb);
    }
}


Here is the debug output, resulted by several presses of the step_left button 

0:10:32.509504000  3952   003D9118 INFO             mpegpsdemux
gstmpegdemux.c:1060:gst_flups_demux_do_seek:<mpegpsdemux0> sink segment
configured 0409D880, trying to go at SCR: 5535000
0:10:32.519518000  3952   003D9118 INFO             mpegpsdemux
gstmpegdemux.c:1082:gst_flups_demux_do_seek:<mpegpsdemux0> doing seek at offset
42065920 SCR: 5534990 0:01:01.499888888
0:10:32.519518000  3952   003D9118 DEBUG                 player
gst_player.cpp:940:gst_player::step_left: seek backwards: 1
0:10:32.519518000  3952   040A06C0 INFO             mpegpsdemux
gstmpegdemux.c:533:gst_flups_demux_send_data:<mpegpsdemux0> sending new
segment: rate -1 applied_rate 1 start: 0:00:00.000011111, stop:
0:01:01.500011111, time: 0:00:00.000000000 to pad 0401E668
0:10:32.990195000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:330:gst_player::bus_watch: message async-done(2097152) from
playbin0
0:10:32.990195000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:334:gst_player::bus_watch: current player position 61500ms
0:10:32.990195000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:341:gst_player::bus_watch: current segment: rate -1.000000 fmt 3
start 11111 stop 61500011111 direction -1
0:10:32.990195000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:354:gst_player::bus_watch: flag_unset(FLAG_STEP_LEFT1);
0:10:32.990195000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:356:gst_player::bus_watch: send step event: 1
0:10:33.000209000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:330:gst_player::bus_watch: message async-done(2097152) from
playbin0
0:10:33.000209000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:334:gst_player::bus_watch: current player position 61500ms
0:10:33.000209000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:341:gst_player::bus_watch: current segment: rate -1.000000 fmt 3
start 11111 stop 61500011111 direction -1
0:14:59.793840000  3952   003D9118 DEBUG                 player
gst_player.cpp:943:gst_player::step_left: send step event: 1
0:14:59.803854000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:330:gst_player::bus_watch: message async-done(2097152) from
playbin0
0:14:59.803854000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:334:gst_player::bus_watch: current player position 61500ms
0:14:59.803854000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:341:gst_player::bus_watch: current segment: rate -1.000000 fmt 3
start 11111 stop 61500011111 direction -1
0:15:02.467685000  3952   003D9118 DEBUG                 player
gst_player.cpp:943:gst_player::step_left: send step event: 1
0:15:02.467685000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:330:gst_player::bus_watch: message async-done(2097152) from
playbin0
0:15:02.467685000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:334:gst_player::bus_watch: current player position 61500ms
0:15:02.467685000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:341:gst_player::bus_watch: current segment: rate -1.000000 fmt 3
start 11111 stop 61500011111 direction -1
0:15:05.191601000  3952   003D9118 DEBUG                 player
gst_player.cpp:943:gst_player::step_left: send step event: 1
0:15:05.191601000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:330:gst_player::bus_watch: message async-done(2097152) from
playbin0
0:15:05.191601000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:334:gst_player::bus_watch: current player position 61500ms
0:15:05.191601000  3952   0404AEE0 DEBUG                 player
gst_player.cpp:341:gst_player::bus_watch: current segment: rate -1.000000 fmt 3
start 11111 stop 61500011111 direction -1


As can be seen, current position remains at 61500ms, the displayed picture
doesn't change. I repeat, m_player is the playbin2, and is paused.

If I increase the mpegdemux debug level, then it can be seen that it parses the
file after the direction was changed to backwards.

-- 
Configure bugmail: https://bugzilla.gnome.org/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
You are the QA contact for the bug.
You are the assignee for the bug.




More information about the Gstreamer-bugs mailing list