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
248b2d5c
Commit
248b2d5c
authored
Jul 08, 2020
by
xiongziliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
完善GB28181推流
parent
477f99b7
显示空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
70 行增加
和
17 行删除
+70
-17
src/Rtp/RtpProcess.h
+15
-0
src/Rtp/RtpSelector.cpp
+3
-6
src/Rtp/RtpSelector.h
+22
-1
src/Rtp/RtpServer.cpp
+28
-8
src/Rtp/RtpServer.h
+1
-0
tests/test_rtp.cpp
+1
-2
没有找到文件。
src/Rtp/RtpProcess.h
查看文件 @
248b2d5c
...
...
@@ -27,9 +27,24 @@ public:
typedef
std
::
shared_ptr
<
RtpProcess
>
Ptr
;
RtpProcess
(
const
string
&
stream_id
);
~
RtpProcess
();
/**
* 输入rtp
* @param sock 本地监听的socket
* @param data rtp数据指针
* @param data_len rtp数据长度
* @param addr 数据源地址
* @param dts_out 解析出最新的dts
* @return 是否解析成功
*/
bool
inputRtp
(
const
Socket
::
Ptr
&
sock
,
const
char
*
data
,
int
data_len
,
const
struct
sockaddr
*
addr
,
uint32_t
*
dts_out
=
nullptr
);
/**
* 是否超时,用于超时移除对象
*/
bool
alive
();
/// SockInfo override
string
get_local_ip
()
override
;
uint16_t
get_local_port
()
override
;
string
get_peer_ip
()
override
;
...
...
src/Rtp/RtpSelector.cpp
查看文件 @
248b2d5c
...
...
@@ -15,20 +15,17 @@ namespace mediakit{
INSTANCE_IMP
(
RtpSelector
);
bool
RtpSelector
::
inputRtp
(
const
Socket
::
Ptr
&
sock
,
string
&
stream_id
,
const
char
*
data
,
int
data_len
,
bool
RtpSelector
::
inputRtp
(
const
Socket
::
Ptr
&
sock
,
const
char
*
data
,
int
data_len
,
const
struct
sockaddr
*
addr
,
uint32_t
*
dts_out
)
{
if
(
stream_id
.
empty
())
{
//未指定流id,那么使用ssrc为流id
//使用ssrc为流id
uint32_t
ssrc
=
0
;
if
(
!
getSSRC
(
data
,
data_len
,
ssrc
))
{
WarnL
<<
"get ssrc from rtp failed:"
<<
data_len
;
return
false
;
}
stream_id
=
printSSRC
(
ssrc
);
}
//假定指定了流id,那么通过流id来区分是否为一路流(哪怕可能同时收到多路流)
auto
process
=
getProcess
(
stream_id
,
true
);
auto
process
=
getProcess
(
printSSRC
(
ssrc
)
,
true
);
if
(
process
)
{
return
process
->
inputRtp
(
sock
,
data
,
data_len
,
addr
,
dts_out
);
}
...
...
src/Rtp/RtpSelector.h
查看文件 @
248b2d5c
...
...
@@ -49,10 +49,31 @@ public:
static
bool
getSSRC
(
const
char
*
data
,
int
data_len
,
uint32_t
&
ssrc
);
static
RtpSelector
&
Instance
();
bool
inputRtp
(
const
Socket
::
Ptr
&
sock
,
string
&
stream_id
,
const
char
*
data
,
int
data_len
,
/**
* 输入多个rtp流,根据ssrc分流
* @param sock 本地socket
* @param data 收到的数据
* @param data_len 收到的数据长度
* @param addr rtp流源地址
* @param dts_out 解析出最新的dts
* @return 是否成功
*/
bool
inputRtp
(
const
Socket
::
Ptr
&
sock
,
const
char
*
data
,
int
data_len
,
const
struct
sockaddr
*
addr
,
uint32_t
*
dts_out
=
nullptr
);
/**
* 获取一个rtp处理器
* @param stream_id 流id
* @param makeNew 不存在时是否新建
* @return rtp处理器
*/
RtpProcess
::
Ptr
getProcess
(
const
string
&
stream_id
,
bool
makeNew
);
/**
* 删除rtp处理器
* @param stream_id 流id
* @param ptr rtp处理器指针
*/
void
delProcess
(
const
string
&
stream_id
,
const
RtpProcess
*
ptr
);
private
:
...
...
src/Rtp/RtpServer.cpp
查看文件 @
248b2d5c
...
...
@@ -17,25 +17,20 @@ RtpServer::RtpServer() {
}
RtpServer
::~
RtpServer
()
{
if
(
_
udp_server
){
_
udp_server
->
setOnRead
(
nullptr
);
if
(
_
on_clearup
){
_
on_clearup
(
);
}
}
void
RtpServer
::
start
(
uint16_t
local_port
,
const
string
&
stream_id
,
bool
enable_tcp
,
const
char
*
local_ip
)
{
_udp_server
.
reset
(
new
Socket
(
nullptr
,
false
));
auto
&
ref
=
RtpSelector
::
Instance
();
auto
sock
=
_udp_server
;
_udp_server
->
setOnRead
([
&
ref
,
sock
,
stream_id
](
const
Buffer
::
Ptr
&
buf
,
struct
sockaddr
*
addr
,
int
)
{
ref
.
inputRtp
(
sock
,
const_cast
<
string
&>
(
stream_id
),
buf
->
data
(),
buf
->
size
(),
addr
);
});
//创建udp服务器
if
(
!
_udp_server
->
bindUdpSock
(
local_port
,
local_ip
))
{
_udp_server
=
nullptr
;
string
err
=
(
StrPrinter
<<
"bindUdpSock on "
<<
local_ip
<<
":"
<<
local_port
<<
" failed:"
<<
get_uv_errmsg
(
true
));
throw
std
::
runtime_error
(
err
);
}
//设置udp socket读缓存
SockUtil
::
setRecvBuf
(
_udp_server
->
rawFD
(),
4
*
1024
*
1024
);
...
...
@@ -51,6 +46,31 @@ void RtpServer::start(uint16_t local_port, const string &stream_id, bool enable
throw
;
}
}
auto
sock
=
_udp_server
;
RtpProcess
::
Ptr
process
;
if
(
!
stream_id
.
empty
())
{
//指定了流id,那么一个端口一个流(不管是否包含多个ssrc的多个流,绑定rtp源后,会筛选掉ip端口不匹配的流)
process
=
RtpSelector
::
Instance
().
getProcess
(
stream_id
,
true
);
_udp_server
->
setOnRead
([
sock
,
process
](
const
Buffer
::
Ptr
&
buf
,
struct
sockaddr
*
addr
,
int
)
{
process
->
inputRtp
(
sock
,
buf
->
data
(),
buf
->
size
(),
addr
);
});
}
else
{
//未指定流id,一个端口多个流,通过ssrc来分流
auto
&
ref
=
RtpSelector
::
Instance
();
_udp_server
->
setOnRead
([
&
ref
,
sock
](
const
Buffer
::
Ptr
&
buf
,
struct
sockaddr
*
addr
,
int
)
{
ref
.
inputRtp
(
sock
,
buf
->
data
(),
buf
->
size
(),
addr
);
});
}
_on_clearup
=
[
sock
,
process
,
stream_id
]()
{
//去除循环引用
sock
->
setOnRead
(
nullptr
);
if
(
process
)
{
//删除rtp处理器
RtpSelector
::
Instance
().
delProcess
(
stream_id
,
process
.
get
());
}
};
}
EventPoller
::
Ptr
RtpServer
::
getPoller
()
{
...
...
src/Rtp/RtpServer.h
查看文件 @
248b2d5c
...
...
@@ -55,6 +55,7 @@ public:
protected
:
Socket
::
Ptr
_udp_server
;
TcpServer
::
Ptr
_tcp_server
;
function
<
void
()
>
_on_clearup
;
};
}
//namespace mediakit
...
...
tests/test_rtp.cpp
查看文件 @
248b2d5c
...
...
@@ -38,7 +38,6 @@ static bool loadFile(const char *path){
uint16_t
len
;
char
rtp
[
2
*
1024
];
struct
sockaddr
addr
=
{
0
};
string
stream_id
;
while
(
true
)
{
if
(
2
!=
fread
(
&
len
,
1
,
2
,
fp
))
{
WarnL
;
...
...
@@ -56,7 +55,7 @@ static bool loadFile(const char *path){
}
uint32_t
timeStamp
;
RtpSelector
::
Instance
().
inputRtp
(
nullptr
,
stream_id
,
rtp
,
len
,
&
addr
,
&
timeStamp
);
RtpSelector
::
Instance
().
inputRtp
(
nullptr
,
rtp
,
len
,
&
addr
,
&
timeStamp
);
if
(
timeStamp_last
){
auto
diff
=
timeStamp
-
timeStamp_last
;
if
(
diff
>
0
&&
diff
<
500
){
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论