[发明专利]一种双口RAM跟随访问方法有效
申请号: | 201710843828.7 | 申请日: | 2017-09-19 |
公开(公告)号: | CN107544927B | 公开(公告)日: | 2020-06-23 |
发明(设计)人: | 王明星;刘宏春;韩文兴;陈杰;贺理;曾少立 | 申请(专利权)人: | 中国核动力研究设计院 |
主分类号: | G06F13/16 | 分类号: | G06F13/16 |
代理公司: | 成都行之专利代理事务所(普通合伙) 51220 | 代理人: | 田甜 |
地址: | 610000 四*** | 国省代码: | 四川;51 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 ram 跟随 访问 方法 | ||
本发明公开了一种双口RAM跟随访问方法,包括以下步骤,A、MCU在等待跟随的时间段中,不断的检测上次写入的数据的状态,当检测到CPU读走上次写入的数据时,记录当前时刻;B、计算CPU下次读取数据的时刻;C、计算当前时刻与CPU下次读取数据的时刻的中间时刻,并计算MCU退出等待时刻;扩展板卡在中间时刻准备好数据等待CPU的读取操作。采用该方法可避免双口RAM的访问冲突,且可提高CPU与扩展板卡数据交互的速度。
技术领域
本发明涉及堆芯冷却监测系统中的通信领域,更具体的说是涉及一种双口RAM跟随访问方法。
背景技术
双口RAM是在SRAM存储器上具有两套完全独立的数据线、地址线和读写控制线,并允许两个独立的系统同时对该存储器进行随机性的访问的存储器。目前,在堆芯冷却监测系统中,如见图1所示,CPU板卡通过AT96总线访问各扩展板卡的双口RAM,以实现和扩展板卡的数据交互。
现有CPU板卡与扩展板卡之间的交互通过抢旗帜位进行。当CPU侧抢占旗帜位时,扩展板卡是无法进行写操作的,必须等待CPU释放旗帜位,然后抢占旗帜位成功后才能执行写操作。这样就可能照成扩展板卡或者CPU板卡写操作的延迟。即现有的CPU板卡与扩展板卡之间数据交互的速度慢,尤其是在堆芯冷却监测系统中,其扩展板卡数量多,怎样提高CPU与扩展板卡数据交互的速度,是值得研究的。
发明内容
本发明为了解决上述技术问题提供一种双口RAM跟随访问方法,可避免双口RAM的访问冲突,且可提高CPU与扩展板卡数据交互的速度。
本发明通过下述技术方案实现:
一种双口RAM跟随访问方法,包括以下步骤,
A、MCU在等待跟随的时间段中,不断的检测上次写入的数据的状态,当检测到CPU读走上次写入的数据时,记录当前时刻;
B、计算CPU下次读取数据的时刻;
C、计算当前时刻之前且最靠近当前时刻的CPU开始读取数据时刻与CPU下次读取数据的时刻的中间时刻,并计算MCU退出等待时刻;所述当前时刻之前且最靠近当前时刻的CPU开始读取数据时刻=当前时刻-CPU读取上次数据所用时间长度;
D、扩展板卡在中间时刻准备好数据等待CPU的读取操作。
本方法通过双口RAM的访问方法,确保了CPU每次访问双口RAM均能访问到,并及时读取到MCU侧的最新数据,提升了数字化仪控平台的能力。扩展板卡根据CPU上次访问双口RAM的时间,从而计算CPU侧的运行周期,推算出下一时刻CPU访问双口RAM的时间,从而计算出CPU两次访问双口RAM的中间时刻,扩版板卡在此时刻就准备好数据,等待CPU来读取新数据,避免了双口RAM的读写冲突。本方法保证CPU板卡在访问各个扩展板卡时,被访问的扩展板卡数据以提前写好存入双口RAM中,这样就避免了双方的抢旗操作,有效的提高数据交互的速度。
作为优选,步骤A中,通过检测双口RAM输入区的标志实现对上次写入的数据的状态的判断。
作为优选,步骤B的具体方法为:根据双口RAM输入区标志中记录的CPU卡读取数据所消耗的时间,计算出CPU开始读取数据的时刻,并根据MCU的刷新周期得到CPU下次读取数据的时刻。
进一步的,所述CPU下次读取数据的时刻为CPU开始读取数据的时刻加上MCU的刷新周期,CPU的周期为MCU周期的整数倍。
作为优选,步骤C中,MCU退出等待时刻为中间时刻减去采集数据并写入双口RAM的时间,采集数据并写入双口RAM的时间即硬件操作时间。
作为优选,若在步骤A的等待跟随时间段,经过最大等待时间长度后仍未检测到CPU读走上次写入的数据,则跳出跟随等待状态,进行下一次数据准备。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国核动力研究设计院,未经中国核动力研究设计院许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201710843828.7/2.html,转载请声明来源钻瓜专利网。