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
cf62f2d2
Commit
cf62f2d2
authored
Apr 30, 2015
by
Ronald S. Bultje
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
vp9: more specifically specify mask destination to mask_edges().
parent
f052ea6b
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
26 deletions
+26
-26
vp9.c
libavcodec/vp9.c
+26
-26
No files found.
libavcodec/vp9.c
View file @
cf62f2d2
...
@@ -2853,7 +2853,7 @@ static void inter_recon(AVCodecContext *ctx)
...
@@ -2853,7 +2853,7 @@ static void inter_recon(AVCodecContext *ctx)
}
}
}
}
static
av_always_inline
void
mask_edges
(
struct
VP9Filter
*
lflvl
,
int
is_uv
,
static
av_always_inline
void
mask_edges
(
uint8_t
(
*
mask
)[
8
][
4
]
,
int
is_uv
,
int
row_and_7
,
int
col_and_7
,
int
row_and_7
,
int
col_and_7
,
int
w
,
int
h
,
int
col_end
,
int
row_end
,
int
w
,
int
h
,
int
col_end
,
int
row_end
,
enum
TxfmMode
tx
,
int
skip_inter
)
enum
TxfmMode
tx
,
int
skip_inter
)
...
@@ -2894,8 +2894,8 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
...
@@ -2894,8 +2894,8 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
int
col_mask_id
=
2
-
!
(
y
&
7
);
int
col_mask_id
=
2
-
!
(
y
&
7
);
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
1
]
|=
m_row_8
;
mask
[
0
][
y
][
1
]
|=
m_row_8
;
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
2
]
|=
m_row_4
;
mask
[
0
][
y
][
2
]
|=
m_row_4
;
// for odd lines, if the odd col is not being filtered,
// for odd lines, if the odd col is not being filtered,
// skip odd row also:
// skip odd row also:
// .---. <-- a
// .---. <-- a
...
@@ -2907,9 +2907,9 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
...
@@ -2907,9 +2907,9 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
// if a/c are even row/col and b/d are odd, and d is skipped,
// if a/c are even row/col and b/d are odd, and d is skipped,
// e.g. right edge of size-66x66.webm, then skip b also (bug)
// e.g. right edge of size-66x66.webm, then skip b also (bug)
if
((
col_end
&
1
)
&&
(
y
&
1
))
{
if
((
col_end
&
1
)
&&
(
y
&
1
))
{
lflvl
->
mask
[
is_uv
]
[
1
][
y
][
col_mask_id
]
|=
m_col_odd
;
mask
[
1
][
y
][
col_mask_id
]
|=
m_col_odd
;
}
else
{
}
else
{
lflvl
->
mask
[
is_uv
]
[
1
][
y
][
col_mask_id
]
|=
m_col
;
mask
[
1
][
y
][
col_mask_id
]
|=
m_col
;
}
}
}
}
}
else
{
}
else
{
...
@@ -2918,11 +2918,11 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
...
@@ -2918,11 +2918,11 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
int
col_mask_id
=
2
-
!
(
y
&
3
);
int
col_mask_id
=
2
-
!
(
y
&
3
);
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
1
]
|=
m_row_8
;
// row edge
mask
[
0
][
y
][
1
]
|=
m_row_8
;
// row edge
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
2
]
|=
m_row_4
;
mask
[
0
][
y
][
2
]
|=
m_row_4
;
lflvl
->
mask
[
is_uv
]
[
1
][
y
][
col_mask_id
]
|=
m_col
;
// col edge
mask
[
1
][
y
][
col_mask_id
]
|=
m_col
;
// col edge
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
3
]
|=
m_col
;
mask
[
0
][
y
][
3
]
|=
m_col
;
lflvl
->
mask
[
is_uv
]
[
1
][
y
][
3
]
|=
m_col
;
mask
[
1
][
y
][
3
]
|=
m_col
;
}
}
}
}
}
else
{
}
else
{
...
@@ -2941,47 +2941,47 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
...
@@ -2941,47 +2941,47 @@ static av_always_inline void mask_edges(struct VP9Filter *lflvl, int is_uv,
int
m_row_8
=
m_row
-
m_row_16
;
int
m_row_8
=
m_row
-
m_row_16
;
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
0
]
|=
m_row_16
;
mask
[
0
][
y
][
0
]
|=
m_row_16
;
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
1
]
|=
m_row_8
;
mask
[
0
][
y
][
1
]
|=
m_row_8
;
}
}
}
else
{
}
else
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
mask_id
]
|=
m_row
;
mask
[
0
][
y
][
mask_id
]
|=
m_row
;
}
}
if
(
is_uv
&&
tx
>
TX_8X8
&&
(
h
^
(
h
-
1
))
==
1
)
{
if
(
is_uv
&&
tx
>
TX_8X8
&&
(
h
^
(
h
-
1
))
==
1
)
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
-
1
;
y
+=
step1d
)
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
-
1
;
y
+=
step1d
)
lflvl
->
mask
[
is_uv
]
[
1
][
y
][
0
]
|=
m_col
;
mask
[
1
][
y
][
0
]
|=
m_col
;
if
(
y
-
row_and_7
==
h
-
1
)
if
(
y
-
row_and_7
==
h
-
1
)
lflvl
->
mask
[
is_uv
]
[
1
][
y
][
1
]
|=
m_col
;
mask
[
1
][
y
][
1
]
|=
m_col
;
}
else
{
}
else
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
+=
step1d
)
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
+=
step1d
)
lflvl
->
mask
[
is_uv
]
[
1
][
y
][
mask_id
]
|=
m_col
;
mask
[
1
][
y
][
mask_id
]
|=
m_col
;
}
}
}
else
if
(
tx
!=
TX_4X4
)
{
}
else
if
(
tx
!=
TX_4X4
)
{
int
mask_id
;
int
mask_id
;
mask_id
=
(
tx
==
TX_8X8
)
||
(
is_uv
&&
h
==
1
);
mask_id
=
(
tx
==
TX_8X8
)
||
(
is_uv
&&
h
==
1
);
lflvl
->
mask
[
is_uv
]
[
1
][
row_and_7
][
mask_id
]
|=
m_col
;
mask
[
1
][
row_and_7
][
mask_id
]
|=
m_col
;
mask_id
=
(
tx
==
TX_8X8
)
||
(
is_uv
&&
w
==
1
);
mask_id
=
(
tx
==
TX_8X8
)
||
(
is_uv
&&
w
==
1
);
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
mask_id
]
|=
t
;
mask
[
0
][
y
][
mask_id
]
|=
t
;
}
else
if
(
is_uv
)
{
}
else
if
(
is_uv
)
{
int
t8
=
t
&
0x01
,
t4
=
t
-
t8
;
int
t8
=
t
&
0x01
,
t4
=
t
-
t8
;
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
2
]
|=
t4
;
mask
[
0
][
y
][
2
]
|=
t4
;
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
1
]
|=
t8
;
mask
[
0
][
y
][
1
]
|=
t8
;
}
}
lflvl
->
mask
[
is_uv
]
[
1
][
row_and_7
][
2
-
!
(
row_and_7
&
7
)]
|=
m_col
;
mask
[
1
][
row_and_7
][
2
-
!
(
row_and_7
&
7
)]
|=
m_col
;
}
else
{
}
else
{
int
t8
=
t
&
0x11
,
t4
=
t
-
t8
;
int
t8
=
t
&
0x11
,
t4
=
t
-
t8
;
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
for
(
y
=
row_and_7
;
y
<
h
+
row_and_7
;
y
++
)
{
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
2
]
|=
t4
;
mask
[
0
][
y
][
2
]
|=
t4
;
lflvl
->
mask
[
is_uv
]
[
0
][
y
][
1
]
|=
t8
;
mask
[
0
][
y
][
1
]
|=
t8
;
}
}
lflvl
->
mask
[
is_uv
]
[
1
][
row_and_7
][
2
-
!
(
row_and_7
&
3
)]
|=
m_col
;
mask
[
1
][
row_and_7
][
2
-
!
(
row_and_7
&
3
)]
|=
m_col
;
}
}
}
}
}
}
...
@@ -3131,9 +3131,9 @@ static void decode_b(AVCodecContext *ctx, int row, int col,
...
@@ -3131,9 +3131,9 @@ static void decode_b(AVCodecContext *ctx, int row, int col,
int
skip_inter
=
!
b
->
intra
&&
b
->
skip
,
col7
=
s
->
col7
,
row7
=
s
->
row7
;
int
skip_inter
=
!
b
->
intra
&&
b
->
skip
,
col7
=
s
->
col7
,
row7
=
s
->
row7
;
setctx_2d
(
&
lflvl
->
level
[
row7
*
8
+
col7
],
w4
,
h4
,
8
,
lvl
);
setctx_2d
(
&
lflvl
->
level
[
row7
*
8
+
col7
],
w4
,
h4
,
8
,
lvl
);
mask_edges
(
lflvl
,
0
,
row7
,
col7
,
x_end
,
y_end
,
0
,
0
,
b
->
tx
,
skip_inter
);
mask_edges
(
lflvl
->
mask
[
0
]
,
0
,
row7
,
col7
,
x_end
,
y_end
,
0
,
0
,
b
->
tx
,
skip_inter
);
if
(
s
->
ss_h
||
s
->
ss_v
)
if
(
s
->
ss_h
||
s
->
ss_v
)
mask_edges
(
lflvl
,
1
,
row7
,
col7
,
x_end
,
y_end
,
mask_edges
(
lflvl
->
mask
[
1
]
,
1
,
row7
,
col7
,
x_end
,
y_end
,
s
->
cols
&
1
&&
col
+
w4
>=
s
->
cols
?
s
->
cols
&
7
:
0
,
s
->
cols
&
1
&&
col
+
w4
>=
s
->
cols
?
s
->
cols
&
7
:
0
,
s
->
rows
&
1
&&
row
+
h4
>=
s
->
rows
?
s
->
rows
&
7
:
0
,
s
->
rows
&
1
&&
row
+
h4
>=
s
->
rows
?
s
->
rows
&
7
:
0
,
b
->
uvtx
,
skip_inter
);
b
->
uvtx
,
skip_inter
);
...
...
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