Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
ee50a7c1
F
Ffmpeg
项目概览
小白菜888
/
Ffmpeg
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
Ffmpeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ee50a7c1
编写于
11月 14, 2006
作者:
M
Michael Niedermayer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
making decoding more error robust
Originally committed as revision 7073 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
7e5f82dc
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
11 deletion
+19
-11
libavcodec/mpegaudiodec.c
libavcodec/mpegaudiodec.c
+19
-11
未找到文件。
libavcodec/mpegaudiodec.c
浏览文件 @
ee50a7c1
...
...
@@ -1748,8 +1748,7 @@ static int huffman_decode(MPADecodeContext *s, GranuleDef *g,
bits_left
=
end_pos
-
get_bits_count
(
&
s
->
gb
);
//av_log(NULL, AV_LOG_ERROR, "left:%d buf:%p\n", bits_left, s->in_gb.buffer);
if
(
bits_left
<
0
)
{
dprintf
(
"bits_left=%d
\n
"
,
bits_left
);
return
-
1
;
av_log
(
NULL
,
AV_LOG_ERROR
,
"bits_left=%d
\n
"
,
bits_left
);
}
skip_bits_long
(
&
s
->
gb
,
bits_left
);
...
...
@@ -2274,20 +2273,28 @@ static int mp_decode_layer3(MPADecodeContext *s)
/* now we get bits from the main_data_begin offset */
dprintf
(
"seekback: %d
\n
"
,
main_data_begin
);
//av_log(NULL, AV_LOG_ERROR, "backstep:%d, lastbuf:%d\n", main_data_begin, s->last_buf_size);
if
(
main_data_begin
>
s
->
last_buf_size
){
av_log
(
NULL
,
AV_LOG_ERROR
,
"backstep:%d, lastbuf:%d
\n
"
,
main_data_begin
,
s
->
last_buf_size
);
// s->last_buf_size= main_data_begin;
return
-
1
;
}
memcpy
(
s
->
last_buf
+
s
->
last_buf_size
,
ptr
,
EXTRABYTES
);
s
->
in_gb
=
s
->
gb
;
init_get_bits
(
&
s
->
gb
,
s
->
last_buf
+
s
->
last_buf_size
-
main_data_begin
,
main_data_begin
*
8
);
init_get_bits
(
&
s
->
gb
,
s
->
last_buf
,
s
->
last_buf_size
*
8
);
skip_bits_long
(
&
s
->
gb
,
8
*
(
s
->
last_buf_size
-
main_data_begin
));
}
for
(
gr
=
0
;
gr
<
nb_granules
;
gr
++
)
{
for
(
ch
=
0
;
ch
<
s
->
nb_channels
;
ch
++
)
{
g
=
&
granules
[
ch
][
gr
];
if
(
get_bits_count
(
&
s
->
gb
)
<
0
){
av_log
(
NULL
,
AV_LOG_ERROR
,
"mdb:%d, lastbuf:%d skiping granule %d
\n
"
,
main_data_begin
,
s
->
last_buf_size
,
gr
);
skip_bits_long
(
&
s
->
gb
,
g
->
part2_3_length
);
memset
(
g
->
sb_hybrid
,
0
,
sizeof
(
g
->
sb_hybrid
));
if
(
get_bits_count
(
&
s
->
gb
)
>=
s
->
gb
.
size_in_bits
&&
s
->
in_gb
.
buffer
){
skip_bits_long
(
&
s
->
in_gb
,
get_bits_count
(
&
s
->
gb
)
-
s
->
gb
.
size_in_bits
);
s
->
gb
=
s
->
in_gb
;
s
->
in_gb
.
buffer
=
NULL
;
}
continue
;
}
bits_pos
=
get_bits_count
(
&
s
->
gb
);
...
...
@@ -2418,9 +2425,7 @@ static int mp_decode_layer3(MPADecodeContext *s)
exponents_from_scale_factors
(
s
,
g
,
exponents
);
/* read Huffman coded residue */
if
(
huffman_decode
(
s
,
g
,
exponents
,
bits_pos
+
g
->
part2_3_length
)
<
0
)
return
-
1
;
huffman_decode
(
s
,
g
,
exponents
,
bits_pos
+
g
->
part2_3_length
);
#if defined(DEBUG)
sample_dump
(
0
,
g
->
sb_hybrid
,
576
);
#endif
...
...
@@ -2446,6 +2451,8 @@ static int mp_decode_layer3(MPADecodeContext *s)
#endif
}
}
/* gr */
if
(
get_bits_count
(
&
s
->
gb
)
<
0
)
skip_bits_long
(
&
s
->
gb
,
-
get_bits_count
(
&
s
->
gb
));
return
nb_granules
*
18
;
}
...
...
@@ -2483,6 +2490,7 @@ static int mp_decode_frame(MPADecodeContext *s,
}
else
av_log
(
NULL
,
AV_LOG_ERROR
,
"invalid old backstep %d
\n
"
,
i
);
s
->
gb
=
s
->
in_gb
;
s
->
in_gb
.
buffer
=
NULL
;
}
align_get_bits
(
&
s
->
gb
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录