研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug

文章目录

背景

问题

排查

解决

总结


背景

        在一个嵌入式软件项目中,客户要求高度可控的时序流,我使用一个全局工步,对整个软件进行控制调度。由于子任务比较多,分门别类放在几个嵌套的子系统中,不能使用Goto模块引用步变量。

        所以我使用了Data Store Memory模块,工步变量既可以跨周期,也能跨Subsystem,包括层级嵌套等。Demo示例如下:

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第1张图片

问题

        按照上述示例,预想两个子系统应该在同一个周期执行,并日根据Simulink数据流的执行顺序,输出值应该相等。但是实际执行情况如下:

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第2张图片

排查

        从上述曲线上看,是Subsystem1的输出不对,所以给Subsystem1的相关信号都打上Scope。

发现Subsystem1的使能条件比信号过来的时间早了,示例如下:

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第3张图片

        进一步排查,发现两个Data Store Read的值居然不同步,示例如下

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第4张图片

        以上说明模块执行顺序有问题,打开Simulink的Sorted Execution Order,看到确实是有问题,示例如下:

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第5张图片

解决

        调整模块的优先级,把Data Store Write的优先级提到最高,示例如下:

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第6张图片

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第7张图片

        重新运行程序,问题不再出现,Bug修复完工。示例如下:

研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug_第8张图片

总结

         1、Data Store Memory模块的Write和Read并不完全按照先Write后Read的顺序执行。

        2、复杂项目中有多个Read模块时,他们之间并没有一定的执行顺序,需要开发者自行约束。


        版权声明:原创文章,转载和引用请注明出处和链接,侵权必究!

        上述例程使用的Demo工程,可以到笔者的主页查找和下载。

你可能感兴趣的:(Matlab/Simulink,bug,研发日记,Matlab,Simulink,DataStoreMemory,嵌入式软件)