Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
af122d6a
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,发现更多精彩内容 >>
提交
af122d6a
编写于
6月 25, 2009
作者:
B
Baptiste Coudurier
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
limit raw packet buffer size used for codec probing
Originally committed as revision 19272 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
57f6d52a
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
19 addition
and
3 deletion
+19
-3
libavformat/avformat.h
libavformat/avformat.h
+9
-2
libavformat/utils.c
libavformat/utils.c
+10
-1
未找到文件。
libavformat/avformat.h
浏览文件 @
af122d6a
...
...
@@ -22,8 +22,8 @@
#define AVFORMAT_AVFORMAT_H
#define LIBAVFORMAT_VERSION_MAJOR 52
#define LIBAVFORMAT_VERSION_MINOR 3
4
#define LIBAVFORMAT_VERSION_MICRO
1
#define LIBAVFORMAT_VERSION_MINOR 3
5
#define LIBAVFORMAT_VERSION_MICRO
0
#define LIBAVFORMAT_VERSION_INT AV_VERSION_INT(LIBAVFORMAT_VERSION_MAJOR, \
LIBAVFORMAT_VERSION_MINOR, \
...
...
@@ -638,6 +638,13 @@ typedef struct AVFormatContext {
struct
AVPacketList
*
packet_buffer_end
;
AVMetadata
*
metadata
;
/**
* Remaining size available for raw_packet_buffer, in bytes.
* NOT PART OF PUBLIC API
*/
#define RAW_PACKET_BUFFER_SIZE 32000
int
raw_packet_buffer_remaining_size
;
}
AVFormatContext
;
typedef
struct
AVPacketList
{
...
...
libavformat/utils.c
浏览文件 @
af122d6a
...
...
@@ -401,6 +401,8 @@ int av_open_input_stream(AVFormatContext **ic_ptr,
ff_metadata_demux_compat
(
ic
);
#endif
ic
->
raw_packet_buffer_remaining_size
=
RAW_PACKET_BUFFER_SIZE
;
*
ic_ptr
=
ic
;
return
0
;
fail:
...
...
@@ -532,8 +534,13 @@ int av_read_packet(AVFormatContext *s, AVPacket *pkt)
if
(
pktl
)
{
*
pkt
=
pktl
->
pkt
;
if
(
s
->
streams
[
pkt
->
stream_index
]
->
codec
->
codec_id
!=
CODEC_ID_PROBE
||
!
s
->
streams
[
pkt
->
stream_index
]
->
probe_packets
){
!
s
->
streams
[
pkt
->
stream_index
]
->
probe_packets
||
s
->
raw_packet_buffer_remaining_size
<
pkt
->
size
){
AVProbeData
*
pd
=
&
s
->
streams
[
pkt
->
stream_index
]
->
probe_data
;
av_freep
(
&
pd
->
buf
);
pd
->
buf_size
=
0
;
s
->
raw_packet_buffer
=
pktl
->
next
;
s
->
raw_packet_buffer_remaining_size
+=
pkt
->
size
;
av_free
(
pktl
);
return
0
;
}
...
...
@@ -567,6 +574,7 @@ int av_read_packet(AVFormatContext *s, AVPacket *pkt)
return
ret
;
add_to_pktbuf
(
&
s
->
raw_packet_buffer
,
pkt
,
&
s
->
raw_packet_buffer_end
);
s
->
raw_packet_buffer_remaining_size
-=
pkt
->
size
;
if
(
st
->
codec
->
codec_id
==
CODEC_ID_PROBE
){
AVProbeData
*
pd
=
&
st
->
probe_data
;
...
...
@@ -1102,6 +1110,7 @@ static void flush_packet_queue(AVFormatContext *s)
av_free_packet
(
&
pktl
->
pkt
);
av_free
(
pktl
);
}
s
->
raw_packet_buffer_remaining_size
=
RAW_PACKET_BUFFER_SIZE
;
}
/*******************************************************/
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录