流程图
//1.使用AVCodec初始化AVCodecContext
//2.此方法线程不安全
int avcodec_open2(AVCodecContext *avctx, const AVCodec *codec, AVDictionary **options);
主要做了一下工作:
- 通过
s->internal
是否为空来判断Codec是否已经打开了,不会重复打开。 - 创建AVCodecContext私有的AVCodecInternal,以供内部使用
- 为AVCodecInternal内部成员变量分配内存及赋初始值
- 使用AVCodec.name匹配白名单,是否在白名单中
(既然白名单匹配不到就返回失败,为什么不提前判断,而是在申请了一堆内存后才进行白名单校验???)
- 针对H.264/VP6F/DXV进行了特殊处理,看逻辑主要是判断是否越界,越界后中断操作,
释放资源,这几种格式有什么特殊之处?
- 对于非H.264/VP6F/DXV格式,判断宽高是否越界,越界后置为0。
- 校验channels、sample_rate、block_align
- 检查是否是自定义codec
- 校验AVCodecContext中设定的pix_fmt是否存在
- 调用AVCodec的init接口函数指针,如h264格式会调用到X264_init()
- 流程中有任何异常都会调用
goto free_and_end
释放资源,正常执行结束会直接return。
avcodec_close
avcodec_close与avcodec_open是反向操作,主要就是释放操作。
调用AVCodec的close方法,如最终调用的是实例化的libx264的x264_encoder_close()