<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Consolas;
        panose-1:2 11 6 9 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-GB" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal"><span lang="EN-US">Hello everyone,<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US">I am experimenting with the GstMeta API, am failing badly and would like to appeal to anyone that might be able to assist.<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US">I have created my own GstMeta called GstMyTestMeta for now.  This meta has a single guint64 field called testfield.<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US">I am using the following pipeline<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US">                videotestsrc ! x264enc ! rtph264pay ! udpsink<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US">I am adding the meta to the buffers as they leave ‘videotestsrc’ using a pad probe, code is below<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:blue">static</span><span style="font-size:9.5pt;font-family:Consolas;color:black">
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstPadProbeReturn</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> insert_test_meta(</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstPad</span><span style="font-size:9.5pt;font-family:Consolas;color:black">*
</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">pad</span><span style="font-size:9.5pt;font-family:Consolas;color:black">,
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstPadProbeInfo</span><span style="font-size:9.5pt;font-family:Consolas;color:black">*
</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">info</span><span style="font-size:9.5pt;font-family:Consolas;color:black">,
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">gpointer</span><span style="font-size:9.5pt;font-family:Consolas;color:black">
</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">user_data</span><span style="font-size:9.5pt;font-family:Consolas;color:black">)<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">{<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstBuffer</span><span style="font-size:9.5pt;font-family:Consolas;color:black">* buffer =
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">GST_PAD_PROBE_INFO_BUFFER</span><span style="font-size:9.5pt;font-family:Consolas;color:black">(</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">info</span><span style="font-size:9.5pt;font-family:Consolas;color:black">);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstBuffer</span><span style="font-size:9.5pt;font-family:Consolas;color:black">* wbuffer =
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">gst_buffer_make_writable</span><span style="font-size:9.5pt;font-family:Consolas;color:black">(buffer);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:green">/* Making a buffer writable can fail (for example if it</span><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:green">       * cannot be copied and is used more than once)</span><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:green">       */</span><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue">if</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> (wbuffer !=
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">NULL</span><span style="font-size:9.5pt;font-family:Consolas;color:black">)<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">       {<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">guint64</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> testfield = 12345;<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstMyTestMeta</span><span style="font-size:9.5pt;font-family:Consolas;color:black">* meta = gst_buffer_add_my_test_meta(wbuffer, testfield);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">G_print</span><span style="font-size:9.5pt;font-family:Consolas;color:black">(</span><span style="font-size:9.5pt;font-family:Consolas;color:#A31515">"Added meta with timestamp %ld"</span><span style="font-size:9.5pt;font-family:Consolas;color:black">,
 meta->testfield);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">       }<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue">return</span><span style="font-size:9.5pt;font-family:Consolas;color:black">
</span><span style="font-size:9.5pt;font-family:Consolas;color:darkslategray">GST_PAD_PROBE_OK</span><span style="font-size:9.5pt;font-family:Consolas;color:black">;<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:9.5pt;font-family:Consolas;color:black">}<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">I would like to access the meta as it leaves the rtph264pay, again using a pad probe, and add it to the RTP Header as a Header Extension, code is below<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:blue">static</span><span style="font-size:9.5pt;font-family:Consolas;color:black">
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstPadProbeReturn</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> convert_test_meta_to_rtp_header_extension(</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstPad</span><span style="font-size:9.5pt;font-family:Consolas;color:black">*
</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">pad</span><span style="font-size:9.5pt;font-family:Consolas;color:black">,
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstPadProbeInfo</span><span style="font-size:9.5pt;font-family:Consolas;color:black">*
</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">info</span><span style="font-size:9.5pt;font-family:Consolas;color:black">,
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">gpointer</span><span style="font-size:9.5pt;font-family:Consolas;color:black">
</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">user_data</span><span style="font-size:9.5pt;font-family:Consolas;color:black">)<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">{<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstBuffer</span><span style="font-size:9.5pt;font-family:Consolas;color:black">* buffer;<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">       buffer =
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">GST_PAD_PROBE_INFO_BUFFER</span><span style="font-size:9.5pt;font-family:Consolas;color:black">(</span><span style="font-size:9.5pt;font-family:Consolas;color:gray">info</span><span style="font-size:9.5pt;font-family:Consolas;color:black">);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">       buffer =
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">gst_buffer_make_writable</span><span style="font-size:9.5pt;font-family:Consolas;color:black">(buffer);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:green">/* Making a buffer writable can fail (for example if it</span><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:green">       * cannot be copied and is used more than once)</span><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:green">       */</span><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue">if</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> (buffer ==
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">NULL</span><span style="font-size:9.5pt;font-family:Consolas;color:black">)<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue">return</span><span style="font-size:9.5pt;font-family:Consolas;color:black">
</span><span style="font-size:9.5pt;font-family:Consolas;color:darkslategray">GST_PAD_PROBE_OK</span><span style="font-size:9.5pt;font-family:Consolas;color:black">;<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstRTPBuffer</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> rtp_buffer =
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">GST_RTP_BUFFER_INIT</span><span style="font-size:9.5pt;font-family:Consolas;color:black">;<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue">if</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> (gst_rtp_buffer_map(buffer,
</span><span style="font-size:9.5pt;font-family:Consolas;color:#6F008A">GST_MAP_READWRITE</span><span style="font-size:9.5pt;font-family:Consolas;color:black">, &rtp_buffer))<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">       {     
<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">GstMyTestMeta</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> *meta = gst_buffer_get_my_test_meta(buffer);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">gchar</span><span style="font-size:9.5pt;font-family:Consolas;color:black">* data = g_strdup_printf(</span><span style="font-size:9.5pt;font-family:Consolas;color:#A31515">"%ld"</span><span style="font-size:9.5pt;font-family:Consolas;color:black">,
 meta->testfield);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:36.0pt;text-indent:36.0pt;text-autospace:none">
<span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF">gboolean</span><span style="font-size:9.5pt;font-family:Consolas;color:black"> added = gst_rtp_buffer_add_extension_onebyte_header(&rtp_buffer, 1, data,
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue">strlen</span><span style="font-size:9.5pt;font-family:Consolas;color:black">(data));<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">             
<o:p></o:p></span></p>
<p class="MsoNormal" style="margin-left:36.0pt;text-indent:36.0pt;text-autospace:none">
<span style="font-size:9.5pt;font-family:Consolas;color:black">gst_rtp_buffer_unmap(&rtp_buffer);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">              g_free(data);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">       }<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black">      
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue">return</span><span style="font-size:9.5pt;font-family:Consolas;color:black">
</span><span style="font-size:9.5pt;font-family:Consolas;color:darkslategray">GST_PAD_PROBE_OK</span><span style="font-size:9.5pt;font-family:Consolas;color:black">;<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:9.5pt;font-family:Consolas;color:black">}<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">I have stepped through the code and know that the meta is being added to the buffer ok, and confirmed by debug output.  However, my program crashes with a memory access violation exception before the second pad
 probe callback is invoked.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">The relevant part of the debug output is show below.  There is more output before the first entry but no more after the last room.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.361461200 27732   057F9730 DEBUG               GST_META gstmeta.c:88:gst_meta_api_type_register: register API "GstMyTestMetaAPI"<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.361520300 27732   057F9730 DEBUG               GST_META gstmeta.c:198:gst_meta_register: register "GstMyTestMeta" implementing "GstMyTestMetaAPI" of size 8<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.361558300 27732   057F9730 DEBUG             GST_BUFFER gstbuffer.c:2281:gst_buffer_add_meta: alloc metadata 05385E70 (GstMytestMeta) of size 8<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362175400 27732   057F9730 DEBUG               GST_PADS gstpad.c:3601:probe_hook_marshal:<videotestsrc0:src> probe returned OK<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362241300 27732   057F9730 DEBUG         GST_SCHEDULING gstpad.c:4324:gst_pad_chain_data_unchecked:<x264enc0:sink> calling chainfunction &gst_video_encoder_chain with buffer buffer: 05827358, pts 0:00:00.000000000,
 dts 99:99:99.999999999, dur 0:00:00.033333333, size 230400, offset 0, offset_end 1, flags 0x40<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362289400 27732   057F9730 LOG             videoencoder gstvideoencoder.c:1465:gst_video_encoder_chain:<x264enc0> received buffer of size 230400 with PTS 0:00:00.000000000, DTS 99:99:99.999999999, duration
 0:00:00.033333333<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362332000 27732   057F9730 LOG             videoencoder gstvideoencoder.c:1552:gst_video_encoder_chain:<x264enc0> passing frame pfn 0 to subclass<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362372200 27732   057F9730 LOG               GST_BUFFER gstbuffer.c:1798:gst_buffer_map_range: buffer 05827358, idx 0, length 1, flags 0001<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362407300 27732   057F9730 LOG               GST_BUFFER gstbuffer.c:242:_get_merged_memory: buffer 05827358, idx 0, length 1<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362442600 27732   057F9730 LOG               GST_BUFFER gstbuffer.c:1798:gst_buffer_map_range: buffer 05827358, idx 0, length 1, flags 0001<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362480900 27732   057F9730 LOG               GST_BUFFER gstbuffer.c:242:_get_merged_memory: buffer 05827358, idx 0, length 1<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362515500 27732   057F9730 LOG               GST_BUFFER gstbuffer.c:1798:gst_buffer_map_range: buffer 05827358, idx 0, length 1, flags 0001<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362549600 27732   057F9730 LOG               GST_BUFFER gstbuffer.c:242:_get_merged_memory: buffer 05827358, idx 0, length 1<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362587600 27732   057F9730 DEBUG               GST_META gstmeta.c:88:gst_meta_api_type_register: register API "GstVideoCaptionMetaAPI"<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362628600 27732   057F9730 LOG                GST_DEBUG gstinfo.c:1604:gst_debug_apply_entry: category video-anc matches pattern 01049A70 - gets set to level 6<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black">0:00:01.362664600 27732   057F9730 INFO               video-anc video-anc.c:859:gst_video_caption_meta_api_get_type: registering<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">I have searched for examples on how to use the GstMeta API but without any success.  I believe that it is the intention of this API to support this use case but I am unsure.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">I would greatly appreciate any help or assistance that anyone is able to offer.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">Kind Regards<o:p></o:p></span></p>
<p class="MsoNormal"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="color:black">Jon Lovewell<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US"><o:p> </o:p></span></p>
</div>
</body>
</html>