我的软件设计在 CM4 内核上执行闪存擦除操作,在 CM0+ 内核上执行基于 Systick
的 IO 反转操作,我遇到了一种现象,当我在 CM0+ 内核上删除 Systick 的初始化代码时,CM4
内核上的闪存擦除操作可以正常结束(IPC 可以获得 SROM 擦除操作 " 已解锁 ",即已完成)。 但是,当在 CM0+ 内核上执行
Systick 的初始化代码时,它会失败(IPC 无法获得 SROM 擦除操作 " unlocked ")。
这可能的原因是什么。
共2条
1/1 1 跳转至页
在CM0+上使用systick时SROM操作超时的原因是什么?
2楼
在CM0+上使用systick时SROM操作超时的原因可能是因为CM0+核心和CM4核心之间的操作冲突。当CM0+核心在执行基于systick的IO反转操作时,CM4核心正在执行闪存擦除操作,可能会导致两个核心之间的资源竞争和冲突。
由于CM0+核心较为简单,可能无法有效处理或等待CM4核心的闪存擦除操作完成。因此,在CM0+核心上执行systick初始化代码会导致超时和失败。
解决这个问题的方法可以是使用适当的同步机制,例如使用信号量或互斥锁,来确保在CM0+核心上执行systick初始化代码之前,CM4核心的闪存擦除操作已经完成。这样可以避免资源竞争和操作冲突,并确保系统的稳定运行。
共2条
1/1 1 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| OK1126B-S开发板下以导航按键控制云台/机械臂姿态调整被打赏¥29元 | |
| 【树莓派5】便携热成像仪被打赏¥36元 | |
| 【树莓派5】环境监测仪被打赏¥35元 | |
| OK1126B-S开发板下多时段语音提示型电子时钟被打赏¥27元 | |
| OK1126B-S开发板下函数构建及步进电机驱动控制被打赏¥25元 | |
| 【S32K3XX】LPI2C 参数配置说明被打赏¥20元 | |
| OK1126B-S开发板的脚本编程及应用设计被打赏¥27元 | |
| 5v升压8.4v两节锂电池充电芯片,针对同步和异步的IC测试被打赏¥35元 | |
| 【S32K3XX】S32DS LPI2C 配置失败问题解决被打赏¥22元 | |
| 【S32K3XX】FLASH 的 DID 保护机制被打赏¥19元 | |
我要赚赏金
