这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » 在CM0+上使用systick时SROM操作超时的原因是什么?

共2条 1/1 1 跳转至

在CM0+上使用systick时SROM操作超时的原因是什么?

工程师
2024-03-27 18:15:54     打赏

我的软件设计在 CM4 内核上执行闪存擦除操作,在 CM0+ 内核上执行基于 Systick 的 IO 反转操作,我遇到了一种现象,当我在 CM0+ 内核上删除 Systick 的初始化代码时,CM4 内核上的闪存擦除操作可以正常结束(IPC 可以获得 SROM 擦除操作 " 已解锁 ",即已完成)。 但是,当在 CM0+ 内核上执行 Systick 的初始化代码时,它会失败(IPC 无法获得 SROM 擦除操作 " unlocked ")。
这可能的原因是什么。




关键词: systick    

助工
2024-03-27 18:16:17     打赏
2楼

在CM0+上使用systick时SROM操作超时的原因可能是因为CM0+核心和CM4核心之间的操作冲突。当CM0+核心在执行基于systick的IO反转操作时,CM4核心正在执行闪存擦除操作,可能会导致两个核心之间的资源竞争和冲突。

由于CM0+核心较为简单,可能无法有效处理或等待CM4核心的闪存擦除操作完成。因此,在CM0+核心上执行systick初始化代码会导致超时和失败。

解决这个问题的方法可以是使用适当的同步机制,例如使用信号量或互斥锁,来确保在CM0+核心上执行systick初始化代码之前,CM4核心的闪存擦除操作已经完成。这样可以避免资源竞争和操作冲突,并确保系统的稳定运行。 


共2条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]