Skip to content
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

FFmpeg: Add Whip Muxer support for subsecond latency streaming #1

Open
wants to merge 60 commits into
base: feature/whip
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
60 commits
Select commit Hold shift + click to select a range
ae07b06
WHIP: Add WebRTC WHIP muxer.
winlinvip Apr 16, 2023
f090d64
WHIP: Only support h264+opus codec.
winlinvip Apr 16, 2023
edaf213
WHIP: Generate and exchange offer server to get answer.
yangrtc Apr 21, 2023
83202f7
WHIP: Support parse ice from answer.
winlinvip Apr 22, 2023
8a63f74
WHIP: Refine code.
winlinvip Apr 22, 2023
67bccbf
WHIP: Support ICE handshake by binding.
winlinvip May 1, 2023
9db6961
WHIP: Support fast retransmit for binding request.
winlinvip May 1, 2023
1496684
WHIP: Update the dependency, requires openssl.
winlinvip May 2, 2023
0522db8
WHIP: Support DTLS handshake by openssl
winlinvip May 2, 2023
4ee4ca5
WHIP: Setup SRTP with key material generated by DTLS
winlinvip May 3, 2023
67f9942
WHIP: Refine code.
winlinvip May 3, 2023
ff5ef96
WHIP: Support mux and send audio by RTP
winlinvip May 3, 2023
98fca74
WHIP: Support mux and send video by RTP
winlinvip May 4, 2023
9ecbef0
WHIP: Support audio or video only
winlinvip May 4, 2023
40c385a
WHIP: Support video annexb format.
winlinvip May 4, 2023
fc0974a
WHIP: Refine code.
winlinvip May 5, 2023
fae7b40
WHIP: Dispose resource when write trailer.
winlinvip May 5, 2023
5e400cd
WHIP: Check alloc fail and return EMOMEM.
winlinvip May 5, 2023
d9c7dc7
WHIP: Always dispose resource by WHIP.
winlinvip May 5, 2023
235aaa0
WHIP: Refine macros.
winlinvip May 6, 2023
34fd9f9
WHIP: Support set parameters by options.
winlinvip May 6, 2023
2bfdb67
WHIP: Eliminate the unused write_trailer.
winlinvip May 6, 2023
e3fdedd
WHIP: Refine code.
winlinvip May 6, 2023
b4574d6
WHIP: Check for null string to avoid strlen crash, scanned by ASAN
winlinvip May 11, 2023
248243a
WHIP: Improve macro and options comments with more background details
winlinvip May 11, 2023
d801061
WHIP: Remote password should be used to generate the message integrity.
winlinvip May 12, 2023
a1a8335
Use AVPrint to generate the offer and answer for WebRTC SDP.
winlinvip May 12, 2023
ff72920
WHIP:Support send sctp
duiniuluantanqin May 12, 2023
fc3a4a2
WHIP: Refining SRTP context selection.
winlinvip May 12, 2023
45e6ece
WHIP: Refine code.
winlinvip May 13, 2023
6f965d6
Add bidirectional ICE binding, DTLS with ECDSA, and compatibility imp…
cloudwebrtc May 13, 2023
3fd6767
Add missing quotation string to error message
winlinvip May 15, 2023
68ef7ad
WHIP: Extract DTLSContext from RTContext.
winlinvip May 17, 2023
c7b146b
WHIP: Reorder functions, nothing changed.
winlinvip May 17, 2023
2dedc86
WHIP: Remove the macro that suppresses warnings for the SSL deprecate…
winlinvip May 18, 2023
1054bed
WHIP: Merge write header to init.
winlinvip May 18, 2023
b31e0c0
WHIP:Support baseline/main/high profile without B frames (#2)
duiniuluantanqin May 19, 2023
b3f5c27
WHIP: Fix the SSL deprecated warning by replacing EC_KEY_new with EVP…
winlinvip May 23, 2023
85c5680
WHIP: Refine the code to be shorter.
winlinvip May 23, 2023
71ee877
WHIP: Increase the base timeout and thereby reduce the number of unne…
winlinvip May 23, 2023
726bb67
WHIP: Refine ARQ for DTLS with bug fixed.
winlinvip May 23, 2023
6e1fbb5
WHIP: Update muxers.texi for RTC.
winlinvip May 29, 2023
86b361c
WHIP: Fix bugs causing build OpenSSL error, to work with Pion
winlinvip May 30, 2023
ea74e3c
Optimize DTLS Handshake and ICE Handling for Improved Performance (#3)
winlinvip Jun 7, 2023
680ed49
Roundtrip3: Refinements Based on Derek Buitenhuis' Comments (#4)
winlinvip Jun 9, 2023
2ac4100
WHIP: Do not hardcode codec for SDP. (#5)
winlinvip Jun 9, 2023
5819297
WHIP: Parse profile and level from extradata.
winlinvip Jun 9, 2023
0c4a158
WHIP: Insert SPS and PPS before IDR frames in annexb format due to h2…
winlinvip Jun 10, 2023
812932e
WHIP: Failed immediately if there is no profile and extradata present.
winlinvip Jun 10, 2023
aaf26ef
WHIP: Refine names and comments.
winlinvip Jun 19, 2023
66a064f
WHIP: Free buffer leak of pb for RTP muxer.
winlinvip Jun 20, 2023
9c7a091
WHIP: Use options for passing parameters to the HTTP or UDP context.
winlinvip Jun 21, 2023
de33fcc
WHIP: Enhance security by using BearToken for delete API.
winlinvip Jun 21, 2023
8971a1f
WHIP: Support user specified certificate and key file.
winlinvip Jun 21, 2023
0bd6867
WHIP: Read DTLS certificate file by ffurl.
winlinvip Jul 4, 2023
0b95312
WHIP: Free bio_in if ENOMEM.
winlinvip Jul 8, 2023
63e3a55
WHIP: Refine DTLS, extract DTLS APIs.
winlinvip Aug 24, 2023
172d34b
Sync with FFmpeg master 5ddab49d48
winlinvip Oct 17, 2023
d3561e6
Extract DTLS to dtls.c
winlinvip Oct 17, 2023
3b15ba1
Change some important step log level to info.
winlinvip Oct 17, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
WHIP: Refine code.
  • Loading branch information
winlinvip committed Oct 17, 2023
commit fc0974aab29a96062733988927b70ccdc8de0570
14 changes: 7 additions & 7 deletions libavformat/rtcenc.c
Original file line number Diff line number Diff line change
Expand Up @@ -482,7 +482,7 @@ static int generate_sdp_offer(AVFormatContext *s)
}

rtc->sdp_offer = av_strdup(tmp);
av_log(s, AV_LOG_VERBOSE, "Generated offer: %s\n", rtc->sdp_offer);
av_log(s, AV_LOG_VERBOSE, "WHIP: Generated offer: %s\n", rtc->sdp_offer);

end:
av_free(tmp);
Expand Down Expand Up @@ -585,7 +585,7 @@ static int exchange_sdp(AVFormatContext *s)
}

rtc->sdp_answer = av_strdup(tmp);
av_log(s, AV_LOG_VERBOSE, "Got answer: %s\n", rtc->sdp_answer);
av_log(s, AV_LOG_VERBOSE, "WHIP: Got answer: %s\n", rtc->sdp_answer);

end:
ffurl_closep(&whip_uc);
Expand Down Expand Up @@ -647,7 +647,7 @@ static int parse_answer(AVFormatContext *s)
}
}

