播放jpeg时,avformat_find_stream_info出现以下问题,排查:

[jpeg_pipe @ 0x146a80] Could not find codec parameters for stream 0 (Video: mjpeg, none(bt470bg/unknown/unknown)): unspecified size
Consider increasing the value for the 'analyzeduration' and 'probesize' options

1. 打印开启的codec信息,发现mjpeg codec已经开启

AVCodec * av_codec = av_codec_next(NULL);
while(av_codec)
{
printf("codec name:%s\n", av_codec->name);
av_codec = av_codec_next(av_codec);
}

检查demux的支持哪些format状况

AVInputFormat *av_i = av_iformat_next(NULL);
while(av_i)
{
printf("name:%s\n", av_i->name);
av_i = av_iformat_next(av_i);
}

2. 阅读avformat_find_stream_info代码,在里面加log确认卡住的地方

发现has_codec_parameters()check失败导致,然后就追查avctx->width为何没有赋值。

  

3.发现read_frame_internal()调用出错,导致没有try decode。然后trace flow

4.iformat->read_packet(),format已经知道为jpeg_pipe,可惜搜不到相应的demuxer。

好像是这里,可惜搜不到函数。wav有ff_wav_demuxer,但是image_jpeg_pipe没有ff_image_jpeg_pipe的变量定义。

此时你已经知道自己掉坑里了,没事,习惯就好了。

void av_register_all(void)
{
//...
/* image demuxers */
REGISTER_DEMUXER (IMAGE_JPEG_PIPE, image_jpeg_pipe);
REGISTER_DEMUXER (IMAGE_JPEGLS_PIPE, image_jpegls_pipe);
//...
}

最后发现定义在img2dec.c中,别问我怎么找到的,_pipe这个字符串不是很特别嘛,虽然也很多。。。

#define IMAGEAUTO_DEMUXER(imgname, codecid)\
static const AVClass imgname ## _class = {\
.class_name = AV_STRINGIFY(imgname) " demuxer",\
.item_name = av_default_item_name,\
.option = ff_img_options,\
.version = LIBAVUTIL_VERSION_INT,\
};\
AVInputFormat ff_image_ ## imgname ## _pipe_demuxer = {\
.name = AV_STRINGIFY(imgname) "_pipe",\
.long_name = NULL_IF_CONFIG_SMALL("piped " AV_STRINGIFY(imgname) " sequence"),\
.priv_data_size = sizeof(VideoDemuxData),\
.read_probe = imgname ## _probe,\
.read_header = ff_img_read_header,\
.read_packet = ff_img_read_packet,\
.priv_class = & imgname ## _class,\
.flags = AVFMT_GENERIC_INDEX, \
.raw_codec_id = codecid,\
}; IMAGEAUTO_DEMUXER(bmp, AV_CODEC_ID_BMP)
IMAGEAUTO_DEMUXER(dds, AV_CODEC_ID_DDS)
IMAGEAUTO_DEMUXER(dpx, AV_CODEC_ID_DPX)
IMAGEAUTO_DEMUXER(exr, AV_CODEC_ID_EXR)
IMAGEAUTO_DEMUXER(j2k, AV_CODEC_ID_JPEG2000)
IMAGEAUTO_DEMUXER(jpeg, AV_CODEC_ID_MJPEG)
IMAGEAUTO_DEMUXER(jpegls, AV_CODEC_ID_JPEGLS)
IMAGEAUTO_DEMUXER(pictor, AV_CODEC_ID_PICTOR)
IMAGEAUTO_DEMUXER(png, AV_CODEC_ID_PNG)
IMAGEAUTO_DEMUXER(qdraw, AV_CODEC_ID_QDRAW)
IMAGEAUTO_DEMUXER(sgi, AV_CODEC_ID_SGI)
IMAGEAUTO_DEMUXER(sunrast, AV_CODEC_ID_SUNRAST)
IMAGEAUTO_DEMUXER(tiff, AV_CODEC_ID_TIFF)
IMAGEAUTO_DEMUXER(webp, AV_CODEC_ID_WEBP)

4. 进入ff_img_read_packet分析,这个流程图就不画了(因为网上没搜到)

原因很简单我的avio不能seek,所以size[0]为-38,然后packet new不出来,然后就少了一个螺丝钉,然后就打仗打输了。

