<div dir="ltr">Hi, thank you so much for the response.<div><br></div><div>What do you mean by "make sure to add downstream caps?"</div><div><br></div><div>Another piece of info I learned: I'm getting a TON of jpeg decode errors, but only with a very specific camera module, that can output up to 1280x720 pixel resolution.  If I use cameras that only run at max 640x480 resolution, they get no decode errors.  Is there something I can do that may be specific to the decode errors in this camera?</div><div><br></div><div>Thank you!</div></div><br><div class="gmail_quote"><div dir="ltr">On Thu, Sep 28, 2017 at 6:30 PM Nicolas Dufresne <<a href="mailto:nicolas@ndufresne.ca">nicolas@ndufresne.ca</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Le jeudi 28 septembre 2017 à 16:45 -0700, ashwath a écrit :<br>
> I'm sorry, just 1 more update.  Adding a leaky queue after the<br>
> capture helped<br>
> get rid of the lost frames problem, but the feed is still quite laggy<br>
> (not<br>
> to mention I'm also losing lots of frames).  I see a lot of gstreamer<br>
> warnings:<br>
><br>
><br>
> 0:00:06.013149788 15050       0x9250a0 WARN            videodecoder<br>
> gstvideodecoder.c:4003:_gst_video_decoder_error:<jpegdec2> error:<br>
> Failed to<br>
> decode JPEG image<br>
> 0:00:06.013162819 15050       0x9250a0 WARN            videodecoder<br>
> gstvideodecoder.c:4005:_gst_video_decoder_error:<jpegdec2> error:<br>
> Decode<br>
> error #62: Unsupported JPEG process: SOF type 0xcf<br>
><br>
><br>
> new pipeline:<br>
><br>
>  gst-launch-1.0 videomixer name=mix sink_0::xpos=0 sink_0::ypos=0<br>
<br>
Replace with videomixer with compositor, and configure latency property<br>
to something large enough (experiment to find the good value for your<br>
use case). The leaky queues won't be required anymore since compositor<br>
has it's own queue mechanism. Make sure so add downstream caps,<br>
compositor will produce a perfect framerate from the detected framerate<br>
in that filter.<br>
<br>
> sink_1::xpos=640 sink_1::ypos=0 sink_2::xpos=0 sink_2::ypos=480<br>
> sink_3::xpos=640 sink_3::ypos=480  ! autovideosink sync=false v4l2src<br>
> device=/dev/video0 do-timestamp=false !<br>
> image/jpeg,height=480,width=640,framerate=30/1 ! queue leaky=2<br>
> max-size-buffers=1 !  jpegparse ! jpegdec ! videoconvert ! mix.sink_0<br>
> v4l2src device=/dev/video1 do-timestamp=false !<br>
> image/jpeg,height=480,width=640,framerate=30/1 ! queue leaky=2<br>
> max-size-buffers=1 !  jpegparse ! jpegdec ! videoconvert ! mix.sink_1<br>
> v4l2src device=/dev/video2 do-timestamp=false !<br>
> image/jpeg,height=480,width=640,framerate=30/1 ! queue leaky=2<br>
> max-size-buffers=1 !  jpegparse ! jpegdec ! videoconvert ! mix.sink_2<br>
> v4l2src device=/dev/video3 do-timestamp=false !<br>
> image/jpeg,height=480,width=640,framerate=30/1 ! queue leaky=2<br>
> max-size-buffers=1 ! jpegparse ! jpegdec !  videoconvert ! mix.sink_3<br>
><br>
><br>
><br>
><br>
> --<br>
> Sent from: <a href="http://gstreamer-devel.966125.n4.nabble.com/" rel="noreferrer" target="_blank">http://gstreamer-devel.966125.n4.nabble.com/</a><br>
> _______________________________________________<br>
> gstreamer-devel mailing list<br>
> <a href="mailto:gstreamer-devel@lists.freedesktop.org" target="_blank">gstreamer-devel@lists.freedesktop.org</a><br>
> <a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
_______________________________________________<br>
gstreamer-devel mailing list<br>
<a href="mailto:gstreamer-devel@lists.freedesktop.org" target="_blank">gstreamer-devel@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
</blockquote></div>