Skip to content

Conversation

@youennf
Copy link
Collaborator

@youennf youennf commented May 4, 2021

The goal of this PR is to clarify the threading model, without changing much of the functionality.
For SFrameTransform, the transform happens as if in the media thread, though implementations may decide to do it however they want.
For RTCRtpScriptTransform, the streams are transferred from the media thread directly to the worker thread.


Preview | Diff


Each {{RTCRtpSender}} or {{RTCRtpReceiver}} has its own <dfn>media thread</dfn> on which media flows,
from a source on which to read encoded data to a sink on which to write encoded data.
The source is the packetizer for {{RTCRtpSender}} and the decoder for {{RTCRtpReceiver}}.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems backwards. For Sender, media comes from the encoder and goes to the packetizer; for the Receiver, media comes from the depacketizer and goes to the decoder.

Either I am misunderstanding line 95 or I'm misunderstanding lines 96+98.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Right, it needs to be reversed.


### Stream creation ### {#stream-creation}

Each {{RTCRtpSender}} or {{RTCRtpReceiver}} has its own <dfn>media thread</dfn> on which media flows,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this is not right; in the non-transform case, the media thread on which media flows is not the thread that is visible to JS.

I'll suggest alternate wording (after the meeting).

@youennf
Copy link
Collaborator Author

youennf commented May 20, 2021

Alternative to this PR:

  • Use a slot in media thread to set the destination where frames should go to be processed by the script transform.

1. [=Queue a task=] to run the following step:
1. [=Queue a task=] on [=this=]'s media thread to run the following steps:
1. If [=this=].`[[pipeToController]]` is not null, abort these steps.
1. Set [=this=].`[[pipeToController]]` to a new {{AbortController}}.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This creates a WebIDL interface on a background thread, which we shouldn't do.

@youennf youennf added the IceBox label Dec 8, 2022
@jan-ivar
Copy link
Member

jan-ivar commented Aug 1, 2024

Cleaning up old PRs and this has an IceBox label. Seems there was pushback here on whether a media thread is an implementation detail or not. In any case I think we need to clean up #229 first.

@jan-ivar jan-ivar closed this Aug 1, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants