<div dir="auto"><div><br><br><div class="gmail_quote"><div dir="ltr">Le ven. 5 oct. 2018 17 h 57,  <<a href="mailto:Jon.Titzell@l3t.com">Jon.Titzell@l3t.com</a>> a écrit :<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">





<div lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="m_-8195909515192861203WordSection1">
<p class="MsoNormal">Hello,<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">I am working on maintaining a plugin that writes directly to raw buffers and noticed that sometimes raw video buffers have an inconsistent size after decoding. Attempting to characterize the size led me to discover that it hinges on a multitude
 of variables; I have observed variance with resolution, codec, video sink, Gstreamer version, and possibly OS.<u></u><u></u></p>
<p class="MsoNormal">I have tested Gstreamer on Windows (7 and 10) and Linux (Centos 7, Fedora 27, Ubuntu 16, 18, and Arch) with most versions from 1.8.3 to 1.14.1; each of these having minute differences in their results. I have also tested briefly on Windows
 7 with Gstreamer 0.10.36 and could not replicate the issue.<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Here’s a specific example on Windows 10, Gstreamer 1.10.4, coding a single frame of a 1280x720 I420 test signal into H.264, then decoding and displaying the frame:<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">gst-launch-1.0.exe –v videotestsrc num-buffers=1 \<u></u><u></u></p>
<p class="MsoNormal">    ! video/x-raw,width=1280,height=720,format=I420 \<u></u><u></u></p>
<p class="MsoNormal">    ! identity name=raw1 silent=false \<u></u><u></u></p>
<p class="MsoNormal">    ! x264enc \<u></u><u></u></p>
<p class="MsoNormal">    ! avdec_h264 \<u></u><u></u></p>
<p class="MsoNormal">    ! identity name=raw2 silent=false \<u></u><u></u></p>
<p class="MsoNormal">    ! d3dvideosink<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">After running this command, the chain message reveals the buffer size in identity raw1 is as expected ( 1280 * 720 * 1.5 = 1,382,400 bytes ) but the buffer size observed in identity raw2 is completely different at 1,596,672 bytes. Switching
 d3dvideosink to glimagesink or fakevideosink results in raw2’s buffer size becoming 1,629,056 bytes, but using fakesink, appsink, or filesink all result in the expected buffer size, 1,382,400 bytes. Changing the codec results in different results yet again,
 such as in this example: on Ubuntu 16, Gstreamer 1.13.0, coding the same test signal into H.265, then decoding and displaying:<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">gst-launch-1.0 –v videotestsrc num-buffers=1 \<u></u><u></u></p>
<p class="MsoNormal">    ! video/x-raw,width=1280,height=720,format=I420 \<u></u><u></u></p>
<p class="MsoNormal">    ! identity name=raw1 silent=false \<u></u><u></u></p>
<p class="MsoNormal">    ! x265enc \<u></u><u></u></p>
<p class="MsoNormal">    ! avdec_h265 \<u></u><u></u></p>
<p class="MsoNormal">    ! identity name=raw2 silent=false \<u></u><u></u></p>
<p class="MsoNormal">    ! xvimagesink<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">This resulted in a 1,624,832 byte buffer. I also tried 1920x1080 and 720x480, which resulted in buffer sizes of 3,444,756 and 640,640 bytes, respectively. I have also tested codecs that are not implemented in libav, such as jpeg, openjpeg,
 png, vp8 and vp9, but only vp9 had a similar ailment.<u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">If anyone can help narrow down the cause of this or how to accommodate for the extra buffer size in my plugin development, it would be greatly appreciated.</p></div></div></blockquote></div></div><div dir="auto"><br></div><div dir="auto">This is normal behaviour. The size of the raw buffer will vary depending on the horizontal and vertical padding. This padding is used to satisfy memory alignment requirements (or coded size, vs display size differences). When you get two different size for the same codec, it simply means one is likely doing a memory copy due to incompatible alignment requirements between two elements.</div><div dir="auto"><br></div><div dir="auto">The GstVideoMeta is used to store this information in the form of 2 arrays, strides and offsets. Stride is the memory size of one line in bytes, and offsets let you know where each planes starts.</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div lang="EN-US" link="#0563C1" vlink="#954F72"><div class="m_-8195909515192861203WordSection1"><p class="MsoNormal"><u></u><u></u></p>
<p class="MsoNormal"><u></u> <u></u></p>
<p class="MsoNormal">Thank you,<u></u><u></u></p>
<p class="MsoNormal">Jon Titzell<u></u><u></u></p>
<p class="MsoNormal"><span style="font-size:10.0pt">Software Engineer<u></u><u></u></span></p>
<p class="MsoNormal"><span style="font-size:10.0pt">L3 Technologies MID<u></u><u></u></span></p>
</div>
------------------------------------------- CONFIDENTIALITY NOTICE: This email and any attachments are for the sole use of the intended recipient and may contain material that is proprietary, confidential, privileged or otherwise legally protected or restricted
 under applicable government laws. Any review, disclosure, distributing or other use without expressed permission of the sender is strictly prohibited. If you are not the intended recipient, please contact the sender and delete all copies without reading, printing,
 or saving..
</div>

_______________________________________________<br>
gstreamer-devel mailing list<br>
<a href="mailto:gstreamer-devel@lists.freedesktop.org" target="_blank" rel="noreferrer">gstreamer-devel@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
</blockquote></div></div></div>