Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
BSP
rt-thread 3.1.1 版本STM32F103ZET6外扩SRAM如何配置?
发布于 2019-10-16 17:16:06 浏览:2554
订阅该版
项目背景:1) 使用STM32F103ZET6芯片,默认使用内部的64K RAM。 2) 连接RW007 WiFi模块,通过EVN工具配置RW007软件包,LWIP软件包之后,运行程序打印某些队列建立失败,通过跟踪,发现是rt_malloc()失败。 \ | / - RT - Thread Operating System / | \ 3.1.3 build Oct 16 2019 2006 - 2019 Copyright by rt-thread team [31m[E/WLAN.work] F:rt_wlan_workqueue_init L:89 wlan work queue create failed[0m lwIP-2.0.2 initialized! [32m[I/WLAN.dev] wlan init failed[0m To initialize device:wlan0 failed. The error code is -2 [31m[E/WLAN.dev] L:62 wlan init failed[0m [31m[E/WLAN.mgnt] F:rt_wlan_set_mode L:782 F:rt_wlan_set_mode L:782 wlan init failed[0m [32m[I/WLAN.dev] wlan init success[0m [31m[E/WLAN.dev] L:68 wlan config mode failed[0m [31m[E/WLAN.mgnt] F:rt_wlan_set_mode L:782 F:rt_wlan_set_mode L:782 wlan init failed[0m rw007 sn: [] rw007 ver: [] 尝试措施: 1)刚好板子上有1个SRAM扩展芯片,接在FSMC_NE3片上。大小是512KByte,使用STM32CubMx工具生成了初始化FSMC代码中,并且增加了工程中,INIT_PREV_EXPORT(HAL_SRAM_MspInit)导出,系统启动时候自动初始时候。 2)将这个512KByte的SRAM交个RT-thread管理,在board.h文件中 将STM32_SRAM_SIZE 修改为512 #define STM32_SRAM_SIZE 512 #define STM32_SRAM_END (0x68000000 + STM32_SRAM_SIZE * 1024) 3) MDK工程中设置使用如下分散加载文件进行编译,但运行起来后,一直停在rt_int32_t rt_vsnprintf()函数中。 ; ************************************************************* ; *** Scatter-Loading Description File generated by uVision *** ; ************************************************************* LR_IROM1 0x08000000 0x00200000 { ; load region size_region ER_IROM1 0x08000000 0x00200000 { ; load address = execution address *.o (RESET, +First) *(InRoot$$Sections) .ANY (+RO) } RW_IRAM1 0x68000000 0x00200000 { ; RW data .ANY (+RW +ZI) } } 现在不知道怎么解决这个问题?
查看更多
4
个回答
默认排序
按发布时间排序
tyustli
2019-10-16
这家伙很懒,什么也没写!
可以参考一下这个 [https://github.com/RT-Thread/rt-thread/blob/master/bsp/stm32/libraries/HAL_Drivers/drv_sdram.c](https://github.com/RT-Thread/rt-thread/blob/master/bsp/stm32/libraries/HAL_Drivers/drv_sdram.c)
swordlifeRT
2019-10-17
这家伙很懒,什么也没写!
谢谢。 1) 按照您的建议,已经将SRAM加入工程文件同时将外扩的SRAM 通过调用rt_memheap_init()分配权交给了RT-thread。 2)分配权交给之后再进行读写测试(直接操作地址),读写测试也OK。 3)RW007软件包建立“”wlan_job“任务的时候,第一次第二次调用 RT_KERNEL_MALLOC能够分配到内存,但第3次调用,则Hard fault 错误。 [0m[D/drv.sram] sram init success, mapped at 0x68000000, size is 512 Kbytes, data width is 16[0m [0m[D/drv.sram] Writing the 4194304 bytes data, waiting....[0m [0m[D/drv.sram] Write data success, total time: 0.000S.[0m [0m[D/drv.sram] start Reading and verifying data, waiting....[0m [0m[D/drv.sram] SRAM test end![0m \ | / - RT - Thread Operating System / | \ 3.1.3 build Oct 17 2019 2006 - 2019 Copyright by rt-thread team psr: 0x01000000 r00: 0x68000818 r01: 0x55555555 r02: 0x20000d38 r03: 0xffffffff r04: 0x20000cf4 r05: 0x68000000 r06: 0x00000800 r07: 0xed55553d r08: 0x00000000 r09: 0x00000800 r10: 0x00000016 r11: 0x0000000a r12: 0x00000000 lr: 0x08015641 pc: 0x08013de8 hard fault on thread: main thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- wlan_job 0 init 0x00000000 0x00000000 00% 0x00000000 000 tidle 31 ready 0x00000044 0x00000100 26% 0x00000020 000 main 10 ready 0x00000044 0x00000800 11% 0x00000013 000 bus fault: SCB_CFSR_BFSR:0x04 IMPRECISERR 还需要继续查询问题。
swordlifeRT
2019-10-19
这家伙很懒,什么也没写!
1)今天调试了一下,上面提到的新问题原因是因为我在启动RT-thread任务调度之前,自己的SRAM进行了读写测试,但读写测试的内容没有清零,导致rt_malloc()申请到地址后,rt-thread判断一些申请结构的数据之后指针地址内容适合出差。 将测试内容写入全零后即可,rt-thread可以正常运行起来了。 2) 现在加入RW007后包后,RW007初始化过程中,打印“[I/drv.spi] spi transfer error : 3” 错误信息,也即SPI收发数据错误。 经过单步追踪,发现在 rt_spi_configure()这个函数中跳过了SPI设备配置。也就是没有配置SPI端口,数据接收当然出错。 rt_err_t rt_spi_configure(struct rt_spi_device *device, struct rt_spi_configuration *cfg) { rt_err_t result; RT_ASSERT(device != RT_NULL); /* set configuration */ device->config.data_width = cfg->data_width; device->config.mode = cfg->mode & RT_SPI_MODE_MASK ; device->config.max_hz = cfg->max_hz ; if (device->bus != RT_NULL) { result = rt_mutex_take(&(device->bus->lock), RT_WAITING_FOREVER); if (result == RT_EOK) { if (device->bus->owner == device) //这个条件不为真,导致初始化configure直接跳过了。 { device->bus->ops->configure(device, &device->config); } /* release lock */ rt_mutex_release(&(device->bus->lock)); } } return RT_EOK; } 现在在解决此问题,还不知道原因在哪里?
暁タマツ
2019-12-05
这家伙很懒,什么也没写!
大佬,我也是STM32F103ZET6这个mcu ,刚刚接触rt-thread 想请教用env怎么样才能配置fsmc驱动,我把驱动和内存部分都翻了一遍也没找到相关选项
撰写答案
登录
注册新账号
关注者
0
被浏览
2.6k
关于作者
swordlifeRT
这家伙很懒,什么也没写!
提问
3
回答
12
被采纳
0
关注TA
发私信
相关问题
1
STM32 407 串口接收数据 系统卡死
2
RTT nrf24l01 设备驱动程序
3
stm32f10x串口只能发送数据,无法接收
4
第一次尝试移植rt-thread 到stm32F103系列问题
5
有人把stm32L07xx的bsp移到rtt上来了吗?求一个
6
rt-thread线程调度异常在stm32f103芯片上
7
RTT是否支持STM32F429
8
请问谁有 STM32F40x HAL + RT-THREAD 模板
9
rt-thread在stm32f411下的移植问题
10
针对STM32F7系列平台的MPU,Cache特性,需要注意哪些问题?
推荐文章
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
【24嵌入式设计大赛】基于RT-Thread星火一号的智慧家居系统
2
RT-Thread EtherKit开源以太网硬件正式发布
3
如何在master上的BSP中添加配置yml文件
4
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
5
RT-Thread 发布 EtherKit开源以太网硬件!
热门标签
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
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
MicroPython
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
15
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
13
个答案
1
次被采纳
本月文章贡献
程序员阿伟
9
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
RTT_逍遥
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部