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
0a6aa30f
Commit
0a6aa30f
authored
Jul 29, 2015
by
Michael Niedermayer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avcodec/h264_refs: extend RAP heuristic to multiple PPS
Signed-off-by:
Michael Niedermayer
<
michael@niedermayer.cc
>
parent
97895951
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
7 additions
and
3 deletions
+7
-3
h264_refs.c
libavcodec/h264_refs.c
+7
-3
No files found.
libavcodec/h264_refs.c
View file @
0a6aa30f
...
@@ -617,6 +617,7 @@ int ff_h264_execute_ref_pic_marking(H264Context *h, MMCO *mmco, int mmco_count)
...
@@ -617,6 +617,7 @@ int ff_h264_execute_ref_pic_marking(H264Context *h, MMCO *mmco, int mmco_count)
{
{
int
i
,
av_uninit
(
j
);
int
i
,
av_uninit
(
j
);
int
pps_count
;
int
pps_count
;
int
pps_ref_count
[
2
]
=
{
0
};
int
current_ref_assigned
=
0
,
err
=
0
;
int
current_ref_assigned
=
0
,
err
=
0
;
H264Picture
*
av_uninit
(
pic
);
H264Picture
*
av_uninit
(
pic
);
...
@@ -801,13 +802,16 @@ int ff_h264_execute_ref_pic_marking(H264Context *h, MMCO *mmco, int mmco_count)
...
@@ -801,13 +802,16 @@ int ff_h264_execute_ref_pic_marking(H264Context *h, MMCO *mmco, int mmco_count)
print_long_term
(
h
);
print_long_term
(
h
);
pps_count
=
0
;
pps_count
=
0
;
for
(
i
=
0
;
i
<
FF_ARRAY_ELEMS
(
h
->
pps_buffers
);
i
++
)
for
(
i
=
0
;
i
<
FF_ARRAY_ELEMS
(
h
->
pps_buffers
);
i
++
)
{
pps_count
+=
!!
h
->
pps_buffers
[
i
];
pps_count
+=
!!
h
->
pps_buffers
[
i
];
pps_ref_count
[
0
]
=
FFMAX
(
pps_ref_count
[
0
],
h
->
pps
.
ref_count
[
0
]);
pps_ref_count
[
1
]
=
FFMAX
(
pps_ref_count
[
1
],
h
->
pps
.
ref_count
[
1
]);
}
if
(
err
>=
0
if
(
err
>=
0
&&
h
->
long_ref_count
==
0
&&
h
->
long_ref_count
==
0
&&
(
h
->
short_ref_count
<=
2
||
h
->
pps
.
ref_count
[
0
]
<=
1
&&
h
->
pps
.
ref_count
[
1
]
<=
1
&&
pps_count
=
=
1
)
&&
(
h
->
short_ref_count
<=
2
||
pps_ref_count
[
0
]
<=
1
&&
pps_ref_count
[
1
]
<
=
1
)
&&
h
->
pps
.
ref_count
[
0
]
<=
2
+
(
h
->
picture_structure
!=
PICT_FRAME
)
+
(
2
*!
h
->
has_recovery_point
)
&&
pps_
ref_count
[
0
]
<=
2
+
(
h
->
picture_structure
!=
PICT_FRAME
)
+
(
2
*!
h
->
has_recovery_point
)
&&
h
->
cur_pic_ptr
->
f
->
pict_type
==
AV_PICTURE_TYPE_I
){
&&
h
->
cur_pic_ptr
->
f
->
pict_type
==
AV_PICTURE_TYPE_I
){
h
->
cur_pic_ptr
->
recovered
|=
1
;
h
->
cur_pic_ptr
->
recovered
|=
1
;
if
(
!
h
->
avctx
->
has_b_frames
)
if
(
!
h
->
avctx
->
has_b_frames
)
...
...
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