Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
ART-Pi
touchgfx
wifi
5
ART-PI 在运行Touchgfx时如果打开wifi就在初始化时有一段时间乱码
发布于 2021-02-03 10:14:37 浏览:1491
订阅该版
首先说明一下问题,在ART-Pi上运行好Touchgfx的官方例程后,若不开启AP6212A,屏幕显示正常,若开启AP6212A发现屏幕在初始化时会发生乱码。经过检查项目的软件包时,发现会有一个Fal被使能,这时在终端可以看到以下数据 [I/SFUD] Probe SPI flash norflash0 by SPI device spi10 success. [D/FAL] (fal_flash_init:63) Flash device | norflash0 | addr: 0x00000000 | len: 0x01000000 | blk_size: 0x00001000 |initialized finish. [I/FAL] ==================== FAL partition table ==================== [I/FAL] | name | flash_dev | offset | length | [I/FAL] ------------------------------------------------------------- [I/FAL] | wifi_image | norflash0 | 0x00000000 | 0x00080000 | [I/FAL] | bt_image | norflash0 | 0x00080000 | 0x00080000 | [I/FAL] | download | norflash0 | 0x00100000 | 0x00200000 | [I/FAL] | easyflash | norflash0 | 0x00300000 | 0x00100000 | [I/FAL] | filesystem | norflash0 | 0x00400000 | 0x00c00000 | [I/FAL] ============================================================= [I/FAL] RT-Thread Flash Abstraction Layer (V0.5.0) initialize success. 发现norflash被分区,接着我又开始分析具体是什么情况引起的初始化时有一段时间的乱码,于是我想到了,TouchGfx会不会使用了Flash靠前的部分,于是就找到了fal_cfg.h文件,打开后可以看到: } /* ==================== Partition Configuration ======================== */ #ifdef FAL_PART_HAS_TABLE_CFG #define FAL_PART_TABLE \ { \ {FAL_PART_MAGIC_WORD, "wifi_image", NOR_FLASH_DEV_NAME, 0, 512*1024, 0}, \ {FAL_PART_MAGIC_WORD, "bt_image", NOR_FLASH_DEV_NAME, 512*1024, 512*1024, 0}, \ {FAL_PART_MAGIC_WORD, "download", NOR_FLASH_DEV_NAME, 1024*1024, 2*1024*1024, 0}, \ {FAL_PART_MAGIC_WORD, "easyflash", NOR_FLASH_DEV_NAME, 3*1024*1024, 1*1024*1024, 0}, \ {FAL_PART_MAGIC_WORD, "filesystem", NOR_FLASH_DEV_NAME, 4*1024*1024, 12*1024*1024, 0}, \ } #endif /* FAL_PART_HAS_TABLE_CFG */ 可以看到第一个分区是关于wifi的,于是就将flash全部向后移动1024,果然屏幕不会有一段时间乱码了,但是又出现了一个新的报错(最后一行): [I/SFUD] Probe SPI flash norflash0 by SPI device spi10 success. [D/FAL] (fal_flash_init:63) Flash device | norflash0 | addr: 0x00000000 | len: 0x01000000 | blk_size: 0x00001000 |initialized finish. [I/FAL] ==================== FAL partition table ==================== [I/FAL] | name | flash_dev | offset | length | [I/FAL] ------------------------------------------------------------- [I/FAL] | wifi_image | norflash0 | 0x00000400 | 0x00080400 | [I/FAL] | bt_image | norflash0 | 0x00080400 | 0x00080400 | [I/FAL] | download | norflash0 | 0x00100400 | 0x00200400 | [I/FAL] | easyflash | norflash0 | 0x00300400 | 0x00100400 | [I/FAL] | filesystem | norflash0 | 0x00400400 | 0x00c00400 | [I/FAL] ============================================================= [I/FAL] RT-Thread Flash Abstraction Layer (V0.5.0) initialize success. [I/at.clnt] AT client(V1.3.0) on device uart6 initialize success. [D/at.dev.ec20] network interface device(4G) set up status. [I/FAL] The FAL MTD NOR device (filesystem) created successfully ../packages/littlefs-latest/lfs.c:1071:error: Corrupted dir pair at {0x0, 0x1} [W/app.filesystem] mount to '/flash' failed! try to mkfs filesyst夗夗眄眄?$ [I/touch] rt_touch init success [D/at.dev.[ec20] startI/OTA] RT init -4G device.Thread OTA package(V0.2.3) initialize success. **msh />[E/WLAN] Wi-Fi image was NOT found on wifi_image partition** 我第一次碰到这个报错的时候已经懵了,于是就开始查找源头,在libraries->drivers->drv_wlan.c 可以看到第171行函数, /* initialize fal */ fal_init(); partition = fal_partition_find(WIFI_IMAGE_PARTITION_NAME); 首先进行fal初始化,其次是fal_partition_find(WIFI_IMAGE_PARTITION_NAME);查找分区函数。接着就会执行一下函数,原来在初始化之前会寻找此分区,但是我不清楚这个分区明明已经定义仅仅是向后移动了一部分不知为何就是找不到,所以还请大佬帮帮忙。 if (rt_ota_part_fw_verify(partition) >= 0) { /* initialize low level wifi(ap6212) library */ wifi_hw_init(); /* waiting for sdio bus stability */ rt_thread_delay(WIFI_INIT_WAIT_TIME); /* set wifi work mode */ rt_wlan_set_mode(RT_WLAN_DEVICE_STA_NAME, RT_WLAN_STATION); /* NEED TODO !!! */ /* rt_wlan_set_mode(RT_WLAN_DEVICE_AP_NAME, RT_WLAN_AP); */ init_flag = 1; } else { LOG_E("Wi-Fi image was NOT found on %s partition!", WIFI_IMAGE_PARTITION_NAME); }
查看更多
whj467467222
认证专家
2021-02-03
开源,分享,交流,共同进步
可以先尝试在一个没有 `touchgfx` 的工程上去验证 `FAL` 的功能是否正常, 偏移地址改到 4096 试一试。 `FAL` 提供了很多的 终端测试命令 `fal probe` `fal write` `fal read` 先测试一下这些是否正常。
2
个回答
默认排序
按发布时间排序
Fjf
2021-05-24
这家伙很懒,什么也没写!
```C++ bool TouchGFXHAL::blockCopy(void* RESTRICT dest, const void* RESTRICT src, uint32_t numBytes) ``` 咨询一下,Touch GFX中的这个函数在RTT中什么时候调用?具体在哪里调用?能不能把它调用的顺序放在SD卡挂载后?
撰写答案
登录
注册新账号
关注者
0
被浏览
1.5k
关于作者
贾S_1872468521
这家伙很懒,什么也没写!
提问
6
回答
1
被采纳
0
关注TA
发私信
相关问题
1
RT-STUDIO下加入TOUCHGFX?
2
ART-Pi 在 Studio 中使用TouchGFX Library 编译报错
3
APT-Pi运行Touchgfx例程出现错误
4
请问程序烧到内部rom后,如何把touchgfx图片数据烧到片外8M闪存里
5
ART-Pi在同时打开板载wifi例程和touchgfx后发生乱屏的现象
6
ART-PI的Touchgfx按键事件没反应
7
TouchGFX从文件系统中读取图片失败
8
TouchGFX如何从文件系统中读取字库
9
将ExtFlashSection映射到添加的USB区域后,程序下载失败
10
ART-PI添加了Touchgfx后显示模糊
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT-Thread项目助手v0.2.0 - 支持Env Windows
2
RttreadV5.10上,GD32F450Z RTC时间显示问题
3
rt-smart启动流程分析
4
EtherKit快速上手PROFINET
5
RTThread USB转串口无法接收数据
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部