- From: Peter Thatcher <pthatcher@google.com>
- Date: Mon, 13 Oct 2014 21:50:13 -0700
- To: Jiannan Zheng <jzheng@exchange.microsoft.com>
- Cc: Bernard Aboba <Bernard.Aboba@microsoft.com>, "public-ortc@w3.org" <public-ortc@w3.org>
Sorry, I don't mean to be so difficult about this, but I think the API has already added so much complexity for the case where the remote end point doesn't do RTCP mux, and I really don't want to see more added if we don't really need it. On Mon, Oct 13, 2014 at 8:13 PM, Jiannan Zheng <jzheng@exchange.microsoft.com> wrote: > Hi, > > First let's acknowledge there was a behavior change impacting RTP/RTCP de-mux scenario, in theory such change should get some agreement. > > RTP/RTCP in nature should be associated, otherwise the whole RTP RTT calculation will be all wrong. We either solve it by mux-ing them, or in legacy system, hinting it, like +1. The behavior change is that the browser doesn't know whether it's RTCP or not while it's gathering. It only knows once it goes beyond gathering. But I don't think the browser needs to know during the gathering phase. > Another example would be you are on a port range based diffserv network configuration, having totally unrelated local port allocation could end up with RTP/RTCP falling into different diffserv port range. In a scenario like that, wouldn't we need a more advanced way to tell the browser what kinds of ports to use anyway? The RTP/RTCP distinction wouldn't be enough. Even using RTP_PORT+1 could fall on a port range boundary. > > UDP demotion is the same/similar case of +1, it is about existing PSTN GWs don't support ICE/DTLS. We cannot build a SIP gateway without more extensions and special handling of RTP/RTCP de-mux in ORTC. This is beyond the worry of today's infant ORTC, but we'd better not close the whole door. I think any endpoint that doesn't speak ICE and DTLS is out scope for ORTC 1.1. If some future version of ORTC wants to try and speak non-ICE and non-DTLS to legacy clients with interesting port requirements, then I'm guessing we'd end up with a quite a different API (perhaps a RawUdpTransport instead of IceTransport and DtlsTransport), and we can think about what that would be like at that point in time. For now, I think it's out of scope. > > Thanks, > > -Jiannan > > -----Original Message----- > From: Peter Thatcher [mailto:pthatcher@google.com] > Sent: Monday, October 13, 2014 6:21 PM > To: Jiannan Zheng > Cc: Bernard Aboba; public-ortc@w3.org > Subject: Re: Issue 154: RTCP Port Control > > I think the big question you bring up in your email is: does the IceGatherer (aka IceListener) need to know if the candidates it is gathering are for RTP or RTCP? I think in general, the answer is "no", the IceGatherer doesn't care. > > However, you point out two use cases that could perhaps be solved with IceGatherer knowing. Once is "+1 port for RTCP" and the other is "UDP demotion". I don't see the "+1 port" use case as very compelling since I don't think there are any PSTN gateways (or any legacy clients, for that matter) that speak both ICE and DTLS but require this RTCP port behavior. Do you know of any? > > The second use case you mention is "udp demotion". I'm not familiar with that one. Can you explain what a JS app would need to do be able do, or expect the browser to do, that it can't right now? > > > > > On Sat, Oct 11, 2014 at 9:44 AM, Jiannan Zheng <jzheng@exchange.microsoft.com> wrote: >> With the move of candidate gathering callback to the ICE gatherer class, we accidentally introduced a behavior change in the RTP/RTCP demux. >> >> 6/15 spec says: >> "createAssociatedTransport >> Create an associated RTCIceTransport for RTCP, and implicitly create a newly associated RTCIceListener object as well for RTCP, or reusing an existing RTCP RTCIceListener if one is already associated with the existing RTP RTCIceListener. If called more than once for the same component, throw an InvalidStateError exception. If called when component is "RTCP", throw a SyntaxError exception. >> " >> We do not do the "implicitly create a newly associated RTCIceListener object as well for RTCP, or reusing an existing RTCP RTCIceListener if one is already associated with the existing RTP RTCIceListener" any more with the move. >> >> Assuming we still do offer/answer, with the callback in ice transport and createassociatedtrasnport() call, browsers knows the RTP/RTCP association before generating the initial offer. After the move, because ice transport start needs the remote ice parameters, browser can only know this RTP/RTCP association after the answer. We pretty much mandate the RTP/RTCP local candidate gathering should not be associated. It closes the door to support extensions like UDP demotion,which is needed to call many existing PSTN gateways and some of them needs this +1 behavior. This is not a minor behavior change and we may need more discussions if we indeed want to take this 6/15 "associated listener" behavior out. >> >> The suggestion to move createassociated* together with the onlocalcandidate callback can keep the association behavior the same and satisfy the onlocalcandidate move request. It sounds to me a better solution. >> >> thanks, >> >> -Jiannan >> >> ________________________________________ >> From: Bernard Aboba <Bernard.Aboba@microsoft.com> >> Sent: Wednesday, October 08, 2014 6:10 PM >> To: Peter Thatcher >> Cc: public-ortc@w3.org >> Subject: Re: Issue 154: RTCP Port Control >> >> I think the question is more about where createAssociated belongs. When local candidate gathering was moved from the ICE Transport to the ICE gatherer, should createAssociated have moved with it? That would leave RTCIceTransport.component undetermined until .start is called (at which time it would be inherited from the gatherer). But this seems like it wouldn't be a big problem. >> >> >> >>> On Oct 8, 2014, at 1:17 PM, Peter Thatcher <pthatcher@google.com> wrote: >>> >>> The application can keep around state about which candidates go with >>> RTP and which go with RTCP. It's not that hard for a handler to have >>> access to that state (it can even just be a closure, I think). I >>> don't think the platform needs to do anything special to help it. >>> >>> On Wed, Oct 8, 2014 at 12:59 PM, Bernard Aboba >>> <Bernard.Aboba@microsoft.com> wrote: >>>> A related issue is that currently the RTCIceGatherer does not have a "component" property as the RTCIceTransport does. One awkward implication of this is that the onlocalcandidate Event handler cannot determine the component of the ICE candidate based on properties of the RTCIceGatherer object because there is no RTCIceGatherer.component attribute. >>>> >>>> To get around this, the sample code creates RTCIceTransport objects with names corresponding to the names of the RTCIceGatherer objects. However, prior to calling RTCIceTransport.start (which may only occur quite a bit after creation of the RTCIceTransport and RTCIceGatherer objects) there is no association between an RTCIceTransport and RTCIceGatherer. >>>> >>>> A somewhat more straightforward way to handle this would be to have an RTCIceGatherer.createAssociatedGatherer method, as well as an RTCIceGatherer.component attribute. >>>> If we did this, I don't think we would need an RTCIceTransport.createAssociatedTransport() method. Instead, the RTCIceTransport component could be determined from RTCIceTransport.gatherer.component. >>>> ________________________________________ >>>> From: Bernard Aboba >>>> Sent: Wednesday, October 08, 2014 12:02 PM >>>> To: public-ortc@w3.org >>>> Subject: Issue 154: RTCP Port Control >>>> >>>> While RFC 3605 defines the "a=rtcp:" SDP attribute which allows for control of the RTCP port, there are legacy RTP implementations that assume that RTCP uses a port of RTP + 1. >>>> >>>> Currently there is no way to indicate a relationship between RTP and RTCP RTCIceGatherer objects, or to request that an RTCIceGatherer object created for TCP use the port + 1 of the object created for RTP. >>>> >>
Received on Tuesday, 14 October 2014 04:51:20 UTC