<div dir="ltr"><div><div><div>Hi Miguel.<br><br></div>Sounds really good. Unfortunately I can't volunteer to do the coding for the moment. Sorry for that. Hope somebody else can. One thing to remember to get right, especially on a lower performance platform such as RaspPi, would be for the module to request buffers for video from downstream and use these for the cam to fill these, so we can avoid an extra memcpy(), which is not insignificant for 1080p. Not sure how well that will fit with mmal.<br><br></div><div>For the multipad, raw, encoded, stills and preview, then yes, the encoded easily can be skipped and be replaced by omxh264dec, with no real additional CPU work required, compared with current solution. Only reason to include it should be, that the current module delivers h264, so to maintain compatibility .... but the others, raw(RGB and YUV), stills and preview may (do) have their own use.<br></div><div><br></div>Best regards<br></div>Peter<br><div><div><div><div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jan 28, 2016 at 10:30 PM, Miguel Domingues <span dir="ltr"><<a href="mailto:miguelbrazaodomingues@gmail.com" target="_blank">miguelbrazaodomingues@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi,<div><br></div><div>After looking at: <a href="https://github.com/thaytan/gst-rpicamsrc/blob/master/src/RaspiCapture.c" target="_blank">https://github.com/thaytan/gst-rpicamsrc/blob/master/src/RaspiCapture.c</a> from gst-rpicamsrc and raspivid.c and raspividyuv.c (both from rpi) it looks that it should be possible and relatively easy to adapt the gst-rpicamsrc to provide raw video.</div><div><br></div><div>Getting simultaneously raw and h264 video, should also be possible although more difficult.</div><div>However with the raw video you can always use the omxh264enc to encode it (e.g., gst-launch rpicamsrcraw ! ... ! omxh264enc ! ... ).</div><div>Don't know if it would have a big impact on performance.</div><div><br></div><div>Thanks Peter for the info regarding the encoding/decoding/encoding process.</div><div>Nevertheless, just to resume the topic, it is possible to (at least) encode, decode and encode again simultaneously with the rpi.</div><div><br></div><div>Regards,</div><div>Miguel</div><span class="HOEnZb"><font color="#888888"><div> <br></div></font></span></div><div class="gmail_extra"><span class="HOEnZb"><font color="#888888"><br clear="all"><div><div>Miguel Domingues</div></div></font></span><div><div class="h5">
<br><div class="gmail_quote">On Thu, Jan 28, 2016 at 11:40 AM, Peter Maersk-Moller <span dir="ltr"><<a href="mailto:pmaersk@gmail.com" target="_blank">pmaersk@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div><div><div><div>Hi Miguel.<br><br></div>In raspivid, they use mmal to pass video buffers between camera and encoder.<br><a href="https://github.com/raspberrypi/userland/blob/master/host_applications/linux/apps/raspicam/RaspiVid.c" target="_blank">https://github.com/raspberrypi/userland/blob/master/host_applications/linux/apps/raspicam/RaspiVid.c</a><br><br></div>In this example, they acess YUV components before passing to the encoder. See video_record.c<br><a href="https://github.com/tasanakorn/rpi-mmal-demo" target="_blank">https://github.com/tasanakorn/rpi-mmal-demo</a><br></div><div>I think you can get RGB as well.<br></div><div><br></div>So it should be possible to both get raw video data and H.264 at the same time. Would be cool if rpicamsrc used this to optinally ondemand output multiple stream, raw, encoded, stills and preview.<br><br></div>best regards<span><font color="#888888"><br></font></span></div><span><font color="#888888">Peter Maersk-Moller<br></font></span></div><div><div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jan 28, 2016 at 11:36 AM, Miguel Domingues <span dir="ltr"><<a href="mailto:miguelbrazaodomingues@gmail.com" target="_blank">miguelbrazaodomingues@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">I was unaware that raspivid encoded the video.<div><br></div><div>Regarding the pipeline, I split the HD 1080 video (with a tee), the first goes into a appsink to record the video when I want. The second copy is decoded, rescaled, changes fps and then is used for web streaming (re-encoded into h264) and motion detection (using opencv).</div><div>The motion detection signals the recorder appsink to start and stop recording.</div><div><br></div><div>So in the end, if rpicamsrc/raspivid is encoding the video, then my pipeline encodes, decodes and re-encodes...</div><div>I will also look into raspivid to see if it is possible to get the raw video.</div><div><br></div><div>Thanks for the info.</div><div>Miguel</div></div><div class="gmail_extra"><span><font color="#888888"><br clear="all"><div><div>Miguel Domingues</div></div></font></span><div><div>
<br><div class="gmail_quote">On Thu, Jan 28, 2016 at 10:13 AM, Peter Maersk-Moller <span dir="ltr"><<a href="mailto:pmaersk@gmail.com" target="_blank">pmaersk@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi Tim<br><div class="gmail_extra"><br></div><div class="gmail_extra">See inline.<br><br></div><div class="gmail_extra"><div class="gmail_quote"><span>On Thu, Jan 28, 2016 at 10:55 AM, Tim Müller <span dir="ltr"><<a href="mailto:tim@centricular.com" target="_blank">tim@centricular.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>On Thu, 2016-01-28 at 01:57 +0100, Peter Maersk-Moller wrote:<br>
<br>
> The rpicamsrc is a wrapper around raspivid. The raspivid reads raw<br>
> video from the cam and encodes it for H.264 using the processors<br>
> hardware encoder. So in your pipeline you do two hardware encodings<br>
> and one decoding. Unless Broadcom did something really stupid, it<br>
> should be possible to modify rpicamsrc (using code example from<br>
> raspivid or raspiyuv) to read RGB or YUV (I420 perhaps).<br>
<br>
</span>Are you sure it's possible to get the raw (post-processed) video from<br>
the camera sensors before it gets encoded? I seem to remember that the<br>
imaging pipeline is closed and they don't give you the option of<br>
getting RGB or YUV out, but maybe that's changed.<br></blockquote><div><br></div></span><div>That's why i wrote "Unless Broadcom did something really stupid ...".<br></div><div>Github was down last night so I couldn't check the source of raspivid - and a little bit busy with a customer today.<br><br></div><div>That said, raspiyuv can deliver stills as YUV or RGB. And after all, video is a long row of successive stills so maybe there is a way.<br><br></div><div>best regards<span><font color="#888888"><br></font></span></div><span><font color="#888888"><div>Peter<br></div></font></span><span><div><br></div><div> <br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
 Cheers<br>
<span><font color="#888888">  -Tim<br>
<br>
--<br>
Tim Müller, Centricular Ltd - <a href="http://www.centricular.com" rel="noreferrer" target="_blank">http://www.centricular.com</a><br>
</font></span><div><div><br>
<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="http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
</div></div></blockquote></span></div><br></div></div>
<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="http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
<br></blockquote></div><br></div></div></div>
<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="http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
<br></blockquote></div><br></div>
</div></div><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="http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
<br></blockquote></div><br></div></div></div>
<br>_______________________________________________<br>
gstreamer-devel mailing list<br>
<a href="mailto:gstreamer-devel@lists.freedesktop.org">gstreamer-devel@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
<br></blockquote></div><br></div></div></div></div></div></div>