av_log(s, AV_LOG_INFO, "SDP offer=%luB, answer=%luB, ufrag=%s, pwd=%luB, transport=%s://%s:%d\n",
av_log(s, AV_LOG_INFO, "WHIP: SDP offer=%luB, answer=%luB, ufrag=%s, pwd=%luB, transport=%s://%s:%d\n",
strlen(rtc->sdp_offer), strlen(rtc->sdp_answer), rtc->ice_ufrag_remote, strlen(rtc->ice_pwd_remote),
rtc->ice_protocol, rtc->ice_host, rtc->ice_port);

Expand Down Expand Up @@ -811,7 +811,7 @@ static int ice_handshake(AVFormatContext *s)
goto end;
}

av_log(s, AV_LOG_INFO, "ICE STUN ok, url=udp://%s:%d, username=%s:%s, req=%dB, res=%dB, arq=%d\n",
av_log(s, AV_LOG_INFO, "WHIP: ICE STUN ok, url=udp://%s:%d, username=%s:%s, req=%dB, res=%dB, arq=%d\n",
rtc->ice_host, rtc->ice_port, rtc->ice_ufrag_remote, rtc->ice_ufrag_local, size, ret,
UDP_FAST_RETRIES - fast_retries);
ret = 0;
Expand Down Expand Up @@ -915,7 +915,7 @@ static void openssl_state_trace(AVFormatContext *s, uint8_t *data, int length, i
handshake_type = (uint8_t)data[13];
}

av_log(s, AV_LOG_INFO, "DTLS: State %s %s, done=%u, arq=%u, r0=%d, r1=%d, len=%u, cnt=%u, size=%u, hs=%u\n",
av_log(s, AV_LOG_INFO, "WHIP: DTLS state %s %s, done=%u, arq=%u, r0=%d, r1=%d, len=%u, cnt=%u, size=%u, hs=%u\n",
"Active", (incoming? "RECV":"SEND"), rtc->dtls_done_for_us, rtc->dtls_arq_packets, r0, r1, length,
content_type, size, handshake_type);
}
Expand Down Expand Up @@ -1155,7 +1155,7 @@ static int openssl_dtls_handshake(AVFormatContext *s)
goto end;
}

av_log(s, AV_LOG_INFO, "DTLS: Handshake done=%d, arq=%d, srtp_material=%luB\n",
av_log(s, AV_LOG_INFO, "WHIP: DTLS handshake done=%d, arq=%d, srtp_material=%luB\n",
rtc->dtls_done_for_us, rtc->dtls_arq_packets, sizeof(rtc->dtls_srtp_material));

end:
Expand Down Expand Up @@ -1222,7 +1222,7 @@ static int setup_srtp(AVFormatContext *s)
goto end;
}

av_log(s, AV_LOG_INFO, "SRTP: Setup done, suite=%s, key=%luB\n", suite, sizeof(send_key));
av_log(s, AV_LOG_INFO, "WHIP: SRTP setup done, suite=%s, key=%luB\n", suite, sizeof(send_key));

end:
return ret;
Expand Down