所以问题点就是我的avio不能seek?what?

    } else {
f[] = s1->pb;
if (avio_feof(f[]) && s->loop && s->is_pipe)
avio_seek(f[], , SEEK_SET);
if (avio_feof(f[]))
return AVERROR_EOF;
if (s->frame_size > ) {
size[] = s->frame_size;
} else if (!s1->streams[]->parser) {
size[] = avio_size(s1->pb);//执行到这咯,size[0]为-38
} else {
size[] = ;
}
}
//这个报错了,res为-22
res = av_new_packet(pkt, size[] + size[] + size[]);

5. avio不能seek是由于,这个avio是定制的(说白了,自己写的,自己给自己挖坑)

AVIOContext *avio_alloc_context(
unsigned char *buffer,
int buffer_size,
int write_flag,
void *opaque,
int (*read_packet)(void *opaque, uint8_t *buf, int buf_size),
int (*write_packet)(void *opaque, uint8_t *buf, int buf_size),
int64_t (*seek)(void *opaque, int64_t offset, int whence)) //...
avio = avio_alloc_context(avio_ctx_buffer, avio_ctx_buffer_size,
, &bd, &read_bs, NULL, NULL);

6.当然如果故事就这样结束了,我也会很happy。同样的图片解码的code,在另一个平台用得好好的,但在这个平台却非要实现一个seek不可?

7.然后在另一个ok的平台上调试,发现走的flow不一样。

在另一个平台上是有相应的parser的。

    } else {
f[] = s1->pb;
if (avio_feof(f[]) && s->loop && s->is_pipe)
avio_seek(f[], , SEEK_SET);
if (avio_feof(f[]))
return AVERROR_EOF;
if (s->frame_size > ) {
size[] = s->frame_size;
} else if (!s1->streams[]->parser) {
size[] = avio_size(s1->pb);
} else {
size[] = ;//我是走这的,笨蛋
}
} res = av_new_packet(pkt, size[] + size[] + size[]);

8. 最终原因很简单,该平台的mjpeg的parse没有开....

9.找到原因就结束了吗?!当然不是,我们还要认真反思。(被老板发现,一分钟就可以开好的配置,具体调试了一天,分分钟被抽死)

第一步就检查了配置,而且是在代码里加code,这样太不方便了。

./configure就会打印到底开了哪些,如果一开始就仔细检查是不是就不用这么花时间调试了。(假装自己是老板,严厉呵斥该码农)

Enabled programs:
ffmpeg ffprobe ffserver External libraries:
iconv zlib External libraries providing hardware acceleration:
cuda cuvid nvenc Libraries:
avcodec avdevice avfilter avformat avutil swresample swscale Enabled decoders:
aac adpcm_yamaha cpia fourxm mdec on2avc pjs srt vp3 Enabled encoders:
a64multi ass ffv1 mjpeg pcm_alaw pcm_s64be prores_aw srt vorbis
a64multi5 Enabled parsers:
aac cavsvideo dpx dvdsub h261 mjpeg mpegvideo rv30 vorbis
aac_latm

10. 还有第十步,不说了,今晚又得加班了...

