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
b965cb90
Commit
b965cb90
authored
Dec 26, 2012
by
Anton Khirnov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mimic: return meaningful error codes.
parent
a0cabd0a
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
25 additions
and
20 deletions
+25
-20
mimic.c
libavcodec/mimic.c
+25
-20
No files found.
libavcodec/mimic.c
View file @
b965cb90
...
@@ -112,14 +112,15 @@ static const uint8_t col_zag[64] = {
...
@@ -112,14 +112,15 @@ static const uint8_t col_zag[64] = {
static
av_cold
int
mimic_decode_init
(
AVCodecContext
*
avctx
)
static
av_cold
int
mimic_decode_init
(
AVCodecContext
*
avctx
)
{
{
MimicContext
*
ctx
=
avctx
->
priv_data
;
MimicContext
*
ctx
=
avctx
->
priv_data
;
int
ret
;
ctx
->
prev_index
=
0
;
ctx
->
prev_index
=
0
;
ctx
->
cur_index
=
15
;
ctx
->
cur_index
=
15
;
if
(
init_vlc
(
&
ctx
->
vlc
,
11
,
FF_ARRAY_ELEMS
(
huffbits
),
if
(
(
ret
=
init_vlc
(
&
ctx
->
vlc
,
11
,
FF_ARRAY_ELEMS
(
huffbits
),
huffbits
,
1
,
1
,
huffcodes
,
4
,
4
,
0
)
)
{
huffbits
,
1
,
1
,
huffcodes
,
4
,
4
,
0
))
<
0
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"error initializing vlc table
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"error initializing vlc table
\n
"
);
return
-
1
;
return
ret
;
}
}
ff_dsputil_init
(
&
ctx
->
dsp
,
avctx
);
ff_dsputil_init
(
&
ctx
->
dsp
,
avctx
);
ff_init_scantable
(
ctx
->
dsp
.
idct_permutation
,
&
ctx
->
scantable
,
col_zag
);
ff_init_scantable
(
ctx
->
dsp
.
idct_permutation
,
&
ctx
->
scantable
,
col_zag
);
...
@@ -198,16 +199,16 @@ static int vlc_decode_block(MimicContext *ctx, int num_coeffs, int qscale)
...
@@ -198,16 +199,16 @@ static int vlc_decode_block(MimicContext *ctx, int num_coeffs, int qscale)
vlc
=
get_vlc2
(
&
ctx
->
gb
,
ctx
->
vlc
.
table
,
ctx
->
vlc
.
bits
,
3
);
vlc
=
get_vlc2
(
&
ctx
->
gb
,
ctx
->
vlc
.
table
,
ctx
->
vlc
.
bits
,
3
);
if
(
!
vlc
)
/* end-of-block code */
if
(
!
vlc
)
/* end-of-block code */
return
1
;
if
(
vlc
==
-
1
)
return
0
;
return
0
;
if
(
vlc
==
-
1
)
return
AVERROR_INVALIDDATA
;
/* pos_add and num_bits are coded in the vlc code */
/* pos_add and num_bits are coded in the vlc code */
pos
+=
vlc
&
15
;
// pos_add
pos
+=
vlc
&
15
;
// pos_add
num_bits
=
vlc
>>
4
;
// num_bits
num_bits
=
vlc
>>
4
;
// num_bits
if
(
pos
>=
64
)
if
(
pos
>=
64
)
return
0
;
return
AVERROR_INVALIDDATA
;
value
=
get_bits
(
&
ctx
->
gb
,
num_bits
);
value
=
get_bits
(
&
ctx
->
gb
,
num_bits
);
...
@@ -223,13 +224,13 @@ static int vlc_decode_block(MimicContext *ctx, int num_coeffs, int qscale)
...
@@ -223,13 +224,13 @@ static int vlc_decode_block(MimicContext *ctx, int num_coeffs, int qscale)
block
[
ctx
->
scantable
.
permutated
[
pos
]]
=
coeff
;
block
[
ctx
->
scantable
.
permutated
[
pos
]]
=
coeff
;
}
}
return
1
;
return
0
;
}
}
static
int
decode
(
MimicContext
*
ctx
,
int
quality
,
int
num_coeffs
,
static
int
decode
(
MimicContext
*
ctx
,
int
quality
,
int
num_coeffs
,
int
is_iframe
)
int
is_iframe
)
{
{
int
y
,
x
,
plane
,
cur_row
=
0
;
int
ret
,
y
,
x
,
plane
,
cur_row
=
0
;
for
(
plane
=
0
;
plane
<
3
;
plane
++
)
{
for
(
plane
=
0
;
plane
<
3
;
plane
++
)
{
const
int
is_chroma
=
!!
plane
;
const
int
is_chroma
=
!!
plane
;
...
@@ -250,8 +251,12 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs,
...
@@ -250,8 +251,12 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs,
* frames preceding the previous. (get_bits1 == 1)
* frames preceding the previous. (get_bits1 == 1)
* Chroma planes don't use backreferences. */
* Chroma planes don't use backreferences. */
if
(
is_chroma
||
is_iframe
||
!
get_bits1
(
&
ctx
->
gb
))
{
if
(
is_chroma
||
is_iframe
||
!
get_bits1
(
&
ctx
->
gb
))
{
if
(
!
vlc_decode_block
(
ctx
,
num_coeffs
,
qscale
))
if
((
ret
=
vlc_decode_block
(
ctx
,
num_coeffs
,
return
0
;
qscale
))
<
0
)
{
av_log
(
ctx
->
avctx
,
AV_LOG_ERROR
,
"Error decoding "
"block.
\n
"
);
return
ret
;
}
ctx
->
dsp
.
idct_put
(
dst
,
stride
,
ctx
->
dct_block
);
ctx
->
dsp
.
idct_put
(
dst
,
stride
,
ctx
->
dct_block
);
}
else
{
}
else
{
unsigned
int
backref
=
get_bits
(
&
ctx
->
gb
,
4
);
unsigned
int
backref
=
get_bits
(
&
ctx
->
gb
,
4
);
...
@@ -285,7 +290,7 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs,
...
@@ -285,7 +290,7 @@ static int decode(MimicContext *ctx, int quality, int num_coeffs,
}
}
}
}
return
1
;
return
0
;
}
}
/**
/**
...
@@ -317,7 +322,7 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
...
@@ -317,7 +322,7 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
if
(
buf_size
<=
MIMIC_HEADER_SIZE
)
{
if
(
buf_size
<=
MIMIC_HEADER_SIZE
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"insufficient data
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"insufficient data
\n
"
);
return
-
1
;
return
AVERROR_INVALIDDATA
;
}
}
bytestream2_init
(
&
gb
,
buf
,
MIMIC_HEADER_SIZE
);
bytestream2_init
(
&
gb
,
buf
,
MIMIC_HEADER_SIZE
);
...
@@ -336,7 +341,7 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
...
@@ -336,7 +341,7 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
if
(
!
(
width
==
160
&&
height
==
120
)
&&
if
(
!
(
width
==
160
&&
height
==
120
)
&&
!
(
width
==
320
&&
height
==
240
))
{
!
(
width
==
320
&&
height
==
240
))
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"invalid width/height!
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"invalid width/height!
\n
"
);
return
-
1
;
return
AVERROR_INVALIDDATA
;
}
}
ctx
->
avctx
=
avctx
;
ctx
->
avctx
=
avctx
;
...
@@ -348,21 +353,21 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
...
@@ -348,21 +353,21 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
ctx
->
num_hblocks
[
i
]
=
width
>>
(
3
+
!!
i
);
ctx
->
num_hblocks
[
i
]
=
width
>>
(
3
+
!!
i
);
}
}
}
else
if
(
width
!=
ctx
->
avctx
->
width
||
height
!=
ctx
->
avctx
->
height
)
{
}
else
if
(
width
!=
ctx
->
avctx
->
width
||
height
!=
ctx
->
avctx
->
height
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"resolution changing is not supported
\n
"
);
av_log
_missing_feature
(
avctx
,
"resolution changing"
,
1
);
return
-
1
;
return
AVERROR_PATCHWELCOME
;
}
}
if
(
is_pframe
&&
!
ctx
->
buf_ptrs
[
ctx
->
prev_index
].
data
[
0
])
{
if
(
is_pframe
&&
!
ctx
->
buf_ptrs
[
ctx
->
prev_index
].
data
[
0
])
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"decoding must start with keyframe
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"decoding must start with keyframe
\n
"
);
return
-
1
;
return
AVERROR_INVALIDDATA
;
}
}
ctx
->
buf_ptrs
[
ctx
->
cur_index
].
reference
=
1
;
ctx
->
buf_ptrs
[
ctx
->
cur_index
].
reference
=
1
;
ctx
->
buf_ptrs
[
ctx
->
cur_index
].
pict_type
=
is_pframe
?
AV_PICTURE_TYPE_P
:
ctx
->
buf_ptrs
[
ctx
->
cur_index
].
pict_type
=
is_pframe
?
AV_PICTURE_TYPE_P
:
AV_PICTURE_TYPE_I
;
AV_PICTURE_TYPE_I
;
if
(
ff_thread_get_buffer
(
avctx
,
&
ctx
->
buf_ptrs
[
ctx
->
cur_index
])
)
{
if
(
(
res
=
ff_thread_get_buffer
(
avctx
,
&
ctx
->
buf_ptrs
[
ctx
->
cur_index
]))
<
0
)
{
av_log
(
avctx
,
AV_LOG_ERROR
,
"get_buffer() failed
\n
"
);
av_log
(
avctx
,
AV_LOG_ERROR
,
"get_buffer() failed
\n
"
);
return
-
1
;
return
res
;
}
}
ctx
->
next_prev_index
=
ctx
->
cur_index
;
ctx
->
next_prev_index
=
ctx
->
cur_index
;
...
@@ -384,10 +389,10 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
...
@@ -384,10 +389,10 @@ static int mimic_decode_frame(AVCodecContext *avctx, void *data,
res
=
decode
(
ctx
,
quality
,
num_coeffs
,
!
is_pframe
);
res
=
decode
(
ctx
,
quality
,
num_coeffs
,
!
is_pframe
);
ff_thread_report_progress
(
&
ctx
->
buf_ptrs
[
ctx
->
cur_index
],
INT_MAX
,
0
);
ff_thread_report_progress
(
&
ctx
->
buf_ptrs
[
ctx
->
cur_index
],
INT_MAX
,
0
);
if
(
!
res
)
{
if
(
res
<
0
)
{
if
(
!
(
avctx
->
active_thread_type
&
FF_THREAD_FRAME
))
{
if
(
!
(
avctx
->
active_thread_type
&
FF_THREAD_FRAME
))
{
ff_thread_release_buffer
(
avctx
,
&
ctx
->
buf_ptrs
[
ctx
->
cur_index
]);
ff_thread_release_buffer
(
avctx
,
&
ctx
->
buf_ptrs
[
ctx
->
cur_index
]);
return
-
1
;
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