完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
在阅读了与我的问题有关的大部分主题后,没有找到解决我们问题的答案,这里是我的描述:
我们目前正在将 OpenAMP 集成到我们的应用程序中。目前,我们正在使用 OpenAMP_TTY_echo 示例项目中的配置,启用跟踪日志,并在 M4 和 A7 之间使用单个虚拟 UART。 在启动的 Linux 系统中使用“rproc start”启动应用程序时,它按预期工作。跟踪日志可用,并且 /dev/ttyRPMSG0 虚拟 UART 已加载:
我们可以将虚拟数据发送到 /dev/ttyRPMSG0 并获得回显响应 在我们的用例中,我们需要尽可能早地启动 M4 应用程序,因此我们配置了 u-boot SSBL 以加载 ELF 文件并启动 M4 执行。然后我们就面临软件启动了,但是linux内核没有加载/dev/ttyRPMSG0设备的问题:
我们检查了以下几点: 在启动序列完成后附加到正在运行的 M4 执行时,我们看到函数 rproc_virtio_wait_remote_ready(vdev) 没有返回。好像linux rproc 没有加载资源表。 resource_table 存在于 ELF 文件中(使用 readelf 检查) u-boot rproc 确实将资源表的正确地址加载到 TAMPER 备份寄存器中 在我们的调查中,我们发现问题似乎与 M4 代码 + 内存大小有关。当代码大小超过 ~130KB(代码 + RAM,其中代码放置在 MCU SRAM 1 中)时,我们可以重现该问题。 低于该大小,M4 应用程序将从 u-boot 正确启动,并且在 Linux 下跟踪可用并创建 RPMSG 设备。 我们尝试在引导期间为相关内核模块(STM32_rproc 和 remoteproc*)输出详细日志消息,并将 dyndbg 参数添加到 u-boot 内核命令行(dyndbg="file ec.c +p"),但我们只得到了内核尝试使用此参数启动时出现恐慌错误。内核配置中启用了动态调试。我们怎样才能打开以获得这些额外的调试信息? |
|
相关推荐
1个回答
|
|
|
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2629 浏览 1 评论
3208 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1782 浏览 1 评论
3607 浏览 6 评论
5987 浏览 21 评论
939浏览 4评论
1315浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
582浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1302浏览 3评论
1357浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-21 20:56 , Processed in 1.179574 second(s), Total 79, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号