ffmpeg jpeg图片播放失败之问题排查的更多相关文章

  1. jquery图片播放切换插件

    点击这里查看效果可自定义数字样式和左右点击按钮 这个更好:移入按钮切换版本 更多图片轮播 以下是HTML文件代码: <!DOCTYPE html PUBLIC "-//W3C//DTD ...

  2. ijg库解码超大型jpeg图片

    1. ijg库解码超大型jpeg图片(>100M)的时候,如何避免内存溢出. 采用边解码边压缩的策略,每次解码一行或者若干行图片数据,然后对于这些解码的数据,进行DQT(量化处理,过滤掉高频的数 ...

  3. Slider.js轻量级图片播放控件

    Slider.js基于HTML5和CSS3实现的Slideshow 1.Slider.js 是一个图片播放Slideshow引擎,采用jQuery.CSS3和HTML5 canvas技术实现. 2.可 ...

  4. 基于Live555,ffmpeg的RTSP播放器直播与点播

    基于Live555,ffmpeg的RTSP播放器直播与点播 多路RTSP高清视频播放器下载地址:http://download.csdn.net/detail/u011352914/6604437多路 ...

  5. 渐进式jpeg(progressive jpeg)图片及其相关 --图片的两种加载方式

    渐进式jpeg(progressive jpeg)图片及其相关   一.基本JPEG(baseline jpeg)和渐进JPEG 网络上那些色色的照片都是.jpg格式的("色色"指 ...

  6. 分享8款精美的jQuery图片播放插件

    本文将和大家一起分享8款精美的jQuery图片播放插件,每一款插件均有演示和源码下载,有兴趣的朋友可以下载使用和研究.废话不多说了,直接上这些插件. 1.3D轮播相册 这款3D相册插件利用了HTML5 ...

  7. HTML5动画图片播放器 高端大气

    我们见过很多图片播放插件(焦点图),很多都基于jQuery.今天介绍的HTML5图片播放器很特别,它不仅在图片间切换有过渡动画效果,而且在切换时图片中的元素也将出现动画效果,比如图中的文字移动.打散. ...

  8. WPF技术触屏上的应用系列(四): 3D效果图片播放器(图片立体轮放、图片立体轮播、图片倒影立体滚动)效果实现

    原文:WPF技术触屏上的应用系列(四): 3D效果图片播放器(图片立体轮放.图片立体轮播.图片倒影立体滚动)效果实现 去年某客户单位要做个大屏触屏应用,要对档案资源进行展示之用.客户端是Window7 ...

  9. BMP图片转换为JPEG图片

    原文:BMP图片转换为JPEG图片 昨天在家学习,发现很多人把BMP图片转换为其它图片格式,有些人写得简单,有些人写得复杂. Insus.NET在想,一直在做文件上传,下载,或是图片剪切,都有进行过文 ...

随机推荐

  1. 20144303 《Java程序设计》第二次实验实验报告

    20144303 <Java程序设计>第二次实验实验报告 北京电子科技学院(besti)实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握U ...

  2. c++ 使用WinHTTP实现文件下载功能

    因为要项目中要想要实现一个软件自动更新的功能,之前是使用socket直接下载.但切换下载源的时候很麻烦.所以换用http方式. 网上找了很多资料,基本上就是下面几种: 1.curllib //功能强大 ...

  3. 【前端】javaScript 常用技巧总结

    javaScript 常用技巧总结 1.  彻底屏蔽鼠标右键  oncontextmenu="window.event.returnValue=false" <table b ...

  4. MapReduce 应用实例

    Hadoop 版本2.8.0 前期准备工作: 1. 设置用户环境变量 PATH 和 CLASSPATH 方便执行 Hadoop 命令时不用转移到对应的目录下,shell 除了会在当前目录下还会到 PA ...

  5. .net 下的 HttpRuntime.Cache 应用

    using System;using System.Collections.Generic;using System.Diagnostics;using System.Linq;using Syste ...

  6. 分页式存储管理方式AND请求分页式存储管理

    先说下什么是页(页面):就是将用户的程序的的地址空间分成固定大小的区域,称为”页“,或者”页面“ 之后将这些页离散的放进内存中,这样解决了内存的碎片问题 记得老师上课说了下这两个概念不能混,现在区分下 ...

  7. jQuery实际案例⑥——图片跟随鼠标、五角星评分案例

    一.图片跟随鼠标移动 1.要求:鼠标移动到哪,图片就要跟到哪 2.用到的事件:首先监听鼠标:$(document).mousemove(function(event){ }); //此时可以获取鼠标距 ...

  8. jQuery中兄弟元素、子元素和父元素的获取

    我们这里主要总结jQuery中对某元素的兄弟元素.子元素和父元素的获取,原声的Javascript代码对这些元素的获取比较麻烦一些,而jQuery正好对这些方法进行封装,让我们更加方便的对这些元素进行 ...

  9. vs2012 在调试或运行的过程中不能加断点

    在使用VS2012 的过程中,突然发现在调试的过程中,不能加断点,显示断点未能绑定.在搜寻了很多解决方案后未能解决,3.23这一天,重装了VS也没有用. 便想着把网上所有的方法都试个遍也要解决这个问题 ...

  10. 使用Easy4net编写代码生成器

    在项目中经常要手动创建和数据库对应的实体类,如果数据库表比较多或者表字段比较多,那会是一个工作量非常大的事情,所以我根据自己的需求写了一个简单的代码生成工具,工具使用Easy4net框架开发. 下面是 ...