mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-20 07:58:10 +00:00
net/quinn: Update QUIC multiplexing examples for WebTransport
Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/1966>
This commit is contained in:
parent
59cc4af3ba
commit
3aa1fa81b5
2 changed files with 45 additions and 15 deletions
|
@ -15,6 +15,12 @@ GST_PLUGIN_PATH=target/debug cargo run -p gst-plugin-quinn --example quic_mux
|
||||||
GST_PLUGIN_PATH=target/debug cargo run -p gst-plugin-quinn --example quic_mux -- --receiver
|
GST_PLUGIN_PATH=target/debug cargo run -p gst-plugin-quinn --example quic_mux -- --receiver
|
||||||
```
|
```
|
||||||
|
|
||||||
|
QUIC multiplexing example with WebTransport can be tested as follows.
|
||||||
|
```bash
|
||||||
|
GST_PLUGIN_PATH=target/debug cargo run -p gst-plugin-quinn --example quic_mux -- --webtransport
|
||||||
|
GST_PLUGIN_PATH=target/debug cargo run -p gst-plugin-quinn --example quic_mux -- --receiver --webtransport
|
||||||
|
```
|
||||||
|
|
||||||
RoQ example can be tested as follows. This tests H264 by default.
|
RoQ example can be tested as follows. This tests H264 by default.
|
||||||
```bash
|
```bash
|
||||||
GST_PLUGIN_PATH=target/debug cargo run -p gst-plugin-quinn --example quic_roq
|
GST_PLUGIN_PATH=target/debug cargo run -p gst-plugin-quinn --example quic_roq
|
||||||
|
|
|
@ -19,6 +19,8 @@ static CAT: LazyLock<gst::DebugCategory> = LazyLock::new(|| {
|
||||||
struct Cli {
|
struct Cli {
|
||||||
#[clap(long, short, action)]
|
#[clap(long, short, action)]
|
||||||
receiver: bool,
|
receiver: bool,
|
||||||
|
#[clap(long, short, action)]
|
||||||
|
webtransport: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn video_bin(text: String) -> gst::Bin {
|
fn video_bin(text: String) -> gst::Bin {
|
||||||
|
@ -133,8 +135,14 @@ fn depay_bin(pipeline: &gst::Pipeline, bin_name: String) -> gst::Bin {
|
||||||
bin
|
bin
|
||||||
}
|
}
|
||||||
|
|
||||||
fn receive_pipeline(pipeline: &gst::Pipeline) {
|
fn receive_pipeline(pipeline: &gst::Pipeline, use_webtransport: bool) {
|
||||||
let quicsrc = gst::ElementFactory::make("quinnquicsrc").build().unwrap();
|
let quicsrc = if use_webtransport {
|
||||||
|
gst::ElementFactory::make("quinnwtclientsrc")
|
||||||
|
.build()
|
||||||
|
.unwrap()
|
||||||
|
} else {
|
||||||
|
gst::ElementFactory::make("quinnquicsrc").build().unwrap()
|
||||||
|
};
|
||||||
let demux = gst::ElementFactory::make("quinnquicdemux").build().unwrap();
|
let demux = gst::ElementFactory::make("quinnquicdemux").build().unwrap();
|
||||||
let compositor = gst::ElementFactory::make("compositor")
|
let compositor = gst::ElementFactory::make("compositor")
|
||||||
.name("compositor")
|
.name("compositor")
|
||||||
|
@ -145,13 +153,17 @@ fn receive_pipeline(pipeline: &gst::Pipeline) {
|
||||||
.build()
|
.build()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
|
if use_webtransport {
|
||||||
|
quicsrc.set_property("url", "https://127.0.0.1:4445");
|
||||||
|
} else {
|
||||||
quicsrc.set_property("initial-mtu", 1200u32);
|
quicsrc.set_property("initial-mtu", 1200u32);
|
||||||
quicsrc.set_property("min-mtu", 1200u32);
|
quicsrc.set_property("min-mtu", 1200u32);
|
||||||
quicsrc.set_property("upper-bound-mtu", 65527u32);
|
quicsrc.set_property("upper-bound-mtu", 65527u32);
|
||||||
quicsrc.set_property("max-udp-payload-size", 65527u32);
|
quicsrc.set_property("max-udp-payload-size", 65527u32);
|
||||||
quicsrc.set_property("use-datagram", false);
|
|
||||||
quicsrc.set_property("secure-connection", false);
|
|
||||||
quicsrc.set_property("server-name", "quinnmux-test");
|
quicsrc.set_property("server-name", "quinnmux-test");
|
||||||
|
}
|
||||||
|
|
||||||
|
quicsrc.set_property("secure-connection", false);
|
||||||
|
|
||||||
pipeline
|
pipeline
|
||||||
.add_many([&quicsrc, &demux, &compositor, &sink])
|
.add_many([&quicsrc, &demux, &compositor, &sink])
|
||||||
|
@ -240,7 +252,7 @@ fn receive_pipeline(pipeline: &gst::Pipeline) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
fn send_pipeline(pipeline: &gst::Pipeline) {
|
fn send_pipeline(pipeline: &gst::Pipeline, use_webtransport: bool) {
|
||||||
let video1 = video_bin("Stream 1".to_string());
|
let video1 = video_bin("Stream 1".to_string());
|
||||||
let video2 = video_bin("Stream 2".to_string());
|
let video2 = video_bin("Stream 2".to_string());
|
||||||
let video3 = video_bin("Stream 3".to_string());
|
let video3 = video_bin("Stream 3".to_string());
|
||||||
|
@ -249,10 +261,17 @@ fn send_pipeline(pipeline: &gst::Pipeline) {
|
||||||
.name("quic-mux")
|
.name("quic-mux")
|
||||||
.build()
|
.build()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let sink = gst::ElementFactory::make("quinnquicsink")
|
let sink = if use_webtransport {
|
||||||
|
gst::ElementFactory::make("quinnwtserversink")
|
||||||
|
.name("wt-sink")
|
||||||
|
.build()
|
||||||
|
.unwrap()
|
||||||
|
} else {
|
||||||
|
gst::ElementFactory::make("quinnquicsink")
|
||||||
.name("quic-sink")
|
.name("quic-sink")
|
||||||
.build()
|
.build()
|
||||||
.unwrap();
|
.unwrap()
|
||||||
|
};
|
||||||
|
|
||||||
sink.set_property("drop-buffer-for-datagram", true);
|
sink.set_property("drop-buffer-for-datagram", true);
|
||||||
sink.set_property("initial-mtu", 1200u32);
|
sink.set_property("initial-mtu", 1200u32);
|
||||||
|
@ -263,6 +282,11 @@ fn send_pipeline(pipeline: &gst::Pipeline) {
|
||||||
sink.set_property("secure-connection", false);
|
sink.set_property("secure-connection", false);
|
||||||
sink.set_property("server-name", "quinnmux-test");
|
sink.set_property("server-name", "quinnmux-test");
|
||||||
|
|
||||||
|
if use_webtransport {
|
||||||
|
sink.set_property("address", "127.0.0.1");
|
||||||
|
sink.set_property("port", 4445u32);
|
||||||
|
}
|
||||||
|
|
||||||
pipeline
|
pipeline
|
||||||
.add_many([&video1, &video2, &video3, &video4])
|
.add_many([&video1, &video2, &video3, &video4])
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
@ -365,10 +389,10 @@ fn main() {
|
||||||
let main_loop = glib::MainLoop::new(Some(&context), false);
|
let main_loop = glib::MainLoop::new(Some(&context), false);
|
||||||
|
|
||||||
if !cli.receiver {
|
if !cli.receiver {
|
||||||
send_pipeline(&pipeline);
|
send_pipeline(&pipeline, cli.webtransport);
|
||||||
pipeline.debug_to_dot_file_with_ts(gst::DebugGraphDetails::all(), "quic-mux-send-pipeline");
|
pipeline.debug_to_dot_file_with_ts(gst::DebugGraphDetails::all(), "quic-mux-send-pipeline");
|
||||||
} else {
|
} else {
|
||||||
receive_pipeline(&pipeline);
|
receive_pipeline(&pipeline, cli.webtransport);
|
||||||
pipeline.debug_to_dot_file_with_ts(gst::DebugGraphDetails::all(), "quic-mux-recv-pipeline");
|
pipeline.debug_to_dot_file_with_ts(gst::DebugGraphDetails::all(), "quic-mux-recv-pipeline");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue