Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
e2220e73
Commit
e2220e73
authored
Feb 20, 2015
by
Martin Storsjö
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
rtpenc_h264: Aggregate multiple NAL units into one RTP packet, if possible
Signed-off-by:
Martin Storsjö
<
martin@martin.st
>
parent
c99915f7
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
44 additions
and
1 deletion
+44
-1
rtpenc.h
libavformat/rtpenc.h
+1
-0
rtpenc_h264.c
libavformat/rtpenc_h264.c
+43
-1
No files found.
libavformat/rtpenc.h
View file @
e2220e73
...
@@ -56,6 +56,7 @@ struct RTPMuxContext {
...
@@ -56,6 +56,7 @@ struct RTPMuxContext {
* (1, 2 or 4)
* (1, 2 or 4)
*/
*/
int
nal_length_size
;
int
nal_length_size
;
int
buffered_nals
;
int
flags
;
int
flags
;
...
...
libavformat/rtpenc_h264.c
View file @
e2220e73
...
@@ -25,21 +25,61 @@
...
@@ -25,21 +25,61 @@
* @author Luca Abeni <lucabe72@email.it>
* @author Luca Abeni <lucabe72@email.it>
*/
*/
#include "libavutil/intreadwrite.h"
#include "avformat.h"
#include "avformat.h"
#include "avc.h"
#include "avc.h"
#include "rtpenc.h"
#include "rtpenc.h"
static
void
flush_buffered
(
AVFormatContext
*
s1
,
int
last
)
{
RTPMuxContext
*
s
=
s1
->
priv_data
;
if
(
s
->
buf_ptr
!=
s
->
buf
)
{
// If we're only sending one single NAL unit, send it as such, skip
// the STAP-A framing
if
(
s
->
buffered_nals
==
1
)
ff_rtp_send_data
(
s1
,
s
->
buf
+
3
,
s
->
buf_ptr
-
s
->
buf
-
3
,
last
);
else
ff_rtp_send_data
(
s1
,
s
->
buf
,
s
->
buf_ptr
-
s
->
buf
,
last
);
}
s
->
buf_ptr
=
s
->
buf
;
s
->
buffered_nals
=
0
;
}
static
void
nal_send
(
AVFormatContext
*
s1
,
const
uint8_t
*
buf
,
int
size
,
int
last
)
static
void
nal_send
(
AVFormatContext
*
s1
,
const
uint8_t
*
buf
,
int
size
,
int
last
)
{
{
RTPMuxContext
*
s
=
s1
->
priv_data
;
RTPMuxContext
*
s
=
s1
->
priv_data
;
av_log
(
s1
,
AV_LOG_DEBUG
,
"Sending NAL %x of len %d M=%d
\n
"
,
buf
[
0
]
&
0x1F
,
size
,
last
);
av_log
(
s1
,
AV_LOG_DEBUG
,
"Sending NAL %x of len %d M=%d
\n
"
,
buf
[
0
]
&
0x1F
,
size
,
last
);
if
(
size
<=
s
->
max_payload_size
)
{
if
(
size
<=
s
->
max_payload_size
)
{
int
buffered_size
=
s
->
buf_ptr
-
s
->
buf
;
// Flush buffered NAL units if the current unit doesn't fit
if
(
buffered_size
+
2
+
size
>
s
->
max_payload_size
)
{
flush_buffered
(
s1
,
0
);
buffered_size
=
0
;
}
// If we aren't using mode 0, and the NAL unit fits including the
// framing (2 bytes length, plus 1 byte for the STAP-A marker),
// write the unit to the buffer as a STAP-A packet, otherwise flush
// and send as single NAL.
if
(
buffered_size
+
3
+
size
<=
s
->
max_payload_size
&&
!
(
s
->
flags
&
FF_RTP_FLAG_H264_MODE0
))
{
if
(
buffered_size
==
0
)
*
s
->
buf_ptr
++
=
24
;
AV_WB16
(
s
->
buf_ptr
,
size
);
s
->
buf_ptr
+=
2
;
memcpy
(
s
->
buf_ptr
,
buf
,
size
);
s
->
buf_ptr
+=
size
;
s
->
buffered_nals
++
;
}
else
{
flush_buffered
(
s1
,
0
);
ff_rtp_send_data
(
s1
,
buf
,
size
,
last
);
ff_rtp_send_data
(
s1
,
buf
,
size
,
last
);
}
}
else
{
}
else
{
uint8_t
type
=
buf
[
0
]
&
0x1F
;
uint8_t
type
=
buf
[
0
]
&
0x1F
;
uint8_t
nri
=
buf
[
0
]
&
0x60
;
uint8_t
nri
=
buf
[
0
]
&
0x60
;
flush_buffered
(
s1
,
0
);
if
(
s
->
flags
&
FF_RTP_FLAG_H264_MODE0
)
{
if
(
s
->
flags
&
FF_RTP_FLAG_H264_MODE0
)
{
av_log
(
s1
,
AV_LOG_ERROR
,
av_log
(
s1
,
AV_LOG_ERROR
,
"NAL size %d > %d, try -slice-max-size %d
\n
"
,
size
,
"NAL size %d > %d, try -slice-max-size %d
\n
"
,
size
,
...
@@ -72,6 +112,7 @@ void ff_rtp_send_h264(AVFormatContext *s1, const uint8_t *buf1, int size)
...
@@ -72,6 +112,7 @@ void ff_rtp_send_h264(AVFormatContext *s1, const uint8_t *buf1, int size)
RTPMuxContext
*
s
=
s1
->
priv_data
;
RTPMuxContext
*
s
=
s1
->
priv_data
;
s
->
timestamp
=
s
->
cur_timestamp
;
s
->
timestamp
=
s
->
cur_timestamp
;
s
->
buf_ptr
=
s
->
buf
;
if
(
s
->
nal_length_size
)
if
(
s
->
nal_length_size
)
r
=
ff_avc_mp4_find_startcode
(
buf1
,
end
,
s
->
nal_length_size
)
?
buf1
:
end
;
r
=
ff_avc_mp4_find_startcode
(
buf1
,
end
,
s
->
nal_length_size
)
?
buf1
:
end
;
else
else
...
@@ -91,4 +132,5 @@ void ff_rtp_send_h264(AVFormatContext *s1, const uint8_t *buf1, int size)
...
@@ -91,4 +132,5 @@ void ff_rtp_send_h264(AVFormatContext *s1, const uint8_t *buf1, int size)
nal_send
(
s1
,
r
,
r1
-
r
,
r1
==
end
);
nal_send
(
s1
,
r
,
r1
-
r
,
r1
==
end
);
r
=
r1
;
r
=
r1
;
}
}
flush_buffered
(
s1
,
1
);
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment