请教一下,在 t113-s3上使用tina5.0,xplayerdemo解码视频时候出现VE: IOCTL_GET_IOMMU_ADDR map
声音正常可以播放,图像无法显示
有没有大佬遇到过,求指点!
[12:14:35:021]# xplayerdemo
[12:14:35:037]WARNING: awplayer <log_set_level:30>: Set log level to 3
[12:14:35:053]ERROR : awplayer <ReadPluginEntry:194>: read plugin entry adecoder-15 fail!
[12:14:35:086]ERROR : awplayer <ReadPluginEntry:194>: read plugin entry vdecoder-8 fail!
[12:14:35:096]INFO : cedarc <CedarPluginVDInit:79>: register h264 decoder success!
[12:14:35:096]INFO : cedarc <CedarPluginVDInit:84>: register mjpeg decoder success!
[12:14:35:106]INFO : cedarc <CedarPluginVDInit:86>: register mpeg2 decoder success!
[12:14:35:118]WARNING: awplayer <DlOpenPlugin:112>: Invalid plugin,function CedarPluginVDInit not found.
[12:14:35:122]INFO : cedarc <CedarPluginVDInit:92>: register mpeg4dx decoder success!
[12:14:35:122]INFO : cedarc <CedarPluginVDInit:79>: register mpeg4H263 decoder success!
[12:14:35:122]INFO : cedarc <CedarPluginVDInit:90>: register mpeg4Normal decoder success!
[12:14:35:122]INFO : cedarc <CedarPluginVDInit:74>: register vc1 decoder success!
[12:14:35:138]ERROR : awplayer <ReadPluginEntry:194>: read plugin entry plugin-0 fail!
[12:14:35:153]DEBUG : awplayer <AwStreamInit:99>: aw stream init...
[12:14:35:153]
[12:14:35:153]*****************************************************************************
[12:14:35:153]* This program implements a simple player,
[12:14:35:153]* you can type commands to control the player.
[12:14:35:169]* To show what commands supported, type 'help'.
[12:14:35:169]* Inplemented by Allwinner ALD-AL3 department.
[12:14:35:169]****************************************************************************
[12:14:35:187]DEBUG : awplayer <XPlayerCreate:216>: XPlayerCreate.
[12:14:35:195]DEBUG : awplayer <LogVersionInfo:34>:
[12:14:35:196]>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> CedarX <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
[12:14:35:196]tag : CedarX-2.8.0
[12:14:35:196]branch: master
[12:14:35:206]commit: 967535b8ff6a073cb4f38e85a4ae5fa6008014d8
[12:14:35:206]date : Mon, 15 May 2017 01:30:22 +0000 (09:30 +0800)
[12:14:35:207]author:
[12:14:35:218]----------------------------------------------------------------------
[12:14:35:218]
[12:14:35:219]DEBUG : awplayer <LayerCreate_DE:832>: LayerCreate.
[12:14:35:222]INFO : awplayer <LayerCreate_DE:857>: screen_id = 0,output_type = 1
[12:14:35:222]INFO : awplayer <LayerCreate_DE:860>: the output type: 0
[12:14:35:238]DEBUG : awplayer <LayerCreate_DE:871>: screen:w 1024, screen:h 600
[12:14:35:238]DEBUG : ionAlloc <CdxIonOpen:30>: begin ion_alloc_open
[12:14:35:238]
[12:14:35:238]DEBUG : ionAlloc <__GetIonMemOpsS:856>: *** get __GetIonMemOpsS ***
[12:14:35:252]INFO : cedarc <VeInitialize:1307>: *** ic_version = 0x1301000010210,
[12:14:35:252]DEBUG : cedarc <VeInitialize:1347>: *** nPhyOffset = 0x0
[12:14:35:268]DEBUG : ionAlloc <ion_alloc_open2:177>: pid: 1322, g_context = 0x1543ba8
[12:14:35:268]
[12:14:35:268]DEBUG : ionAlloc <ion_alloc_open2:204>: ion alloc open ok
[12:14:35:268]DEBUG : TinaSoundControl <TinaSoundDeviceInit:146>: TinaSoundDeviceInit()
[12:14:35:289]DEBUG : awplayer <XPlayerSetVideoSurfaceTexture:597>: setVideoSurfaceTexture, surface = 0x15415c8
[12:14:35:302]DEBUG : awplayer <XPlayerThread:1957>: process message XPLAYER_COMMAND_SET_SURFACE.
[12:14:35:304]DEBUG : awplayer <XPlayerThread:2018>: ==== process message XPLAYER_COMMAND_SET_SUBCTRL.
[12:14:35:311]DEBUG : awplayer <XPlayerSetDeinterlace:698>: set deinterlace
[12:14:35:311]DEBUG : awplayer <XPlayerThread:2033>: ==== process message XPLAYER_COMMAND_SET_SUBCTRL.
[12:14:35:312]
[12:14:38:240]demoPlayer#
[12:14:38:241]
[12:14:38:453]demoPlayer#
[12:14:38:453]
[12:14:38:636]demoPlayer#
[12:14:38:636]
[12:14:39:762]demoPlayer# set url:/trailer.mp4
[12:14:39:762]DEBUG : awplayer <XPlayerSetDataSourceUrl:462>: setDataSource(url), url='/trailer.mp4'
[12:14:39:778]INFO : awplayer <XPlayerThread:1794>: process message XPLAYER_COMMAND_SET_SOURCE.
[12:14:39:778]DEBUG : awplayer <XPlayerPrepare:747>: prepare
[12:14:39:796]DEBUG : awplayer <XPlayerThread:2047>: process message XPLAYER_COMMAND_PREPARE. mPriData->mStatus: 1
[12:14:39:796]DEBUG : demuxComponent <DemuxThread:1792>: process message DEMUX_COMMAND_PREPARE.
[12:14:39:812]DEBUG : awplayer <CdxParserPrepare:778>: source uri 'file:///trailer.mp4'
[12:14:39:812]DEBUG : awplayer <__FileStreamConnect:407>: (6/0/4372373) path:'file:///trailer.mp4'
[12:14:39:812]DEBUG : awplayer <CdxParserCreate:717>: Good, it's 'mov'
[12:14:39:833]DEBUG : demuxComponent <PrintMediaInfo:468>: *********PrintMediaInfo begin*********
[12:14:39:847]DEBUG : demuxComponent <PrintMediaInfo:482>: fileSize = 4372373, bSeekable = 1, duration = 52209, audioNum = 1, videoNum = 1, subtitleNu[ 79.035245] VE: VE real_freq=576000000
[12:14:39:850][ 79.035245]
[12:14:39:850]m = 0
[12:14:39:858]DEBUG : demuxComponent <PrintMediaInfo:502>: ***Video[0]*** eCodecFormat = 0x115, nWidth = 854, nHeight = 480, nFrameRate = 24000, nFrameDuration = 0, bIs3DStream = 0, bSecureFlag = 0
[12:14:39:879]DEBUG : demuxComponent <PrintMediaInfo:520>: ***Audio[0]*** eCodecFormat = 0x4, eSubCodecFormat = 0x0, nChannelNum = 2, nBitsPerSample = 16, nSampleRate = 48000
[12:14:39:879]DEBUG : demuxComponent <PrintMediaInfo:536>: *********PrintMediaInfo end*********
[12:14:39:897]DEBUG : cedarc <CdcIniParserInit:41>: load conf file /etc/cedarc.conf ok!
[12:14:39:897]
[12:14:39:897]WARNING: awplayer <log_set_level:30>: Set log level to 5
[12:14:39:897]ERROR : cedarc <DebugCheckConfig:301>: now cedarc log level:5
[12:14:39:897]setDataSource end
[12:14:39:913]++++ video width: 854, height: 480
[12:14:39:913]info: prepare ok.
[12:14:39:913]preparing...
[12:14:39:913]
[12:14:45:635]demoPlayer# play
[12:14:45:653](Allwinner Audio Middle Layer),line(971) : Create Decoder!!=====
[12:14:45:666](Allwinner Audio Middle Layer),line(603) : AudioDec_Installaudiolib ok
[12:14:45:669](Allwinner Audio Middle Layer),line(606) : audio decoder init start ...
[12:14:45:669](AllwinnerAlibs),line(50) :
[12:14:45:670]>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> Audio <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
[12:14:45:670]tag : audiocodec-v1.2
[12:14:45:670]branch: new
[12:14:45:686]commit: 3ba65962c01cbf1280ddda19d843009b6ef8ce85
[12:14:45:686]date : Tue Jan 8 16:25:27 2019 +0800
[12:14:45:686]----------------------------------------------------------------------
[12:14:45:686]
[12:14:45:686](AllwinnerAlibs),line(700) : ----Loading so success!
[12:14:45:699](AllwinnerAlibs),line(902) : *************pAudioStreamInfo start******************
[12:14:45:699](AllwinnerAlibs),line(903) : eCodecFormat :id(4), name(aac low-complexy)
[12:14:45:716](AllwinnerAlibs),line(904) : eSubCodecFormat :0
[12:14:45:716](AllwinnerAlibs),line(905) : nChannelNum :2
[12:14:45:716](AllwinnerAlibs),line(906) : nBitsPerSample :16
[12:14:45:716](AllwinnerAlibs),line(907) : nSampleRate :48000
[12:14:45:735](AllwinnerAlibs),line(908) : nAvgBitrate :0
[12:14:45:743](AllwinnerAlibs),line(909) : nMaxBitRate :128000
[12:14:45:744](AllwinnerAlibs),line[ 84.944752] VE: ve get dma_buf error
[12:14:45:754](910) : nFileSize :0
[12:14:45:755](AllwinnerAlibs),line(911) : eAudioBitstreamSource:0
[12:14:45:765](AllwinnerAlibs),line(912) : eDataEncodeT[ 84.956966] VE: IOCTL_GET_IOMMU_ADDR map dma buf fail
[12:14:45:765]ype :0
[12:14:45:765](AllwinnerAlibs),line(913) : nCodecSpecificDataLen:2
[12:14:45:765](AllwinnerAlibs),line(914) : pCodecSpecificData :0xb526cff8[ 84.971247] VE: ve get dma_buf error
[12:14:45:765]
[12:14:45:781](AllwinnerAlibs),line(915) : nFlags :0
[12:14:45:781](AllwinnerAlibs),line(916) : nBlockAlign :0
[12:14:45:799](AllwinnerAlibs),l[ 84.983750] VE: IOCTL_GET_IOMMU_ADDR map dma buf fail
[12:14:45:799]ine(917) : *************pAudioStreamInfo end ******************
[12:14:45:799](AAC Decoder),line(36) : init successs...
[12:14:45:799](Allwinner Audio Mi[ 85.002923] VE: ve get dma_buf error
[12:14:45:816]ddle Layer),line(614) : AUDIO DECODE INIT OK...0
[12:14:45:816]playing.
[12:14:45:816]
[12:14:45:816]demoPlayer# WARNING: awplayer <callbackProcess:3636>: message 0x40[ 85.015502] VE: IOCTL_GET_IOMMU_ADDR map dma buf fail
[12:14:45:816]a not handled.
[12:14:45:840][ 85.032907] VE: ve get dma_buf error
[12:14:45:840][ 85.034632] L1 PageTable Invalid
[12:14:45:851][ 85.037409] VE: IOCTL_GET_IOMMU_ADDR map dma buf fail
[12:14:45:851][ 85.040847] 0xb5292000 is not mapped!
[12:14:45:857][ 85.040855] VE invalid address: 0xb5292000, data:0x0, id:0x1
[12:14:45:857][ 85.057163] VE: ve get dma_buf error
[12:14:45:866][ 85.061316] VE: IOCTL_GET_IOMMU_ADDR map dma buf fail
[12:14:45:866][ 85.067114] VE: ve get dma_buf error
[12:14:45:866][ 85.071612] VE: IOCTL_GET_IOMMU_ADDR map dma buf fail
[12:14:45:882][ 85.077416] VE: ve get dma_buf error
[12:14:45:882][ 85.082146] VE: IOCTL_GET_IOMMU_ADDR map dma buf fail
[12:14:45:981][ 85.181517] [SNDCODEC][sunxi_card_hw_params][620]:stream_flag: 0
[12:14:46:893]WARNING: cedarc <waitInterruptDecoder:748>: wait ve interrupt timeout. ret = 0
[12:14:50:258]WARNING: awplayer <CallbackProcess:2982>: break audio video first sync.
[12:14:50:258]WARNING: awplayer <checkSampleRate:644>: sample rate change from 48000 to 48000.
[12:14:50:258]WARNING: awplayer <checkSampleRate:646>: channel num change from 2 to 2.
[12:14:50:277]WARNING: awplayer <checkSampleRate:648>: bitPerSample num change from 16 to 16.
[12:14:50:285]WARNING: awplayer <checkSampleRate:650>: if need direct out put flag change from 0 to 1.
[12:14:50:293]WARNING: awplayer <checkSampleRate:652>: data type change from 1 to 1.
[12:14:50:384]WARNING: awplayer <checkSampleRate:671>: start sound devide again because samplaRate or channelNum change
[12:14:50:410][ 89.587908] [SNDCODEC][sunxi_card_hw_params][620]:stream_flag: 0
[12:14:50:623]WARNING: awplayer <CallbackProcess:3709>: reset the timer to 0.040, time difference is -0.318
[12:15:05:402]^C[ 104.606873] VE: release lost-lock...
输入pack出现错误:
ERROR: unable to open file boot-resource.fex
ERROR: update mbr file fail
ERROR: update_mbr failed
应该是某些依赖包没有安装,
sudo apt-get install build-essential subversion git-core libncurses5-dev zlib1g-dev gawk flex quilt libssl-dev xsltproc libxml-parser-perl mercurial bzr ecj cvs unzip lib32z1 lib32z1-dev lib32stdc++6 libstdc++6 -y
就可以正常运行pack命令了!
以下相关链接由@晕哥 2020-03-16 添加:
---------------
F1C100S下LittleVgl+RTT触摸、GT911、看门狗踩坑记录 by @staunchheart
--作者:燕十三(flyingcys) blog:http://blog.csdn.net/flyingcys
--荔枝派nano/RTT非官方群:711174828
在此感谢
RT-Thread官方成员@uestczyh222提供的荔枝派Nano内核移植、rttbootloader文件、rtota等一系列工具。
挖坑/填坑网 https://whycan.cn/ 站长@晕哥,默默的为我们收集各种荔枝派Nano相关的资讯、工具。
RT-Thread是一款由中国开源社区主导开发的开源嵌入式实时操作系统(遵循GPLv2+许可协议,当标识产品使用RT-Thread时可以按照自由代码非开源的方式应用在商业产品中),它包含实时嵌入式系统相关的各个组件:实时操作系统内核、TCP/IP协议栈、文件系统、libc接口、图形引擎等。
RT-Thread实时操作系统是一个分层的操作系统,它包括了:
底层移植、驱动层,这层与硬件密切相关,由Drivers和CPU移植相构成。
硬实时内核,这层是RT-Thread的核心,包含了内核系统中对象的实现,例如多线程机器调度,信号量,邮箱,消息队列,内存管理,定时器等实现。
组件层,这些是基于RT-Thread核心基础上的外围组件,例如文件系统,命令行shell接口,LwIP轻型TCP/IP协议栈,GUI图形引擎等。
更详细信息及开发文档可在官网https://www.rt-thread.org获取。
RT-Thread代码开源在github及国内的码云,2个仓库同步更新。2018年3月底最新版本为3.0.3。github仓库地址:https://github.com/RT-Thread,码云仓库地址:https://gitee.com/rtthread。
荔枝派Nano采用全志科技F1C100s ARM9内核SOC处理器,主频408MHz,片内DDR达32MByte,
支持UART、USB OTG、SPI、TWI、TP、SD/MMC、LCD、音视频接口等众多外设接口,
是一款不可多得的高配低价开发板。
荔枝派Nano相关资料可在:
https://pan.baidu.com/s/1smzuGS9下载。
同时荔枝派Nano在正式发售之前已经得到了Linux、RT-Thread等操作系统支持。
RT-Thread是率先完成荔枝派Nano移植的嵌入式实时RTOS操作系统,
代码已经合并进RT-Thread官方github仓库,github地址为:
https://github.com/RT-Thread/rt-thread/tree/master/bsp/allwinner_tina
一、开发环境搭建
在windows下使用RT-Thread进行荔枝派Nano开发,推荐使用RT-Thread Env工具。RT-Thread Env工具包括配置器和包管理器,
用来对内核和组件的功能进行配置,对组件进行自由裁剪,对线上软件包进行管理,使得系统以搭积木的方式进行构建,简单方便。
同时Env工具自带RT-Thread开发过程中需要用到的git、python、scons、arm-none-eabi-gcc等多种工具。
Env工具可在RT-Thread官网->“资源”->“下载”页面下载,下载地址:
https://www.rt-thread.org/page/download.html
Env自带的arm-none-eabi-gcc正是荔枝派Nano使用的交叉编译器,Env工具已经帮我们配置好环境变量,可直接使用。
Env工具使用请参照Env工具包内使用说明。
二、RT-Thread编译与运行
1.RT-Thread下载
RT-Thread官方github地址为:https://github.com/RT-Thread/rt-thread。
在Env工具下使用:git clone https://github.com/RT-Thread/rt-thread.git
RT-Thread荔枝派Nano源码文件位于RT-Thread/bsp/allwinner_tina目录。
2.RT-Thread编译
在Env工具下切换目录至RT-Thread/bsp/allwinner_tina,并执行scons命令,即可编译。
正确编译完成后,会自动生成rtthread.bin文件。
3.rttbootloader下载
RT-Thread荔枝派Nano在Windows下更新固件需通过rttbootloader引导,USB更新。rttbootloader下载只需1次即可,完成后即可通过“rtota工具”下载。在开始正式下载之前需要完成以下步骤:
(1)USB驱动安装
荔枝派Nano在Windows下使用USB需要安装驱动,驱动可在QQ群(711174828)空间下载或挖坑/填坑网F1C100S页面(https://whycan.cn/t_444.html)下载。
1)短接flash 1、4脚(当flash中无可引导代码时无需此步骤)
2)连接USB
此时如果在“设备管理器”中发现“无法识别”设备,那就是需要安装USB驱动。驱动名为Zadig。
安装完成后,即可在Windows下发现USB设备。
(2)rttbootloader下载
rttbootloader_f1c100s_v1.0.0.bin是RT-Thread适用于F1C100S的bootloader,使用rttbootloader后即可通过Flash,下载、启动、运行RT-Thread,否则只能下载程序在Ram中运行,掉电后程序即丢失。
当前1.0.0版rttbootloader_f1c100s只支持8MByte及以上的Flash,并且Falsh地址已经固定。期待更新的1.0.1版本发布。
rttbootloader_f1c100s_v1.0.0.bin可在QQ群(711174828)空间下载或挖坑/填坑网F1C100S页面(https://whycan.cn/viewtopic.php?pid=3924#p3924)下载。
rttbootloader下载依赖sunxi-tools。sunxi-tools可在QQ群(711174828)空间下载或挖坑/填坑网F1C100S页面(https://whycan.cn/t_444.html)下载。
1)短接flash 1、4脚(当flash中无可引导代码时无需此步骤)
2)连接USB
3)在evn工具下输入sunxi-fel -p spiflash-write 0 rttbootloader_f1c100s_v1.0.0.bin.bin
此时可看到下载进度条,并等待下载完成。下载完成后请断开flash1、4脚。
4.RT-Thread固件下载
1)OTA固件制作
RT-Thread OTA固件制作依赖“RT-Thread OTA固件打包器”,通过打包器制作出在rttbootloaer下可被识别并更新的固件。
“RT-Thread OTA固件打包器”可在QQ群(711174828)空间下载或挖坑/填坑网F1C100S页面(https://whycan.cn/viewtopic.php?pid=3924#p3924)下载。
其中:
选择固件:为之前RT-Thread源码bsp下allwinner_tina目录编译完成后的rtthread.bin文件。
保存路径:可自由设置保存路径,OTA固件名与选择固件名一致,后缀为.rbl。
固件名称:必须设置为app。
固件版本:可根据实际情况输入。
其他选项为默认。
2)OTA固件更新
上一步骤已完成rttbootloader下载至spiflash中,同时已经生成OTA固件。此时需要将荔枝派Nano启动至rttbootloader状态,否则无法更新OTA固件。
OTA固件更新使用“rtota工具”,该工具通过windows命令行执行,可直接在Env工具下运行。期待windows图形工具发布!!!
“rtota工具”可在可在QQ群(711174828)空间下载或挖坑/填坑网F1C100S页面
(https://whycan.cn/viewtopic.php?pid=3924#p3924)下载
rttbootloader已将Uart0设置为shell串口,Uart0在荔枝派Nano中分别为PE0(Rx0)和PE1(Tx0),请连接至PC,rttbootloader默认波特率为115200。
在没有下载RT-Thread应用固件或在启动3秒内输入键盘任意键,rttbootloader自动进入bootloader。
在rttbootloader模式下,使用env工具,输入命令:rtota -u ./rtthread.rbl,开始下载。
同时输入rtota,可获取工具使用手册
其中:
-u:下载至flash。
-R:下载至ram运行。
5.运行
以上操作已将rtthread.bin下载至荔枝派Nano的flash中,每次重启后,rttbootloader先行运行,然后启动RT-Thread应用。
RT-Thread应用同样使用Uart0设置为shell串口,将Uart0连接至PC,这样就可以看到RT-Thread正常启动后的Logo及荔枝派Nano的时钟运行频率等信息。
在msh命令行状态下,输入help或者TAB键,即可查看当前RT-Thread shell命令。
下集预告:
玩转RT-Thread之荔枝派Nano
二、uart应用
敬请期待!
RT-Thread荔枝派Nano启动文件rttbootloader_f1c100s_v1.0.0.bin
rttbootloader_f1c100s_v1.0.0.bin
RT-Thread OTA固件打包器
RT-Thread OTA固件打包器
荔枝派Nano RT-Thread 固件windows命令行USB更新工具rtota
荔枝派Nano RT-Thread 固件windows命令行USB更新工具rtota