<div dir="ltr"><div dir="ltr"><br></div><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, 1 Oct 2020 at 00:57, Tim Müller <<a href="mailto:tim@centricular.com">tim@centricular.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi Tony,<br>
<br>
> I've got a simpler question about adding pads dynamically.<br>
> Apparently, when adding a pad to an element, you should call<br>
> gst_pad_set_active(pad, TRUE); and examples show this being called<br>
> before adding the pad. But according to the API this calls its<br>
> activate virtual function. I would have thought a pad should only be<br>
> activated when it's at least entering PAUSED state.<br>
<br>
PAUSED is an element state, pads only have active/non-active states<br>
(plus flushing/eos).<br></blockquote><div><br></div><div>Right, but shouldn't pads only be active when their elements are PAUSED or PLAYING? </div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
> And shouldn't you at least wait until the pipeline's push/pull mode<br>
> has been negotiated?<br>
<br>
Pads usually get activated as part of the state change mechanism, when<br>
elements go from READY to PAUSED state.<br></blockquote><div><br></div><div>OK, I'm getting a better understanding of this now, but that seems to be contradicted in parts of the documentation which say things like "<a href="https://gstreamer.freedesktop.org/documentation/plugin-development/advanced/request.html?gi-language=c">need to activate the pad before adding</a>". Wouldn't that cause problems eg if a source tried to start a push task before the pipeline was ready to preroll or play? I guess it only needs to activate it in that example because it adds pads while the pipeline is running, but wouldn't it be better to activate the new pad immediately after adding it instead of before?<br> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
When pads get activated, they get activated in a mode, i.e. pull mode<br>
or push mode.<br>
<br>
Figuring out what mode to activate a pad in is part of the pad<br>
activation / element state change mechanism.<br>
<br>
Pipeline state is usually set topologically going element by element<br>
from sink elements towards source elements. At each point, when an<br>
element goes from READY to PAUSED state it will activate the pads, and<br>
in the rare case that the element supports pull mode (mostly only<br>
parser + demuxers + typefind), it will query the element upstream if it<br>
also supports pull mode when activating its sink pad(s), and if not<br>
fall back to push mode.<br>
<br>
So the negotiation of the push/pull modes is directly linked to the<br>
pipeline state change propagation mechanism.<br></blockquote><div><br></div><div> OK. I think I got confused because the information is a bit fragmented (examples/tutorials, design doc, application manual, plugin writer's guide, API reference).</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
> What if I want to add a pad before either of those conditions?<br>
<br>
Not sure what conditions those are. If you add a pad before the element<br>
goes to PAUSED it will be activated as part of the state change<br>
mechanism later. You can activate it already of course, but it would be<br>
pointless since there's no streaming going on yet.<br></blockquote><div><br></div><div>One of the conditions was push/pull negotiation, but now I realise that didn't make sense because it happens simultaneously to activation. The other condition is the pipeline going from READY to PAUSED. If it's OK to activate a pad before that, then a custom activate or activate_mode handler should check the parent's state and not do anything like start a pushing task if it isn't PAUSED/PLAYING?</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
I'm not entirely sure what you want to achieve exactly to be honest. As<br>
an application you would typically only activate ghost pads perhaps,<br>
but usually it's the elements who activate pads at runtime before<br>
adding them. Pads that the element doesn't know about rarely make sense<br>
after all.<br>
</blockquote></div><div><br></div>I'm writing a plugin for the HTS protocol (tvheadend). I've written a basic source for recordings ("htsprecsrc"), which was quite simple, because it can just copy filesrc's behaviour with open()/read() etc replaced by corresponding network messages. The payload is an MPEG transport stream, which tsdemux can handle. If I add URI handling it works in a playbin (almost?) every time.<div><br></div><div>The trouble is live TV is handled differently, but it would be handy to be able to use the same URI scheme. So I moved the URI handling to a manager element derived from GstBin, which adds an htsprecsrc to itself when it gets a recording URI (I haven't started writing the live TV support yet), with a SOMETIMES ghost pad to expose the htsprecsrc's ALWAYS source.<div><br></div><div>Initially that failed, with an error about the ghost pad not being activated in pull mode, which I've described in another message. I got rid of that error by setting a custom activate callback on the ghost pad's proxy which simply calls activate_mode with pull. Is it OK for the callback to be that simple, or am I skipping other important functionality. This sometimes works, under certain conditions, but usually it just freezes before playback starts. It seems more likely to play successfully if I increase the logging verbosity, which doesn't help getting to the bottom of the problem. I seem to have a deadlock depending on a race condition.</div><div><br></div><div>I've also tried adding a tsdemux element to my bin, which adds ghost pads for each pad-added callback on the tsdemux. This is a preferable solution in the long run I think, but it freezes every time. I get a set of pad-added callbacks as expected, but it stops there. I've also connected to the demuxer's no-more-pads signal, but it never arrives.<br clear="all"><div><br></div>-- <br><div dir="ltr" class="gmail_signature"><div dir="ltr">TH<div><br></div></div></div></div></div></div>