Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
Z
ZLMediaKit
概览
Overview
Details
Activity
Cycle Analytics
版本库
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
问题
0
Issues
0
列表
Board
标记
里程碑
合并请求
0
Merge Requests
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
Snippets
成员
Collapse sidebar
Close sidebar
活动
图像
聊天
创建新问题
作业
提交
Issue Boards
Open sidebar
张翔宇
ZLMediaKit
Commits
90315ebc
Commit
90315ebc
authored
Nov 27, 2021
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
RTC: srtp发送减少一次内存拷贝,提高webrtc发送性能
parent
5daf52ca
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
31 行增加
和
29 行删除
+31
-29
webrtc/WebRtcTransport.cpp
+26
-23
webrtc/WebRtcTransport.h
+5
-6
没有找到文件。
webrtc/WebRtcTransport.cpp
查看文件 @
90315ebc
...
...
@@ -46,6 +46,7 @@ static onceToken token([]() {
WebRtcTransport
::
WebRtcTransport
(
const
EventPoller
::
Ptr
&
poller
)
{
_poller
=
poller
;
_identifier
=
to_string
(
reinterpret_cast
<
uint64_t
>
(
this
));
_packet_pool
.
setSize
(
64
);
}
void
WebRtcTransport
::
onCreate
(){
...
...
@@ -69,7 +70,7 @@ const string &WebRtcTransport::getIdentifier() const {
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void
WebRtcTransport
::
OnIceServerSendStunPacket
(
const
RTC
::
IceServer
*
iceServer
,
const
RTC
::
StunPacket
*
packet
,
RTC
::
TransportTuple
*
tuple
)
{
onSendSockData
((
char
*
)
packet
->
GetData
(),
packet
->
GetSize
(),
(
struct
sockaddr_in
*
)
tuple
);
sendSockData
((
char
*
)
packet
->
GetData
(),
packet
->
GetSize
(),
tuple
);
}
void
WebRtcTransport
::
OnIceServerSelectedTuple
(
const
RTC
::
IceServer
*
iceServer
,
RTC
::
TransportTuple
*
tuple
)
{
...
...
@@ -110,7 +111,7 @@ void WebRtcTransport::OnDtlsTransportConnected(
}
void
WebRtcTransport
::
OnDtlsTransportSendData
(
const
RTC
::
DtlsTransport
*
dtlsTransport
,
const
uint8_t
*
data
,
size_t
len
)
{
onSendSockData
((
char
*
)
data
,
len
);
sendSockData
((
char
*
)
data
,
len
,
nullptr
);
}
void
WebRtcTransport
::
OnDtlsTransportConnecting
(
const
RTC
::
DtlsTransport
*
dtlsTransport
)
{
...
...
@@ -132,10 +133,10 @@ void WebRtcTransport::OnDtlsTransportApplicationDataReceived(const RTC::DtlsTran
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void
WebRtcTransport
::
onSendSockData
(
const
char
*
buf
,
size_t
len
,
bool
flush
){
auto
tuple
=
_ice_server
->
GetSelectedTuple
();
assert
(
tuple
);
onSendSockData
(
buf
,
len
,
(
struct
sockaddr_in
*
)
tuple
,
flush
);
void
WebRtcTransport
::
sendSockData
(
const
char
*
buf
,
size_t
len
,
RTC
::
TransportTuple
*
tuple
){
auto
pkt
=
_packet_pool
.
obtain
();
pkt
->
assign
(
buf
,
len
);
onSendSockData
(
std
::
move
(
pkt
),
true
,
tuple
?
tuple
:
_ice_server
->
GetSelectedTuple
()
);
}
RTC
::
TransportTuple
*
WebRtcTransport
::
getSelectedTuple
()
const
{
...
...
@@ -266,23 +267,28 @@ void WebRtcTransport::inputSockData(char *buf, int len, RTC::TransportTuple *tup
void
WebRtcTransport
::
sendRtpPacket
(
const
char
*
buf
,
int
len
,
bool
flush
,
void
*
ctx
)
{
if
(
_srtp_session_send
)
{
auto
pkt
=
_packet_pool
.
obtain
();
//预留rtx加入的两个字节
CHECK
((
size_t
)
len
+
SRTP_MAX_TRAILER_LEN
+
2
<=
sizeof
(
_srtp_buf
));
memcpy
(
_srtp_buf
,
buf
,
len
);
onBeforeEncryptRtp
((
char
*
)
_srtp_buf
,
len
,
ctx
);
if
(
_srtp_session_send
->
EncryptRtp
(
_srtp_buf
,
&
len
))
{
onSendSockData
((
char
*
)
_srtp_buf
,
len
,
flush
);
pkt
->
setCapacity
((
size_t
)
len
+
SRTP_MAX_TRAILER_LEN
+
2
);
pkt
->
assign
(
buf
,
len
);
onBeforeEncryptRtp
(
pkt
->
data
(),
len
,
ctx
);
if
(
_srtp_session_send
->
EncryptRtp
(
reinterpret_cast
<
uint8_t
*>
(
pkt
->
data
()),
&
len
))
{
pkt
->
setSize
(
len
);
onSendSockData
(
std
::
move
(
pkt
),
flush
);
}
}
}
void
WebRtcTransport
::
sendRtcpPacket
(
const
char
*
buf
,
int
len
,
bool
flush
,
void
*
ctx
){
void
WebRtcTransport
::
sendRtcpPacket
(
const
char
*
buf
,
int
len
,
bool
flush
,
void
*
ctx
)
{
if
(
_srtp_session_send
)
{
CHECK
((
size_t
)
len
+
SRTP_MAX_TRAILER_LEN
<=
sizeof
(
_srtp_buf
));
memcpy
(
_srtp_buf
,
buf
,
len
);
onBeforeEncryptRtcp
((
char
*
)
_srtp_buf
,
len
,
ctx
);
if
(
_srtp_session_send
->
EncryptRtcp
(
_srtp_buf
,
&
len
))
{
onSendSockData
((
char
*
)
_srtp_buf
,
len
,
flush
);
auto
pkt
=
_packet_pool
.
obtain
();
//预留rtx加入的两个字节
pkt
->
setCapacity
((
size_t
)
len
+
SRTP_MAX_TRAILER_LEN
+
2
);
pkt
->
assign
(
buf
,
len
);
onBeforeEncryptRtcp
(
pkt
->
data
(),
len
,
ctx
);
if
(
_srtp_session_send
->
EncryptRtcp
(
reinterpret_cast
<
uint8_t
*>
(
pkt
->
data
()),
&
len
))
{
pkt
->
setSize
(
len
);
onSendSockData
(
std
::
move
(
pkt
),
flush
);
}
}
}
...
...
@@ -313,7 +319,6 @@ void WebRtcTransportImp::onCreate(){
WebRtcTransportImp
::
WebRtcTransportImp
(
const
EventPoller
::
Ptr
&
poller
)
:
WebRtcTransport
(
poller
)
{
InfoL
<<
getIdentifier
();
_packet_pool
.
setSize
(
64
);
}
WebRtcTransportImp
::~
WebRtcTransportImp
()
{
...
...
@@ -325,16 +330,14 @@ void WebRtcTransportImp::onDestory() {
unregisterSelf
();
}
void
WebRtcTransportImp
::
onSendSockData
(
const
char
*
buf
,
size_t
len
,
struct
sockaddr_in
*
dst
,
bool
flush
)
{
void
WebRtcTransportImp
::
onSendSockData
(
Buffer
::
Ptr
buf
,
bool
flush
,
RTC
::
TransportTuple
*
tuple
)
{
if
(
!
_session
)
{
WarnL
<<
"send data failed:"
<<
len
;
WarnL
<<
"send data failed:"
<<
buf
->
size
()
;
return
;
}
auto
ptr
=
_packet_pool
.
obtain
();
ptr
->
assign
(
buf
,
len
);
//一次性发送一帧的rtp数据,提高网络io性能
_session
->
setSendFlushFlag
(
flush
);
_session
->
send
(
std
::
move
(
ptr
));
_session
->
send
(
std
::
move
(
buf
));
}
///////////////////////////////////////////////////////////////////
...
...
webrtc/WebRtcTransport.h
查看文件 @
90315ebc
...
...
@@ -135,7 +135,7 @@ protected:
virtual
void
onStartWebRTC
()
=
0
;
virtual
void
onRtcConfigure
(
RtcConfigure
&
configure
)
const
;
virtual
void
onCheckSdp
(
SdpType
type
,
RtcSession
&
sdp
)
=
0
;
virtual
void
onSendSockData
(
const
char
*
buf
,
size_t
len
,
struct
sockaddr_in
*
dst
,
bool
flush
=
true
)
=
0
;
virtual
void
onSendSockData
(
Buffer
::
Ptr
buf
,
bool
flush
=
true
,
RTC
::
TransportTuple
*
tuple
=
nullptr
)
=
0
;
virtual
void
onRtp
(
const
char
*
buf
,
size_t
len
,
uint64_t
stamp_ms
)
=
0
;
virtual
void
onRtcp
(
const
char
*
buf
,
size_t
len
)
=
0
;
...
...
@@ -149,7 +149,7 @@ protected:
void
sendRtcpPli
(
uint32_t
ssrc
);
private
:
void
onSendSockData
(
const
char
*
buf
,
size_t
len
,
bool
flush
=
tru
e
);
void
sendSockData
(
const
char
*
buf
,
size_t
len
,
RTC
::
TransportTuple
*
tupl
e
);
void
setRemoteDtlsFingerprint
(
const
RtcSession
&
remote
);
protected
:
...
...
@@ -157,7 +157,6 @@ protected:
RtcSession
::
Ptr
_answer_sdp
;
private
:
uint8_t
_srtp_buf
[
2000
];
string
_identifier
;
EventPoller
::
Ptr
_poller
;
std
::
shared_ptr
<
RTC
::
IceServer
>
_ice_server
;
...
...
@@ -165,6 +164,8 @@ private:
std
::
shared_ptr
<
RTC
::
SrtpSession
>
_srtp_session_send
;
std
::
shared_ptr
<
RTC
::
SrtpSession
>
_srtp_session_recv
;
Ticker
_ticker
;
//循环池
ResourcePool
<
BufferRaw
>
_packet_pool
;
};
class
RtpChannel
;
...
...
@@ -232,7 +233,7 @@ public:
protected
:
WebRtcTransportImp
(
const
EventPoller
::
Ptr
&
poller
);
void
onStartWebRTC
()
override
;
void
onSendSockData
(
const
char
*
buf
,
size_t
len
,
struct
sockaddr_in
*
dst
,
bool
flush
=
true
)
override
;
void
onSendSockData
(
Buffer
::
Ptr
buf
,
bool
flush
=
true
,
RTC
::
TransportTuple
*
tuple
=
nullptr
)
override
;
void
onCheckSdp
(
SdpType
type
,
RtcSession
&
sdp
)
override
;
void
onRtcConfigure
(
RtcConfigure
&
configure
)
const
override
;
...
...
@@ -279,8 +280,6 @@ private:
unordered_map
<
uint32_t
/*ssrc*/
,
MediaTrack
::
Ptr
>
_ssrc_to_track
;
//根据接收rtp的pt获取相关信息
unordered_map
<
uint8_t
/*pt*/
,
std
::
unique_ptr
<
WrappedMediaTrack
>>
_pt_to_track
;
//循环池
ResourcePool
<
BufferRaw
>
_packet_pool
;
};
class
WebRtcTransportManager
{
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论