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
a7b365ae
Commit
a7b365ae
authored
Nov 16, 2014
by
Anton Khirnov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
hevc: reduce code duplication in hls_prediction_unit()
parent
de1f8ead
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
51 additions
and
66 deletions
+51
-66
hevc.c
libavcodec/hevc.c
+51
-66
No files found.
libavcodec/hevc.c
View file @
a7b365ae
...
@@ -1652,88 +1652,73 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0,
...
@@ -1652,88 +1652,73 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0,
int
x_pu
,
y_pu
;
int
x_pu
,
y_pu
;
int
i
,
j
;
int
i
,
j
;
if
(
SAMPLE_CTB
(
s
->
skip_flag
,
x_cb
,
y_cb
))
{
int
skip_flag
=
SAMPLE_CTB
(
s
->
skip_flag
,
x_cb
,
y_cb
);
if
(
!
skip_flag
)
lc
->
pu
.
merge_flag
=
ff_hevc_merge_flag_decode
(
s
);
if
(
skip_flag
||
lc
->
pu
.
merge_flag
)
{
if
(
s
->
sh
.
max_num_merge_cand
>
1
)
if
(
s
->
sh
.
max_num_merge_cand
>
1
)
merge_idx
=
ff_hevc_merge_idx_decode
(
s
);
merge_idx
=
ff_hevc_merge_idx_decode
(
s
);
else
else
merge_idx
=
0
;
merge_idx
=
0
;
ff_hevc_luma_mv_merge_mode
(
s
,
x0
,
y0
,
ff_hevc_luma_mv_merge_mode
(
s
,
x0
,
y0
,
nPbW
,
nPbH
,
log2_cb_size
,
1
<<
log2_cb_size
,
partIdx
,
merge_idx
,
&
current_mv
);
1
<<
log2_cb_size
,
log2_cb_size
,
partIdx
,
merge_idx
,
&
current_mv
);
x_pu
=
x0
>>
s
->
sps
->
log2_min_pu_size
;
x_pu
=
x0
>>
s
->
sps
->
log2_min_pu_size
;
y_pu
=
y0
>>
s
->
sps
->
log2_min_pu_size
;
y_pu
=
y0
>>
s
->
sps
->
log2_min_pu_size
;
for
(
j
=
0
;
j
<
nPbH
>>
s
->
sps
->
log2_min_pu_size
;
j
++
)
for
(
j
=
0
;
j
<
nPbH
>>
s
->
sps
->
log2_min_pu_size
;
j
++
)
for
(
i
=
0
;
i
<
nPbW
>>
s
->
sps
->
log2_min_pu_size
;
i
++
)
for
(
i
=
0
;
i
<
nPbW
>>
s
->
sps
->
log2_min_pu_size
;
i
++
)
tab_mvf
[(
y_pu
+
j
)
*
min_pu_width
+
x_pu
+
i
]
=
current_mv
;
tab_mvf
[(
y_pu
+
j
)
*
min_pu_width
+
x_pu
+
i
]
=
current_mv
;
}
else
{
/* MODE_INTER */
}
else
{
lc
->
pu
.
merge_flag
=
ff_hevc_merge_flag_decode
(
s
);
enum
InterPredIdc
inter_pred_idc
=
PRED_L0
;
if
(
lc
->
pu
.
merge_flag
)
{
ff_hevc_set_neighbour_available
(
s
,
x0
,
y0
,
nPbW
,
nPbH
);
if
(
s
->
sh
.
max_num_merge_cand
>
1
)
if
(
s
->
sh
.
slice_type
==
B_SLICE
)
merge_idx
=
ff_hevc_merge_idx_decode
(
s
);
inter_pred_idc
=
ff_hevc_inter_pred_idc_decode
(
s
,
nPbW
,
nPbH
);
else
merge_idx
=
0
;
if
(
inter_pred_idc
!=
PRED_L1
)
{
if
(
s
->
sh
.
nb_refs
[
L0
])
{
ff_hevc_luma_mv_merge_mode
(
s
,
x0
,
y0
,
nPbW
,
nPbH
,
log2_cb_size
,
ref_idx
[
0
]
=
ff_hevc_ref_idx_lx_decode
(
s
,
s
->
sh
.
nb_refs
[
L0
]);
partIdx
,
merge_idx
,
&
current_mv
);
current_mv
.
ref_idx
[
0
]
=
ref_idx
[
0
];
x_pu
=
x0
>>
s
->
sps
->
log2_min_pu_size
;
y_pu
=
y0
>>
s
->
sps
->
log2_min_pu_size
;
for
(
j
=
0
;
j
<
nPbH
>>
s
->
sps
->
log2_min_pu_size
;
j
++
)
for
(
i
=
0
;
i
<
nPbW
>>
s
->
sps
->
log2_min_pu_size
;
i
++
)
tab_mvf
[(
y_pu
+
j
)
*
min_pu_width
+
x_pu
+
i
]
=
current_mv
;
}
else
{
enum
InterPredIdc
inter_pred_idc
=
PRED_L0
;
ff_hevc_set_neighbour_available
(
s
,
x0
,
y0
,
nPbW
,
nPbH
);
if
(
s
->
sh
.
slice_type
==
B_SLICE
)
inter_pred_idc
=
ff_hevc_inter_pred_idc_decode
(
s
,
nPbW
,
nPbH
);
if
(
inter_pred_idc
!=
PRED_L1
)
{
if
(
s
->
sh
.
nb_refs
[
L0
])
{
ref_idx
[
0
]
=
ff_hevc_ref_idx_lx_decode
(
s
,
s
->
sh
.
nb_refs
[
L0
]);
current_mv
.
ref_idx
[
0
]
=
ref_idx
[
0
];
}
current_mv
.
pred_flag
[
0
]
=
1
;
hls_mvd_coding
(
s
,
x0
,
y0
,
0
);
mvp_flag
[
0
]
=
ff_hevc_mvp_lx_flag_decode
(
s
);
ff_hevc_luma_mv_mvp_mode
(
s
,
x0
,
y0
,
nPbW
,
nPbH
,
log2_cb_size
,
partIdx
,
merge_idx
,
&
current_mv
,
mvp_flag
[
0
],
0
);
current_mv
.
mv
[
0
].
x
+=
lc
->
pu
.
mvd
.
x
;
current_mv
.
mv
[
0
].
y
+=
lc
->
pu
.
mvd
.
y
;
}
}
current_mv
.
pred_flag
[
0
]
=
1
;
if
(
inter_pred_idc
!=
PRED_L0
)
{
hls_mvd_coding
(
s
,
x0
,
y0
,
0
);
if
(
s
->
sh
.
nb_refs
[
L1
])
{
mvp_flag
[
0
]
=
ff_hevc_mvp_lx_flag_decode
(
s
);
ref_idx
[
1
]
=
ff_hevc_ref_idx_lx_decode
(
s
,
s
->
sh
.
nb_refs
[
L1
]);
ff_hevc_luma_mv_mvp_mode
(
s
,
x0
,
y0
,
nPbW
,
nPbH
,
log2_cb_size
,
current_mv
.
ref_idx
[
1
]
=
ref_idx
[
1
];
partIdx
,
merge_idx
,
&
current_mv
,
}
mvp_flag
[
0
],
0
);
current_mv
.
mv
[
0
].
x
+=
lc
->
pu
.
mvd
.
x
;
if
(
s
->
sh
.
mvd_l1_zero_flag
==
1
&&
inter_pred_idc
==
PRED_BI
)
{
current_mv
.
mv
[
0
].
y
+=
lc
->
pu
.
mvd
.
y
;
AV_ZERO32
(
&
lc
->
pu
.
mvd
);
}
}
else
{
hls_mvd_coding
(
s
,
x0
,
y0
,
1
);
if
(
inter_pred_idc
!=
PRED_L0
)
{
}
if
(
s
->
sh
.
nb_refs
[
L1
])
{
ref_idx
[
1
]
=
ff_hevc_ref_idx_lx_decode
(
s
,
s
->
sh
.
nb_refs
[
L1
]);
current_mv
.
pred_flag
[
1
]
=
1
;
current_mv
.
ref_idx
[
1
]
=
ref_idx
[
1
];
mvp_flag
[
1
]
=
ff_hevc_mvp_lx_flag_decode
(
s
);
ff_hevc_luma_mv_mvp_mode
(
s
,
x0
,
y0
,
nPbW
,
nPbH
,
log2_cb_size
,
partIdx
,
merge_idx
,
&
current_mv
,
mvp_flag
[
1
],
1
);
current_mv
.
mv
[
1
].
x
+=
lc
->
pu
.
mvd
.
x
;
current_mv
.
mv
[
1
].
y
+=
lc
->
pu
.
mvd
.
y
;
}
}
x_pu
=
x0
>>
s
->
sps
->
log2_min_pu_size
;
if
(
s
->
sh
.
mvd_l1_zero_flag
==
1
&&
inter_pred_idc
==
PRED_BI
)
{
y_pu
=
y0
>>
s
->
sps
->
log2_min_pu_size
;
AV_ZERO32
(
&
lc
->
pu
.
mvd
);
}
else
{
hls_mvd_coding
(
s
,
x0
,
y0
,
1
);
}
for
(
j
=
0
;
j
<
nPbH
>>
s
->
sps
->
log2_min_pu_size
;
j
++
)
current_mv
.
pred_flag
[
1
]
=
1
;
for
(
i
=
0
;
i
<
nPbW
>>
s
->
sps
->
log2_min_pu_size
;
i
++
)
mvp_flag
[
1
]
=
ff_hevc_mvp_lx_flag_decode
(
s
);
tab_mvf
[(
y_pu
+
j
)
*
min_pu_width
+
x_pu
+
i
]
=
current_mv
;
ff_hevc_luma_mv_mvp_mode
(
s
,
x0
,
y0
,
nPbW
,
nPbH
,
log2_cb_size
,
partIdx
,
merge_idx
,
&
current_mv
,
mvp_flag
[
1
],
1
);
current_mv
.
mv
[
1
].
x
+=
lc
->
pu
.
mvd
.
x
;
current_mv
.
mv
[
1
].
y
+=
lc
->
pu
.
mvd
.
y
;
}
}
x_pu
=
x0
>>
s
->
sps
->
log2_min_pu_size
;
y_pu
=
y0
>>
s
->
sps
->
log2_min_pu_size
;
for
(
j
=
0
;
j
<
nPbH
>>
s
->
sps
->
log2_min_pu_size
;
j
++
)
for
(
i
=
0
;
i
<
nPbW
>>
s
->
sps
->
log2_min_pu_size
;
i
++
)
tab_mvf
[(
y_pu
+
j
)
*
min_pu_width
+
x_pu
+
i
]
=
current_mv
;
}
}
if
(
current_mv
.
pred_flag
[
0
])
{
if
(
current_mv
.
pred_flag
[
0
])
{
...
...
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