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
d3463912
Commit
d3463912
authored
May 29, 2016
by
Andrey Turkin
Committed by
Timo Rothenpieler
May 31, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avcodec/nvenc: extract timestamp calculations into separate function
Signed-off-by:
Timo Rothenpieler
<
timo@rothenpieler.org
>
parent
0d021cc8
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
16 deletions
+29
-16
nvenc.c
libavcodec/nvenc.c
+29
-16
No files found.
libavcodec/nvenc.c
View file @
d3463912
...
@@ -1405,6 +1405,29 @@ static void nvenc_codec_specific_pic_params(AVCodecContext *avctx,
...
@@ -1405,6 +1405,29 @@ static void nvenc_codec_specific_pic_params(AVCodecContext *avctx,
}
}
}
}
static
int
nvenc_set_timestamp
(
AVCodecContext
*
avctx
,
NV_ENC_LOCK_BITSTREAM
*
params
,
AVPacket
*
pkt
)
{
NvencContext
*
ctx
=
avctx
->
priv_data
;
pkt
->
pts
=
params
->
outputTimeStamp
;
pkt
->
dts
=
timestamp_queue_dequeue
(
ctx
->
timestamp_list
);
/* when there're b frame(s), set dts offset */
if
(
ctx
->
encode_config
.
frameIntervalP
>=
2
)
pkt
->
dts
-=
1
;
if
(
pkt
->
dts
>
pkt
->
pts
)
pkt
->
dts
=
pkt
->
pts
;
if
(
ctx
->
last_dts
!=
AV_NOPTS_VALUE
&&
pkt
->
dts
<=
ctx
->
last_dts
)
pkt
->
dts
=
ctx
->
last_dts
+
1
;
ctx
->
last_dts
=
pkt
->
dts
;
return
0
;
}
static
int
process_output_surface
(
AVCodecContext
*
avctx
,
AVPacket
*
pkt
,
NvencSurface
*
tmpoutsurf
)
static
int
process_output_surface
(
AVCodecContext
*
avctx
,
AVPacket
*
pkt
,
NvencSurface
*
tmpoutsurf
)
{
{
NvencContext
*
ctx
=
avctx
->
priv_data
;
NvencContext
*
ctx
=
avctx
->
priv_data
;
...
@@ -1434,7 +1457,7 @@ static int process_output_surface(AVCodecContext *avctx, AVPacket *pkt, NvencSur
...
@@ -1434,7 +1457,7 @@ static int process_output_surface(AVCodecContext *avctx, AVPacket *pkt, NvencSur
slice_offsets
=
av_mallocz
(
slice_mode_data
*
sizeof
(
*
slice_offsets
));
slice_offsets
=
av_mallocz
(
slice_mode_data
*
sizeof
(
*
slice_offsets
));
if
(
!
slice_offsets
)
if
(
!
slice_offsets
)
return
AVERROR
(
ENOMEM
)
;
goto
error
;
lock_params
.
version
=
NV_ENC_LOCK_BITSTREAM_VER
;
lock_params
.
version
=
NV_ENC_LOCK_BITSTREAM_VER
;
...
@@ -1499,29 +1522,19 @@ FF_ENABLE_DEPRECATION_WARNINGS
...
@@ -1499,29 +1522,19 @@ FF_ENABLE_DEPRECATION_WARNINGS
ff_side_data_set_encoder_stats
(
pkt
,
ff_side_data_set_encoder_stats
(
pkt
,
(
lock_params
.
frameAvgQP
-
1
)
*
FF_QP2LAMBDA
,
NULL
,
0
,
pict_type
);
(
lock_params
.
frameAvgQP
-
1
)
*
FF_QP2LAMBDA
,
NULL
,
0
,
pict_type
);
pkt
->
pts
=
lock_params
.
outputTimeStamp
;
res
=
nvenc_set_timestamp
(
avctx
,
&
lock_params
,
pkt
);
pkt
->
dts
=
timestamp_queue_dequeue
(
ctx
->
timestamp_list
);
if
(
res
<
0
)
goto
error2
;
/* when there're b frame(s), set dts offset */
if
(
ctx
->
encode_config
.
frameIntervalP
>=
2
)
pkt
->
dts
-=
1
;
if
(
pkt
->
dts
>
pkt
->
pts
)
pkt
->
dts
=
pkt
->
pts
;
if
(
ctx
->
last_dts
!=
AV_NOPTS_VALUE
&&
pkt
->
dts
<=
ctx
->
last_dts
)
pkt
->
dts
=
ctx
->
last_dts
+
1
;
ctx
->
last_dts
=
pkt
->
dts
;
av_free
(
slice_offsets
);
av_free
(
slice_offsets
);
return
0
;
return
0
;
error:
error:
timestamp_queue_dequeue
(
ctx
->
timestamp_list
);
error2:
av_free
(
slice_offsets
);
av_free
(
slice_offsets
);
timestamp_queue_dequeue
(
ctx
->
timestamp_list
);
return
res
;
return
res
;
}
}
...
...
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