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
42dd1434
Commit
42dd1434
authored
Jun 21, 2017
by
Ronald S. Bultje
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mdec: use correctly permutated quant matrix for dequantization.
parent
9e85c5d6
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
10 additions
and
1 deletion
+10
-1
mdec.c
libavcodec/mdec.c
+10
-1
No files found.
libavcodec/mdec.c
View file @
42dd1434
...
...
@@ -49,6 +49,7 @@ typedef struct MDECContext {
int
mb_height
;
int
mb_x
,
mb_y
;
DECLARE_ALIGNED
(
16
,
int16_t
,
block
)[
6
][
64
];
DECLARE_ALIGNED
(
16
,
uint16_t
,
quant_matrix
)[
64
];
uint8_t
*
bitstream_buffer
;
unsigned
int
bitstream_buffer_size
;
int
block_last_index
[
6
];
...
...
@@ -61,7 +62,7 @@ static inline int mdec_decode_block_intra(MDECContext *a, int16_t *block, int n)
int
component
;
RLTable
*
rl
=
&
ff_rl_mpeg1
;
uint8_t
*
const
scantable
=
a
->
scantable
.
permutated
;
const
uint16_t
*
quant_matrix
=
ff_mpeg1_default_intra
_matrix
;
const
uint16_t
*
quant_matrix
=
a
->
quant
_matrix
;
const
int
qscale
=
a
->
qscale
;
/* DC coefficient */
...
...
@@ -212,6 +213,7 @@ static int decode_frame(AVCodecContext *avctx,
static
av_cold
int
decode_init
(
AVCodecContext
*
avctx
)
{
MDECContext
*
const
a
=
avctx
->
priv_data
;
int
i
;
if
(
avctx
->
idct_algo
==
FF_IDCT_AUTO
)
avctx
->
idct_algo
=
FF_IDCT_SIMPLE
;
...
...
@@ -231,6 +233,13 @@ static av_cold int decode_init(AVCodecContext *avctx)
avctx
->
pix_fmt
=
AV_PIX_FMT_YUVJ420P
;
avctx
->
color_range
=
AVCOL_RANGE_JPEG
;
/* init q matrix */
for
(
i
=
0
;
i
<
64
;
i
++
)
{
int
j
=
a
->
idsp
.
idct_permutation
[
i
];
a
->
quant_matrix
[
j
]
=
ff_mpeg1_default_intra_matrix
[
i
];
}
return
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