-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Issues with receive-only codecs #22
Comments
Question: Can we use
|
draft-uberti-rtcweb-rfc8829bis Section 4.2.6 says: The setCodecPreferences method sets the codec preferences of a transceiver, which in turn affect the presence and order of codecs of the associated "m=" section on future calls to createOffer and createAnswer. Note that setCodecPreferences does not directly affect which codec the implementation decides to send. It only affects which codecs the implementation indicates that it prefers to receive, via the offer or answer. Even when a codec is excluded by setCodecPreferences, it still may be used to send until the next offer/answer exchange discards it. The codec preferences of an RtpTransceiver can cause codecs to be excluded by subsequent calls to createOffer and createAnswer, in which case the corresponding media formats in the associated "m=" section will be excluded. The codec preferences cannot add media formats that would otherwise not be present. The codec preferences of an RtpTransceiver can also determine the order of codecs in subsequent calls to createOffer and createAnswer, in which case the order of the media formats in the associated "m=" section will follow the specified preferences. |
Case 1: should work as intended, the answer will signal H265. I do suspect we need the "add additional codecs in the answer" that JSEP talks about... |
@fippo In Case 1, with a Safari TP Offer with H.265/H.264 will a Chrome Answer include H.265 on a send/recv m-line? |
RFC 3264 Section 5.1 says: "For a sendonly stream, the offer SHOULD indicate those formats the offerer is willing to send for this stream. For a recvonly stream, the offer SHOULD indicate those formats the offerer is willing to receive for this stream. For a sendrecv stream, the offer SHOULD indicate those codecs that the offerer is willing to send and receive with." This seems consistent with the idea that a sendonly m-line should only include formats it can send; that a recv-only m-line should only include formats that it can receive; and that a send/recv m-line should only include formats that it can both send and receive. That would imply that a send/recv m-line should not include formats that can only be sent or can only be received. |
Correct. |
JSEP has this note (https://rtcweb-wg.github.io/jsep/#rfc.section.4.2.6):
Based on the above, does this make sense to you for a send-only m-line? |
No, not based on the text in JSEP. However, when I read the W3C spec, I can't find any text indicating that it would only be the preferred order of codecs for receiving. The text says the following about setCodecPreferences:
So, based on that the method can also be used to control what codecs are put in the SDP to begin with, which I assume is something that you may want to do also in the case of sendonly. The W3C text also says:
...which sounds like you could use it also for sendonly. And, there is a note saying:
|
@cdh4u Yes, the W3C text is fairly clear about the role of SCP, and this does not seem consistent with JSEP. |
The main problem, however, does not seem to be related to SCP. The problem is that some codecs can only be either sent or received, and there is no way to indicate per-codec directions in SDP. The direction applies to the whole m- line. You could use multiple m- lines, but that would probably cause issues, at least with non-browser endpoints. In the discussions I have seen some suggestions using the rtcmap attribute, but that seems like a hack to me, and would not work with non-browser endpoints either. Harald suggested a new mechanism which would allow to set the direction per codec, That would of course not be backward compatible either, but would probably be the "cleanest" solution. |
Yes, sCP makes things worse because it leads to an API footgun there you do a sendonly m-line but asked for a receive-only codec as the only option which leads to w3c/webrtc-pc#2939 Using unidirectional m-lines avoids the issue but for sendrecv it gets hard to understand the state/result just from the SDP in case 1. Let me elaborate a bit:
This is offering codecs that Safari (support encode/decode of both) can send and receive.
Since Chrome (assuming it can only decode H.265) it can put H.265 into the answer but since it can not send it will only send H.264. This is fine since Safari TP said it can decode H264. But it will not know that it is not going to receive H.265 which means it can not do something like freeing the associated HW decoder resource. I believe this is covered by https://www.rfc-editor.org/rfc/rfc3264#section-6.1
For case 2 the problem is that Chrome (assuming it can only decode H.265) would not include H.265 in the sendrecv offer because of what is written in 5.1 of RFC 3264:
However, there is a loophole (that is not currently supported by libWebRTC but that is an implementation issue): the answer may contain additional codecs (section 6.1)
which is also supplemented by JSEP's https://www.rfc-editor.org/rfc/rfc8829.html#name-initial-answers
How widely supported that is outside of browsers... In theory we are good... 🤞 |
But there is a minor headache related to sCP. JSEP says
If sticking strictly to this, the answerer would not be able to prefer H.265 and put it as the first format? |
@fippo To add to the headaches, there is the matter of profiles. In a send/recv offer, Safari TP can only include a profile/level that it can both send and receive. If there is asymmetry, separate send-only and recv-only m-lines are needed in the Offer to express the profiles/levels that can be sent and those that can be received. |
I think both Case 1 and Case 2 should work. While it could be argued that since H.265 is recvonly for Chrome, it shouldn't be offered on its sendrecv transceiver, that seems overly strict. Chrome should offer both H.265 and H.264 and then just choose to send H.264 while receiving H.265, the same way it would if, for some reason, it determined it had insufficient compute to send H.265 and had to fall back to H.264. Generally, I think that any situation where you get different behavior depending on who is playing the offerer role is going to lead to a suboptimal experience; we should try to avoid such non-deterministic situations. |
That would work assuming that the answer also contains H.264. |
At TPAC 2024, the W3C WEBRTC WG decided on "Proposal A" which is aligned with RFC 3264 Section 5.1. Related: w3c/webrtc-pc#3006 |
Problems have been found in the specification as well as the implementation of the WebRTC API (
setCodecPreferences
) when receive-only codecs are present. This problem surfaced originally in H.264, but is also affecting H.265.The concern is whether an implementation that only supports receiving H.265 (e.g. Chrome) will successfully negotiate HEVC reception with an implementation that can both send and receive (e.g. Safari Tech Preview).
References
w3c/webrtc-pc#2936
w3c/webrtc-pc#2933
w3c/webrtc-pc#2935
w3c/webrtc-pc#2888
The text was updated successfully, but these errors were encountered: