- 收藏
- 点赞
- 分享
- 举报
最新版本mplayer移植pxa270成功
1.下载新版本的mplayer,方法可以参见其他版本的README
cvs -z3 -d:pserver:anonymous@mplayerhq.hu:/cvsroot/mplayer co -P main
下载libavcodec和libavutil,方法
cvs -z3 -d:pserver:anonymous@mplayerhq.hu:/cvsroot/ffmpeg co ffmpeg
下载的目录中有两个子目录,libavutil和libavcodec,然后把这两个目录拷到Mplayer目录下
note:如果是再wincvs下载的话,要把configure和version.sh用linux自带的工具dos2unix转换一下
2.在mplayer主目录下新建一个脚本文件build-arm.sh,主要是写configure设置,内容如下:
#!/bin/sh
./configure --cc=arm-linux-gcc \
--host-cc=gcc \
--enable-cross-compile \
--target=arm-armv4l-linux \
--enable-linux-devfs \
--disable-win32 \
--disable-dvdread \
--enable-fbdev \
--disable-mencoder \
--enable-libavcodec \
--enable-liba52 \
--disable-libmpeg2 \
--enable-liba52 \
--disable-mp3lib \
--enable-static
--disable-live 2>&1 | tee logfile
--with-extraincdir=/opt/crosstool/arm-linux/arm-linux/include\
--with-extralibdir=/opt/crosstool/arm-linux/arm-linux/lib \
下面部分参考网上的资料
--cc=arm-linux-gcc设置交叉编译器
--host-cc=gcc是用来编译一些需要在host上执行的中间文件的,如codec-cfg,切记不能少了或搞错了!网上的《mplayer在ARM9(s3c2410)上的移植》(以下简称《移》文)一文介绍说遇到提示codec-cfg不能被执行出错时的解决方法是先将codec-cfg编译成i386平台的在再这里停下来时用i386的codec-cfg替代从而使编译继续。通过实验设置了这个参数就不用那么麻烦了,而且整个过程也显得比较幽雅了。
--enable-cross-compile ,允许交叉编译,我是看./configure --help中有这个选项,所以就加入了,对编译有没有影响还不是很清楚.
--enable-linux-devfs set default devices to devfs ones,configure中是这么解释的,具体的含义还不是很清楚,不过这个跟编译有很大的影响,如果没有加上这个选项,在pxa270平台上不能正常运行程序,不能显示.
--target=arm-armv4l-linux这个参数要注意的是一个分三部分,第一部分的arm是指arch,这里设定为arm;第二部分的armv4l是指具体的版本,这个要注意了,一定要跟libavcodec目录下的平台目录名一致,否则为这个平台的优化代码没办法编译进去;第三部分是系统平台。这个主要是用在libavcodec的编译中,libavcodec下面支持很多平台,比如i386,armv4l,ppc,sh,...,你进入libavcodec的目录下就可以看见这些 子目录,里面分别存放跟这些平台相关的优化汇编代码,我们所用的平台是xscale pxa270,跟arm是兼容的 ,所以设置为armv4l,当然在编译的过程中还可以设置为iwmmxt,因为270平台支持无线mmx指令.在这个实验中,我们没有加入.
--enable-static是设定静态连接,不需要一堆乱七八糟的动态库,尤其对我们这些新手来说省了很多的麻烦。如果设置了这个参数就不用设置—divfix了,另外也不用执行make install。
最后的一个2>&1 | tee logfile意思是将执行的情况在输出到屏幕的同时记录到logfile文件中,在控制台下编译比较有用。
剩余的几个参数没什么好介绍的了,记住--disable-mencoder要加上,mencoder在这里编译会有问题,还没有时间去研究呢。如果不清楚其它的参数的意思自己看configure文件(参考help_config)吧,里面都有介绍。(参考,反正mencoder也没什么用,对于解码)
3.接下来心惊肉跳的时刻来了,编译过程是移植中最考验心脏的.有时一个错误出现都让人头痛不已,我也是反反复复经过了好多此编译才成功,具体步骤如下,我所用的编译器是博创提供的交叉编译工具, arm-linux-gcc 3.4.3版本的.具体在交叉编译的编译步骤我也不是很清楚,可以用arm-linux-gcc -v来查看
./build-arm.sh #先将这个文件改成可执行,chmod +x build-arm.sh make
make过程是很漫长的,主要是我们在configure的时候没有把一些没用的codec给disable掉,我在编译的过程中出现了两个错误,第一个错误是在dsputil.c中出现了arm-linux-gcc bug,我后来找到出错的地方,找了一下这个函数的使用情况,直接把函数主体部分给#if 0 #endif 掉了.这个当然是不提倡的做法,但实在找不出错误的原因.
第二个错误是也是同样的.只不果出错的地方在../libaf/af.c中,这个错误在mplayer发布版的编译过程中没有出现,于是我就着到了那个版本中的这个文件,对比发现基本上一致,于是把那边的程序拷贝到这个函数中.再去掉一些参数.如果这个函数没有正确定义,音频解码部分会出错. 好了,大功告成,程序编译能够通过.ll mplayer 发现有5M多.
4.到了最紧张的时候了,在minicom下../mplayer /mnt/yaffs/mm/xyt.avi,8''液晶屏上出现<<逍遥叹>>的画面和声音,ok!
到这里,说明移植过程没有什么问题了,但是对于H.264的视频是否可以流畅播放还得验证.因为在Mplayer 1.0发布版中发现播放.mkv和H.264文件出现内存出错,这应该是程序的问题.最新的版本中不知道有没有改进.
./mplayer test.264.avi 可以播放,而且fps还可以,具体达到多少不是很清楚
./mplayer gudan.mkv 可以播放,但视频部分解码明显没有达到25fps,画面落后声音很多
./mplayer Shivi.avi //D1(720X480)分辨率,DIVX,mplayer出现提示
************************************************
**** Your system is too SLOW to play this! ****
************************************************
Possible reasons, problems, workarounds:
- Most common: broken/buggy _audio_ driver
- Try -ao sdl or use the OSS emulation of ALSA.
- Experiment with different values for -autosync, 30 is a good start.
- Slow video output
- Try a different -vo driver (-vo help for a list) or try -framedrop!
- Slow CPU
- Don't try to play a big DVD/DivX on a slow CPU! Try some of the lavdopts,
e.g. -vfm ffmpeg -lavdopts lowres=1:fast:skiploopfilter=all.
- Broken file
- Try various combinations of -nobps -ni -forceidx -mc 0.
- Slow media (NFS/SMB mounts, DVD, VCD etc)
- Try -cache 8192.
- Are you using -cache to play a non-interleaved AVI file?
- Try -nocache.
看来解码速度还是有待提高,主要是因为这个基本上是c代码,arm汇编代码占的比重很小,另外nfs可能对速度有一定的影响. 今天拿到一个博创PXA270A开发板,但是随机光盘挂掉了,新的光盘至少要等待下周,所以自己尝试搭建了一个交叉编译环境。 在google上找了一天,大部分的交叉编译环境搭建方法并不适用于此开发板。最后,终于发现了一个开源项目crosstool,利用此工具可以轻松搭建XScale,ARM7-ARM9,MK6800,POWERPC等环境的交叉编译环境。通过执行不同的脚本,会自动下载并编译,最终形成可用的开发套件。
crosstool可以在下面的网站找到,并有较为详细的文档 www.kegel.com/crosstool/
在成功的搭建平台后,尝试着交叉编译MPlayer 按以下方式执行configure
./configure --host-cc=gcc --cc=arm-xscale-linux-gnu-gcc --target=arm-armv4l-linux --enable-static --prefix=/tmp/mplayer --disable-dvdread --enable-fbdev --disable-mencoder --disable-dvdread-internal --disable-live 2>&1 | tee logfile
注意,网上的大多数方法没有--disable-dvdread-internal选项而有--disbale-win32选项,但是我这样编译时回有错误,于是去掉了--disable-win32加入了--disable-dvdread-internal 可以成功的得到mplayer的静态编译执行文件,移植到开发板上即可。
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
-
2019-01-03 13:59:05
-
2015-06-15 10:32:35
-
2016-04-18 15:57:11
-
2017-01-20 13:39:46
-
2018-07-04 10:17:56
-
2020-05-20 15:38:13
-
2020-09-29 14:27:25
-
2013-11-29 22:39:01
-
2023-02-24 23:11:25
-
2020-12-01 16:39:21
-
2016-10-07 15:59:18
-
2016-02-18 21:51:06
-
2019-01-08 16:32:23
-
2018-09-21 09:02:57
-
2021-01-14 17:33:49
-
2019-12-20 09:45:14
-
2015-08-11 16:00:38
-
2018-01-15 09:42:43
-
2022-10-13 10:47:58
-
5cat /dev/logmpp 报错 <3>[ vi] [func]:vi_send_frame_node [line]:99 [info]:vi pic queue is full!
-
50如何获取vpss chn的图像修改后发送至vo
-
5FPGA通过Bt1120传YUV422数据过来,vi接收不到数据——3516dv500
-
50SS928 运行PQtools 拼接 推到设备里有一半画面会异常
-
53536AV100的sample_vdec输出到CVBS显示
-
10海思板子mpp怎么在vi阶段改变视频数据尺寸
-
10HI3559AV100 多摄像头同步模式
-
9海思ss928单路摄像头vio中加入opencv处理并显示
-
10EB-RV1126-BC-191板子运行自己编码的程序
-
10求HI3519DV500_SDK_V2.0.1.1
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明