[发明专利]基于Forth虚拟机的任务调度方法及装置在审

专利信息
申请号: 201710810188.X 申请日: 2017-09-11
公开(公告)号: CN107391251A 公开(公告)日: 2017-11-24
发明(设计)人: 代红兵;周永录;王丽清 申请(专利权)人: 云南大学
主分类号: G06F9/48 分类号: G06F9/48;G06F9/455
代理公司: 暂无信息 代理人: 暂无信息
地址: 650091 云*** 国省代码: 云南;53
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 基于 forth 虚拟机 任务 调度 方法 装置
【说明书】:

技术领域

发明涉及一种基于Forth虚拟机的任务调度及装置,属计算机操作系统技术领域。

背景技术

Forth语言本身就是一种过程控制语言和一种快速开发环境,而不仅仅是一个单纯的编程工具,具有很强的交互性、重构性、移植性和自扩展能力,以及高效的生成代码,甚至可以快速构造出一个实时多任务操作系统。

一直以来,基于Forth虚拟机(FVM)的嵌入式多任务操作系统(FVMOS)究竟采用何种多任务调度策略始终是Forth界长期争论的焦点,以至于在先后形成的FIG-Forth、Forth-79、Forth-83、ANSI X3.215-1994、ISO/IEC 15145:1997、Forth-2012等标准中均未出现相关的内容。与直接基于CPU处理器架构的多任务操作系统不同,FVMOS的实现有其独特性,若引入抢占式调度,势必会破坏虚拟机的硬件抽象,从而散失固有的重构、扩展、移植等特性。按照以往的方式,若采用抢占式调度,同时具备并发(终端和后台)、定时和中断三种任务类型,则实时性的保证是以数十项复杂的CPU现场保护与恢复以及丢失重构、扩展、移植等特性为代价的。此外,如果存在终端任务,这种中断驱动的强制调度还会严重干扰和打乱Forth系统特有的在线交互过程。

发明内容

本发明的目的是克服现有技术的不足,提供一种精简高效的基于Forth虚拟机架构的嵌入式任务调度方法及装置。

本发明提供一种基于Forth虚拟机任务调度方法,包括:

将当前返回栈指针,即指向PAUSE模快后的断点,压入数据栈;

将当前数据栈指针保存到当前任务的tcb[sp];

得到下一个任务status里pass或wake对应过程的pfa,并压入返回栈;

FVM虚拟机开始跳转去执行PASS或WAKE过程;

若是pass,rp0和tcbn仍在数据栈里。PASS模快将沿着多任务循环链表不断循环,跳过处于pass状态的任务,直到遇到wake为止;

若是wake,rp0和tcbm仍在数据栈里。WAKE模快将恢复处于wake状态任务的数据栈和返回栈,并由FVM实现跳转;

当退出PAUSE模块时,FVM又开始返回到PAUSE后面的断点处开始执行。

本发明提供一种基于Forth虚拟机的任务调度装置,包括:

Flash中存放在FVM上运行可重入的Forth代码以及在其之上由高级定义组成的任务创建、任务初始化、任务激活、任务调度、任务控制等模块;

RAM中有若干与用户任务相对应的由任务控制块TCB、返回栈RS、数据栈DS等组成的用户变量区,以及文本输入缓冲区TIB、其他用户变量区和普通变量区等存储项;

在Flash的Forth字典里创建一个特殊的任务定义,初始化任务用户变量区里的TCB和堆栈区,链接任务体,启动任务调度,并可以按需要随时随停止、休眠、唤醒某个任务。

与现有技术相比,本发明提供的一种基于Forth虚拟机的任务调度方法及装置在无需状态判定的情况下,就能在预定的时刻精确调度切换每一个任务。通常,轮询调度是在TCB的status单元里保存任务的状态,每次任务调度时都去循环搜索处于wake状态的任务,而在本发明中,通过引入Forth向量字pass和wake,可以使调度过程进一步优化到省去状态比较和循环跳转。这时,TCB里的status存储的就不再是任务状态,而是可随时置换的pass或wake向量字。

与现有技术相比,本发明提供的一种基于Forth虚拟机的任务调度方法及装置任务切换定位在Forth定义之间,把调度时刻精确控制在FVM每次跳转执行下一条Forth指令时,与FVM指令周期保持同步,因此只需在保存或恢复当前数据栈指针的情况下,快速完成任务调度切换。现场保护仅需要将当前返回栈指针压入数据栈,并将当前数据栈指针保存到该任务的用户变量区里;而恢复现场仅需要从该任务的用户变量区里恢复SP,并将栈顶值存入返回栈指针。

本发明的有益效果在于能够在确保良好的重构、扩展、移植、交互等Forth系统固有特性的前提下,实现精简高效,并满足特定嵌入式应用的实时性要求。

附图说明

图1为一个实施例中基于Forth虚拟机任务调度的结构示意图。

图2为一个实施例中任务调度方法的流程图。

图3为一个实施例中PASS和WAKE模块执行过程示意图。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于云南大学,未经云南大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201710810188.X/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top