一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

一种运行时访问控制装置和方法与流程

2021-11-09 23:14:00 来源:中国专利 TAG:

1.本技术涉及信息技术领域,特别涉及一种运行时隔离方法,以及一种运行时访问控制方法及计算装置。本案是针对申请号为:201910278179.x的母案,提出的分案申请。


背景技术:

2.现有技术中,特别是现有操作系统和处理器体系架构技术中,对于内存及其使用的设计更多的考虑是紧凑、方便、高效,这样的设计使得各个功能的代码之间有着错综复杂的相互联系,数据几乎没有任何封装,或者仅在高级语言的语法编译阶段具有有限的封装,而在运行时实际上可以不受任何检查的随意访问。
3.具体的,对语法的检查只能保证源码中不包含语法所不允许的非法访问,但在运行时,攻击者有可能通过某种手段改变程序的执行序或者是数据访问对象,从而打破语法规则的封装。比如,c 语言规定了类中的私有成员不可被其他类对象访问,但是如果程序被攻击,攻击者在运行时改变了函数的转移目标,就可以打破这种保护。
4.特别是对于操作系统内核而言,现有技术的上述缺陷,实质上导致内核空间是平坦的,一旦攻击者借助如果攻击者借助用户态和内核态之间的数据传输,利用内核态代码在传输、处理数据中的设计缺陷,就能够用攻击者准备好的数据几乎任意修改内核的数据、代码,进而发起攻击。
5.其中最危险的是攻击导致超越授权,例如:
6.1、超越授权读取用户数据(包括内存和外设的数据)。
7.2、超越授权写入(包括篡改、删除)用户数据。
8.3、超越授权执行系统调用。
9.4、超越授权执行应用程序。
10.一旦攻击者完成了上述动作,同时由于现有操作系统中仅有极为有限的检查机制,攻击者实质上就获得了对计算机任意访问的权限。
11.特别是在硬件设计层面,没有从架构层面,在设计的初期就考虑安全问题,更加剧了信息安全风险。现有体系架构的实现,只考虑功能实现、效率提高等使用方面的问题,并没有从体系架构的设计基点开始就专门的考虑安全问题;即便有些设计,如特权级、分页等,客观上在一定程度上为计算的提供了安全保障,但其设计的出发点仍然是为了使用而非安全,这导致安全保障不成体系,进而不足以消除攻击成立所需的必要条件。在攻击条件下,仍然存在重大安全隐患。


技术实现要素:

12.为了解决现有体系架构的设计初衷没有系统性的考虑安全的问题,本发明公开了一种安全装置,在设计基点上,就系统性的解决安全问题,同时优选的,公开一种保障装置,来保障即便在攻击状态下,安全装置也能保持有效。
13.进一步的,考虑到技术方案的可实施性,安全装置及保障装置的设计,也最大限度
的与现有硬件体系流水线机制相配合,确保在解决安全问题的同时,不影响流水线的整体设计,进而保证执行效率。
14.一种装置,其特征在于:
15.包括安全装置,和/或,保障装置;
16.所述安全装置基于硬件针对内存区域进行访问控制;所述保障装置基于硬件确保只有在特定状态下才能设置使所述安全装置有效的控制状态数据和执行使所述安全装置有效的特定指令。
17.优选的,所述装置可以称为内存系统装置。
18.所述安全装置,包括:拦截非法跨越内存区域边界的访问;提供合法跨越内存区域边界的方式。
19.所述内存区域边界是指:处理器认定的由内存地址值所构成的区域边界,和/或,处理器认定的由页面标识信息所标定的区域边界。
20.所述拦截非法跨越内存区域边界的访问,包括:如果待执行的指令地址超出处理器认定的内存区域边界,处理器报异常;如果数据读写目标匹配的地址超出读写指令对应的内存区域边界,处理器报异常。
21.所述提供合法跨越内存区域边界的方式,包括:执行专用的跨区域转移指令或发生中断/异常时,必须先转移至中转区域,再由此区域中代码进行边界切换并转移至最终的目标地址;特别的,如果二者转移到相同中转区域的共同代码位置,由硬件提供标识信息,以区别转移是由执行跨区域转移指令引起还是由产生中断/异常引起;中断返回也会导致跨区域转移。
22.所述保障装置,包括:仅在中转区域中,和/或,跨区域转移指令执行,和/或,中断/异常产生,和/或,中断返回时,才能访问确保安全装置有效所需的信息和确保保障装置有效所需的状态数据;仅有跨区域转移指令执行,和/或,中断/异常产生,和/或,中断返回导致跨区域转移。
23.优选的,在装置中设置安全功能,和/或,保障功能的开关,如关闭该开关,则装置失效。
24.一种安全装置的制作方法,包括:制作边界检查装置的方法和提供合法跨越内存区域边界的方法。
25.所述制作边界检查装置的方法包括:制作指令边界检查装置的方法和指令数据边界检查装置的方法。
26.所述制作指令边界检查装置的方法包括:由处理器认定当前内存区域范围,并判断待执行指令所在地址是否在此区域范围之内,如在,可正常取址,如不在,处理器报出异常;
27.具体的,由处理器认定当前内存区域范围,并判断待执行指令所在地址是否在此范围之内,可以采用多种方法,一种优选的方法为:处理器设置专用存储设施保存当前内存区域边界地址值,在执行指令时,判断处理器的程序计数器的地址值是否在边界范围中,如在,表明没有超出所述范围,如不在,表明超出所述范围;另一种优选的方法为:在内存页面的属性中添加标识信息,处理器记录当前页面标识信息,在执行指令时,判断处理器中程序计数器所存地址所在的页面标识信息是否与当前的页面标识信息一致,如一致,表明没有
超出所述范围,否则表明超出所述范围。
28.所述制作数据边界检查装置的方法包括:由处理器认定若干组数据存储区域边界,针对每组数据区域匹配不同的读写指令,在对内存进行读写时,根据不同的读写指令判断操作地址是否在匹配的数据边界中,如在,可正常访问,如不在,则报出异常。设置多组数据区的目的是为了区分程序的数据区、栈区以及用作其他用途的独立数据区。
29.具体的,处理器判断数据操作目标是否在匹配边界内,可以采用有多种方法:一种优选的方法为:处理器设置若干组专用存储设施保存不同类型数据区的边界地址值,在执行读写指令时,判断操作目标地址是否在指令匹配的边界范围中,如在,表明没有超出所述范围,如不在,表明超出所述范围;另一种优选的方法为:在内存页面的属性中添加标识信息,处理器记录若干组可访问的数据区域的页面标识信息,在执行读写指令时,判断操作目标地址所在的页面标识信息是否与匹配区域类型的页面标识信息一致,一致表明在可读写数据区域中,否则不在区域中。
30.优选的:在安全装置设置开关,在所述开关处在关状态时,不进行指令边界检查和数据边界检查。
31.所述提供合法跨越内存区域边界的方法包括:提供专用的跨区域转移指令,执行此类指令时,转移至中转区域;提供专用转移指令,执行此类指令时,完成由中转区域到目标区域的转移;在中断/异常发生时,通过处理器硬件机制转移至中转区域;在中断返回时,通过中断指令执行从中转区域返回中断现场,恢复现场信息。
32.所述提供专用的跨区域转移指令,执行此类指令时,转移至中转区域;提供专用转移指令,执行此类指令时,完成由中转区域到目标区域的转移;进一步包括:
33.所述跨区域转移的指令,简称第一类指令,此类指令执行时转移到中转区域入口位置,指令同时将当前区域边界切换为中转区域边界,和/或,同时也将当前可访问的数据区域边界切换为中转区域中代码可访问的数据区域边界,如果不在第一类指令中对当前区域边界进行切换,处理器需在第一类指令执行后忽略指令边界检查,优选的,中转区域入口位置可以通过默认的固定存储设施来存储,不必出现在第一类指令中;优选的,转移目标地址可以通过第一类指令的操作数指定,也可以通过特定的专用寄存器来指定;
34.所述专用转移指令,简称第二类指令,此类指令用于从中转区域转移到指定地址;和/或,指令同时将当前区域边界切换为目标地址所属区域边界,和/或,同时也将中转区域可访问的数据区域边界切换为目标区域中代码可访问的数据区域边界;优选的,第二类指令的目标地址应为第一类指令指定的转移目标地址,二者协同完成区域间的转移,优选的,如果第一类指令执行会导致处理器不进行指令边界检查,那么第二类指令则应指定是否恢复指令边界检查,优选的,转移目标地址可以通过第二类指令操作数指定,也可以通过特定的专用寄存器来指定。
35.优选的:如果安全装置包含开关,则开关处于关状态时,不能够执行第一类指令、第二类指令,执行会报出异常。
36.所述在中断/异常发生时,通过处理器硬件机制转移至中转区域,进一步包括:在产生中断/异常后,先保存中断现场的确保安全装置有效所需信息,然后将当前区域边界设置为中转区域边界,和/或,同时也将当前区域可访问的数据区域边界切换为中转区域代码可访问的数据区域边界,并转移至指定的指令位置,优选的,如果不在中断/异常产生时对
当前区域边界进行切换,处理器需在中转区域中忽略指令边界检查。
37.中断/异常的指定转移位置可以有多种选择,一种可选方法为:与第一类指令的转移到相同的中转区域,可选的,转移到同一地址,那么处理器需提供信息标识当前是由哪种触发方式导致执行到指定转移位置;另一种可选方式为:为中断/异常单独设置一个中转区域,那么这个中转区域的入口地址应被记入特定存储设施中。
38.在中断返回时,中断指令执行回到中断现场,进一步包括:恢复中断现场的确保安全装置有效所需信息,这个信息在发生中断时被记录在特定存储设施中。
39.优选的:如果安全装置包含开关,仅在开关处于开状态时,执行以上关于中断、异常、中断返回的操作。
40.一种保障装置的制作方法:将确保安全装置有效所需的信息和确保保障装置有效所需的状态数据,保存在专用存储设施中;设置专用存储设施标记各个专用存储设施的访问状态;处理器根据访问状态信息确保,只有在中转区域中,和/或,跨区域转移指令执行,和/或,中断/异常产生,和/或,中断返回时,才能访问这些存储设施;第二类指令仅可在第一类指令转移到的中转区域中执行。
41.所述确保安全装置有效所需的信息包括:全局数据所在内存区域的边界信息;栈数据所在内存区域的边界信息;其它种类数据所在内存区域边界信息;转移指令所需中转代码的首地址;转移指令所需中转区域的边界信息;中断/异常所需中转代码的首地址;中断/异常服务程序所需中转区域的边界信息;安全装置开启/关闭标识信息;优选的,转移指令和中断/异常的中转区域可以相同,所需中转代码的首地址也可以相同。
42.所述所需中转代码的首地址是指当执行第一类指令或发生中断/异常时,必须转移到的位置。
43.所述中转区域是指:当执行第一类指令或发生中断/异常时,转移地址所在区域,转移地址被记录在装置中,特别的:中转区域中的指令执行时不进行指令边界检查。
44.所述保障装置所需的状态数据包括:是否处于转移指令所需的中转区域;是否处于中断/异常所需的中转区域。
45.从上述发明内容可知,保障装置用来保障安全装置在攻击状态下不受破坏,因此,安全装置的制作方法不同,保障装置的制作方法也会相应的做调整;安全装置在拦截非法跨越内存区域边界的访问方面,设计差异体现为:处理器对边界信息的认定方法,一种是认定地址值包围而成的边界,另一种是认定页面标识信息;在提供合法跨越内存区域边界的方式方面,设计差异体现为用于转移的特定指令和中断/异常产生后转移的中转区域,可以是同一内存区域,也可以是不同内存区域;保障装置针对这两方面四种设计差异,也要做出相应的调整,这样就形成了4套安全装置制作方法和与之匹配的保障装置制作方法。
46.下面分别列举实现上述安全装置以及保障装置的四种制作方式:
47.一种安全装置,和/或,以及与之匹配的保障装置的制作方法m1:
48.所述制作方法m1的特征为:内存区域边界信息由内存地址值构成,第一类指令执行和中断/异常产生分别转移至不同中转区域,并通过专用存储设施记录安全装置所需信息和保障装置所需的状态数据,本制作方法优选的存储设施为:专用寄存器。
49.安全装置的制作方法:
50.m

a

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内
存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
51.设置专用寄存器,记录指令,和/或,数据所在内存区域边界信息,处理器据此检查指令以及数据访问是否跨边界;
52.设置专用寄存器,记录栈数据所在内存区域边界,处理器据此检查栈数据访问是否跨边界;
53.设置专用寄存器,记录其它用途数据所在内存区域边界,处理器据此检查其它用途数据访问是否跨边界;
54.设置专用寄存器,临时记录中断/异常产生时,现场边界信息,在中断返回时,处理器据此恢复现场边界信息;
55.设置专用寄存器,记录中断/异常服务程序所在内存区域边界信息;
56.设置专用寄存器,记录安全装置开启/关闭的标识信息;
57.设置专用寄存器,记录第一类指令转移的特定位置地址值;
58.设置专用寄存器,记录第一类指令转移的特定位置地址所在内存区域边界信息。
59.m

a

a2、在安全装置中增加检查待执行的指令的地址是否跨边界的功能
60.处理器根据程序计数器中的数值进行取址,判断该值是否超越了专用寄存器中保存的内存区域边界值,如是,处理器报出异常,如不是,可正常取址。
61.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行指令边界检查。
62.检查时机:优选的,处理器通过tlb(translation lookaside buffer)识别到本次处理指令地址值与上次处理的指令地址值不属同一页面时或每次使用程序计数器的值时校验其合法性,二者选一。
63.m

a

a3、在安全装置中增加检查数据访问是否跨边界的功能
64.专用边界寄存器中保存不同种类数据区的边界,包括:普通数据区、栈区、其它数据区等,每种数据区匹配不同的读写指令,执行内存读写指令时,根据该指令匹配的数据区类型选择匹配的区域边界,判断当前待操作的地址是否在匹配的区域内,如是,可执行;如不是,处理器报出异常。
65.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行数据边界检查。
66.m

a

a4、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
67.优选的,指令操作数包含:转移目标
68.指令功能:发起跨区域的转移
69.指令动作包括:自动保存下一条指令地址;将装置中专用边界寄存器的值设置为转移指令所需中转区域的边界值,和/或,将相应专用寄存器的值设置为该区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置为该区域程序可访问其它用途数据所在区域边界值;将程序计数器的值设置为中转代码的首地址,这个地址记录在安全装置的专用寄存器中。
70.优选的,可在第一类指令执行时不切换边界值,为此需要添加标识信息表明中转区域中不需要指令边界检查,标识信息存储进专用寄存器。
71.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安全功能关闭时不允许执行第一类指令,执行则报出异常。
72.m

a

a5、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
73.优选的,指令操作数包含:转移目标
74.指令功能:第一类指令执行转移到的中转区域向外的转移
75.指令动作包括:将转移目标的值赋给程序计数器,和/或,同时切换区域边界值,边界值包括指令,和/或,数据区域边界值,和/或,可访问栈区域边界值,和/或,可访问其它用途数据所在区域边界值。
76.优选的,如果第一类指令执行时标明中转区域中不需要指令边界检查,则第二类指令执行时,要标明恢复边界检查,标识信息存储进专用寄存器。
77.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安全功能关闭时不允许执行第二类指令,执行则报出异常。
78.m

a

a6、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
79.将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;将装置中专用边界寄存器的值,设置为中断/异常转移中转区域的边界信息;和/或,将相应专用寄存器的值设置中转区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置中转区域程序可访问其它用途数据所在区域边界值,转移至中断服务程序的入口地址;其余操作与现有中断/异常的处理一致。
80.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时进行与现有中断、异常处理不同的部分。
81.m

a

a7、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
82.处理器根据专用寄存器中保存现场信息,恢复确保安全装置有效所需中断/异常现场信息到相应的专用寄存器,优选的,还要恢复中断/异常发生时是否需要检查指令边界标识信息。
83.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时,恢复确保安全装置有效所需中断/异常现场信息。
84.保障装置的制作方法:
85.m

a

a8、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于中转区域:
86.设置专用寄存器,记录当前是否处于第一类指令转移到的中转区域;
87.设置专用寄存器,记录当前是否处于中断/异常产生转移到的中转区域;
88.m

a

a9、识别需要保障的寄存器的方式:
89.通过识别寄存器编址信息来认定同类寄存器属性。优选的,将同类寄存器安排在连续编址范围内,通过识别高低端编址信息来认定同类寄存器。优选的,将寄存器安排在特定的连续编址范围内,通过识别编址信息中特定位类认定寄存器属性。
90.m

a

a10、访问专用寄存器时增加访问控制的功能:
91.通过特定指令对专用寄存器进行访问,优选的,仍沿用现有寄存器访问指令,并为其增加功能,以便能够即兼容现有访问规则,又兼顾寄存器访问规则。
92.进一步的:处理器通过专用寄存器当前是否可访问这一属性信息,来认定专用寄存器当前是否可访问,如果可访问,允许特定指令执行,否则报异常。
93.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时履行更改的指令执行规则,否则沿用现有规则。
94.m

a

a11、设置允许及限制访问安全装置和保障装置的专用寄存器以及执行跨区域转移执行和专用寄存器访问指令的条件:
95.允许在关闭安全装置时设置安全装置和保障装置的专用寄存器;
96.允许第一类指令、第二类指令、中断/异常、中断返回、专用寄存器访问指令,设置安全装置和保障装置的专用寄存器;
97.允许中断/异常保存中断现场的安全装置和保障装置的专用寄存器中信息;
98.其余情况下不得改写安全装置和保障装置的专用寄存器。
99.在第一类指令执行转移到的中转区域中,不允许执行第一类指令;允许执行第二类指令;允许执行专用寄存器访问指令;优选的,不允许执行中断返回指令;
100.在中断/异常产生转移到的中转区域中,不允许执行第二类指令;允许执行第一类指令;允许执行专用寄存器访问指令;允许执行中断返回指令;
101.在非中转区域中,允许执行第一类指令,不允许执行第二类指令,不允许执行专用寄存器访问指令。优选的,不允许执行中断返回指令;
102.一种安全装置,和/或,与之匹配的保障装置的制作方法m2:
103.所述制作方法m2的特征为:内存区域边界信息由内存地址值构成,第一类指令执行和中断/异常产生分别转移至相同中转区域,优选的,转移到共同代码位置,并通过专用存储设施记录安全装置所需信息和保障装置所需的状态数据,本制作方法优选的存储设施为:专用寄存器。
104.安全装置的制作方法:
105.m

b

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
106.设置专用寄存器,记录指令,和/或,数据所在内存区域边界信息,处理器据此检查指令以及数据访问是否跨边界;
107.设置专用寄存器,记录栈数据所在内存区域边界,处理器据此检查栈数据访问是否跨边界;
108.设置专用寄存器,记录其它用途数据所在内存区域边界,处理器据此检查其它用途数据访问是否跨边界;
109.设置专用寄存器,临时记录中断/异常产生时,现场边界信息,在中断返回时,处理器据此恢复现场边界信息;
110.设置专用寄存器,记录第一类指令转移和中断/异常转移的共同地址值;
111.设置专用寄存器,记录安全装置开启/关闭的标识信息;
112.设置专用寄存器,记录第一类指令转移的特定位置地址值;
113.设置专用寄存器,记录第一类指令转移和中断/异常转移共同中转区域的边界信息。
114.m

b

a2、在安全装置中增加检查待执行的指令的地址是否跨边界的功能
115.处理器根据程序计数器中的数值进行取址,判断该值是否超越了专用寄存器中保存的内存区域边界值,如是,处理器报出异常,如不是,可正常取址。
116.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行指令边界检查。
117.检查时机:优选的,处理器通过tlb(translation lookaside buffer)识别到本次处理指令地址值与上次处理的指令地址值不属同一页面时或每次使用程序计数器的值时校验其合法性,二者选一。
118.m

b

a3、在安全装置中增加检查数据访问是否跨边界的功能
119.专用边界寄存器中保存不同种类数据区的边界,包括:普通数据区、栈区、其它数据区等,每种数据区匹配不同的读写指令,执行内存读写指令时,根据该指令匹配的数据区类型选择匹配的区域边界,判断当前待操作的地址是否在匹配的区域内,如是,可执行;如不是,处理器报出异常。
120.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行数据边界检查。
121.m

b

a4、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
122.优选的,指令操作数包含:转移目标
123.指令功能:发起跨区域的转移
124.指令动作包括:自动保存下一条指令地址;将装置中专用边界寄存器的值,设置为第一类指令转移和中断/异常转移共同中转区域的边界值,和/或,将相应专用寄存器的值设置为该区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置为该区域程序可访问其它用途数据所在区域边界值;处理器需提供信息标识,表明当前由第一类指令执行导致转移,标识信息被记录在安全装置的专用寄存器中;将程序计数器的值设置为中转代码的首地址,这个地址记录在安全装置的专用寄存器中,即第一类指令转移和中断/异常转移的共同地址值。
125.优选的,可在第一类指令执行时不切换边界值,为此需要添加标识信息表明中转区域中不需要指令边界检查,标识信息存储进专用寄存器。
126.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安全功能关闭时不允许执行第一类指令,执行则报出异常。
127.m

b

a5、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
128.优选的,指令操作数包含:转移目标
129.指令功能:第一类指令转移和中断/异常转移共同的中转区域向外的转移
130.指令动作包括:将转移目标的值赋给程序计数器,和/或,同时切换区域边界值,边界值包括指令,和/或,数据区域边界值,和/或,可访问栈区域边界值,和/或,可访问其它用途数据所在区域边界值。
131.优选的,如果第一类指令执行时标明共同的中转区域中不需要指令边界检查,则第二类指令执行时,要标明恢复边界检查,标识信息存储进专用寄存器。
132.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安全功能关闭时不允许执行第二类指令,执行则报出异常。
133.m

b

a6、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
134.将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;处理器需提供信息标识,表明当前由中断/异常产生导致转移,标识信息被记录在安全装置的专用寄存器中;将装置中专用边界寄存器的值,设置为第一类指令转移和中断/异常转移共同中转区域的边界值,和/或,将相应专用寄存器的值设置中转区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置中转区域程序可访问其它用途数据所在区域边界值;转移至第一类指令转移和中断/异常转移共同的转移地址;其余操作与现有中断、异常的处理一致。
135.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时进行与现有中断、异常处理不同的部分。
136.m

b

a7、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
137.处理器根据专用寄存器中保存现场信息,恢复确保安全装置有效所需中断/异常现场信息到相应的专用寄存器,优选的,还要恢复中断/异常发生时是否需要检查指令边界标识信息。
138.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时,恢复确保安全装置有效所需中断/异常现场信息。
139.保障装置的制作方法:
140.m

b

a8、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于中转区域:
141.设置专用寄存器,记录当前是否处于第一类指令转移和中断/异常转移共同的中转区域;
142.m

b

a9、识别需要保障的寄存器的方式:
143.通过识别寄存器编址信息来认定同类寄存器属性。优选的,将同类寄存器安排在连续编址范围内,通过识别高低端编址信息来认定同类寄存器。优选的,将寄存器安排在特定的连续编址范围内,通过识别编址信息中特定位类认定寄存器属性。
144.m

b

a10、访问专用寄存器时增加访问控制的功能:
145.通过特定指令对专用寄存器进行访问,优选的,仍沿用现有寄存器访问指令,并为其增加功能,以便能够即兼容现有访问规则,又兼顾寄存器访问规则。
146.进一步的:处理器通过专用寄存器当前是否可访问这一属性信息,来认定专用寄存器当前是否可访问,如果可访问,允许特定指令执行,否则报异常。
147.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时履行更改的指令执行规则,否则沿用现有规则。
148.m

b

a11、设置允许及限制访问安全装置和保障装置的专用寄存器以及执行跨区域转移执行和专用寄存器访问指令的条件:
149.允许在关闭安全装置时设置安全装置和保障装置的专用寄存器;
150.允许第一类指令、第二类指令、中断/异常、中断返回、专用寄存器访问指令,设置安全装置和保障装置的专用寄存器;
151.允许中断/异常保存中断现场的安全装置和保障装置的专用寄存器中信息;
152.其余情况下不得改写安全装置和保障装置的专用寄存器。
153.在第一类指令执行转移和中断/异常产生转移的共同中转区域中,不允许执行第一类指令;允许执行第二类指令;允许执行专用寄存器访问指令;允许执行中断返回指令;
154.在非中转区域中,允许执行第一类指令,不允许执行第二类指令,不允许执行专用寄存器访问指令。优选的,不允许执行中断返回指令;
155.一种安全装置,和/或,以及与之匹配的保障装置的制作方法m3:
156.所述制作方法m3的特征为:内存区域边界信息由内存地址值,和/或,页面标识值构成,第一类指令执行和中断/异常产生分别转移至不同中转区域,并通过专用存储设施记录安全装置所需信息和保障装置所需的状态数据,本制作方法优选的存储设施为:专用寄存器。特别的:内存区域边界信息可以以内存地址值,和/或,以页面标识的方式记录,本制作方法优选的记录方式为:指令,和/或,数据所在内存区域边界信息以页面标识的方式记录,栈区域以及其它用途数据所在内存区域边界信息以内存地址值方式记录。
157.安全装置的制作方法:
158.m

c

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
159.设置专用寄存器,记录指令,和/或,数据所在内存区域页面标识信息,处理器据此检查指令以及数据访问是否跨边界;
160.设置专用寄存器,记录栈数据所在内存区域边界,处理器据此检查栈数据访问是否跨边界;
161.设置专用寄存器,记录其它用途数据所在内存区域边界,处理器据此检查其它用途数据访问是否跨边界;
162.设置专用寄存器,临时记录中断/异常产生时,现场边界,和/或,页面标识信息,在中断返回时,处理器据此恢复现场边界,和/或,页面标识信息;
163.设置专用寄存器,记录中断/异常服务程序所在内存区域页面标识信息;
164.设置专用寄存器,记录安全装置开启/关闭的标识信息;
165.设置专用寄存器,记录第一类指令转移的特定位置地址值;
166.设置专用寄存器,记录第一类指令转移的特定位置地址所在内存区域页面标识信息。
167.m

c

a2、增加页表项内容
168.在现有页表结构的基础上,建立与其对应的数据结构,其中的每一项都对应一个页表项,结构中记录该页表项对应页面标识信息。将此结构体现在处理器的tlb中。
169.m

c

a3、在安全装置中增加检查待执行的指令的地址是否跨边界的功能
170.处理器根据程序计数器中的数值进行取址,判断该值所在页面标识值是否与了专
用寄存器中保存的内存区域页面标识值不一致,如是,处理器报出异常,如不是,可正常取址。
171.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行指令边界检查。
172.检查时机:优选的,处理器通过tlb(translation lookaside buffer)识别到本次处理指令地址值与上次处理的指令地址值不属同一页面时或每次使用程序计数器的值时校验其合法性,二者选一。
173.m

c

a4、在安全装置中增加检查数据访问是否跨边界的功能
174.专用边界寄存器中保存不同种类数据区的边界,包括:普通数据区、栈区、其它数据区等,每种数据区对应不同的读写指令,执行普通数据区读写指令时,判断当前待操作的地址所在页面标识信息,是否与专用寄存器中保存的数据区所在内存区域页面标识值一致,如是,可执行;如不是,处理器报出异常;执行栈区、其它数据区等读写指令时,根据该指令匹配的数据区类型选择匹配的区域边界,判断当前待操作的地址是否在匹配的区域内,如是,可执行;如不是,处理器报出异常;
175.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行数据边界检查。
176.m

c

a5、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
177.优选的,指令操作数包含:转移目标
178.指令功能:发起跨区域的转移
179.指令动作包括:自动保存下一条指令地址;将装置中专用边界寄存器的值设置为转移指令所需中转区域的页面标识值,和/或,将相应专用寄存器的值设置为该区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置为该区域程序可访问其它用途数据所在区域边界值;将程序计数器的值设置为中转代码的首地址,这个地址记录在安全装置的专用寄存器中。
180.优选的,可在第一类指令执行时不切换页面标识值,为此需要添加标识信息表明中转区域中不需要指令边界检查,标识信息存储进专用寄存器。
181.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安全功能关闭时不允许执行第一类指令,执行则报出异常。
182.m

c

a6、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
183.优选的,指令操作数包含:转移目标
184.指令功能:第一类指令执行转移到的中转区域向外的转移
185.指令动作包括:将转移目标的值赋给程序计数器,和/或,同时切换区域边界值,边界值包括指令,和/或,数据区域页面标识值,和/或,可访问栈区域边界地址值,和/或,可访问其它用途数据所在区域边界地址值。
186.优选的,如果第一类指令执行时标明中转区域中不需要指令边界检查,则第二类指令执行时,要标明恢复边界检查,标识信息存储进专用寄存器。
187.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安
全功能关闭时不允许执行第二类指令,执行则报出异常。
188.m

c

a7、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
189.将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;将装置中专用边界寄存器的值,设置为中断/异常转移中转区域的页面标识信息;和/或,将相应专用寄存器的值设置中转区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置中转区域程序可访问其它用途数据所在区域边界值;转移至中断服务程序的入口地址;其余操作与现有中断、异常的处理一致。
190.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时进行与现有中断、异常处理不同的部分。
191.m

c

a8、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
192.处理器根据专用寄存器中保存现场信息,恢复确保安全装置有效所需中断/异常现场信息到相应的专用寄存器,优选的,还要恢复中断/异常发生时是否需要检查指令边界标识信息。
193.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时,恢复确保安全装置有效所需中断/异常现场信息,和/或,页面标识信息。
194.保障装置的制作方法:
195.m

c

a9、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于中转区域:
196.设置专用寄存器,记录当前是否处于第一类指令转移到的中转区域;
197.设置专用寄存器,记录当前是否处于中断/异常产生转移到的中转区域;
198.m

c

a10、识别需要保障的寄存器的方式:
199.通过识别寄存器编址信息来认定同类寄存器属性。优选的,将同类寄存器安排在连续编址范围内,通过识别高低端编址信息来认定同类寄存器。优选的,将寄存器安排在特定的连续编址范围内,通过识别编址信息中特定位类认定寄存器属性。
200.m

c

a11、访问专用寄存器时增加访问控制的功能:
201.通过特定指令对专用寄存器进行访问,优选的,仍沿用现有寄存器访问指令,并为其增加功能,以便能够即兼容现有访问规则,又兼顾寄存器访问规则。
202.进一步的:处理器通过专用寄存器当前是否可访问这一属性信息,来认定专用寄存器当前是否可访问,如果可访问,允许特定指令执行,否则报异常。
203.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时履行更改的指令执行规则,否则沿用现有规则。
204.m

c

a12、设置允许及限制访问安全装置和保障装置的专用寄存器以及执行跨区域转移执行和专用寄存器访问指令的条件:
205.允许在关闭安全装置时设置安全装置和保障装置的专用寄存器;
206.允许第一类指令、第二类指令、中断/异常、中断返回、专用寄存器访问指令,设置安全装置和保障装置的专用寄存器;
207.允许中断/异常保存中断现场的安全装置和保障装置的专用寄存器中信息;
208.其余情况下不得改写安全装置和保障装置的专用寄存器。
209.在第一类指令执行转移到的中转区域中,不允许执行第一类指令;允许执行第二类指令;允许执行专用寄存器访问指令;优选的,不允许执行中断返回指令;
210.在中断/异常产生转移到的中转区域中,不允许执行第二类指令;允许执行第一类指令;允许执行专用寄存器访问指令;允许执行中断返回指令;
211.在非中转区域中,允许执行第一类指令,不允许执行第二类指令,不允许执行专用寄存器访问指令。优选的,不允许执行中断返回指令;
212.一种安全装置,和/或,与之匹配的保障装置的制作方法m4:
213.所述制作方法m4的特征为:内存区域边界信息由内存地址值,和/或,页面标识值构成,第一类指令执行和中断/异常产生分别转移至相同中转区域,优选的,转移到共同代码位置,并通过专用存储设施记录安全装置所需信息和保障装置所需的状态数据,本制作方法优选的存储设施为:专用寄存器。特别的:内存区域边界信息可以以内存地址值,和/或,以页面标识的方式记录,本制作方法优选的记录方式为:指令,和/或,数据所在内存区域边界信息以页面标识的方式记录,栈区域以及其它用途数据所在内存区域边界信息以内存地址值方式记录。
214.安全装置的制作方法:
215.m

d

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
216.设置专用寄存器,记录指令,和/或,数据所在内存区域页面标识信息,处理器据此检查指令以及数据访问是否跨边界;
217.设置专用寄存器,记录栈数据所在内存区域边界,处理器据此检查栈数据访问是否跨边界;
218.设置专用寄存器,记录其它用途数据所在内存区域边界,处理器据此检查其它用途数据访问是否跨边界;
219.设置专用寄存器,临时记录中断/异常产生时,现场边界,和/或,页面标识信息,在中断返回时,处理器据此恢复现场边界,和/或,页面标识信息;
220.设置专用寄存器,记录第一类指令转移和中断/异常转移的共同地址值;
221.设置专用寄存器,记录安全装置开启/关闭的标识信息;
222.设置专用寄存器,记录第一类指令转移的特定位置地址值;
223.设置专用寄存器,记录第一类指令转移和中断/异常转移共同中转区域的页面标识信息。
224.m

d

a2、增加页表项内容
225.在现有页表结构的基础上,建立与其对应的数据结构,其中的每一项都对应一个页表项,结构中记录该页表项对应页面标识信息。将此结构体现在处理器的tlb中。
226.m

d

a3、在安全装置中增加检查待执行的指令的地址是否跨边界的功能
227.处理器根据程序计数器中的数值进行取址,判断该值所在页面标识值是否与了专用寄存器中保存的内存区域页面标识值不一致,如是,处理器报出异常,如不是,可正常取址。
228.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行指令边界检查。
229.检查时机:优选的,处理器通过tlb(translation lookaside buffer)识别到本次处理指令地址值与上次处理的指令地址值不属同一页面时或每次使用程序计数器的值时校验其合法性,二者选一。
230.m

d

a4、在安全装置中增加检查数据访问是否跨边界的功能
231.专用边界寄存器中保存不同种类数据区的边界,包括:普通数据区、栈区、其它数据区等,每种数据区匹配不同的读写指令,执行普通数据区读写指令时,判断当前待操作的地址所在页面标识信息,是否与专用寄存器中保存的数据区所在内存区域页面标识值一致,如是,可执行;如不是,处理器报出异常;执行栈区、其它数据区等读写指令时,根据该指令匹配的数据区类型选择匹配的区域边界,判断当前待操作的地址是否在匹配的区域内,如是,可执行;如不是,处理器报出异常;
232.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时进行数据边界检查。
233.m

d

a5、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
234.优选的,指令操作数包含:转移目标
235.指令功能:发起跨区域的转移
236.指令动作包括:自动保存下一条指令地址;将装置中专用边界寄存器的值,设置为第一类指令转移和中断/异常转移共同中转区域的页面标识值,该值被记录在安全装置的专用寄存器中,和/或,将相应专用寄存器的值设置为该区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置为该区域程序可访问其它用途数据所在区域边界值;处理器需提供信息标识,表明当前由第一类指令执行导致转移,标识信息被记录在安全装置的专用寄存器中;将程序计数器的值设置为中转代码的首地址,这个地址记录在安全装置的专用寄存器中,即第一类指令转移和中断/异常转移的共同地址值。
237.优选的,可在第一类指令执行时不切换页面标识值,为此需要添加标识信息表明中转区域中不需要指令边界检查,标识信息存储进专用寄存器。
238.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安全功能关闭时不允许执行第一类指令,执行则报出异常。
239.m

d

a6、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
240.优选的,指令操作数包含:转移目标
241.指令功能:第一类指令转移和中断/异常转移共同的中转区域向外的转移
242.指令动作包括:将转移目标的值赋给程序计数器,和/或,同时切换区域边界值,边界值包括指令,和/或,数据区域页面标识值,和/或,可访问栈区域边界地址值,和/或,可访问其它用途数据所在区域边界地址值。
243.优选的,如果第一类指令执行时标明中转区域中不需要指令边界检查,则第二类指令执行时,要标明恢复边界检查,标识信息存储进专用寄存器。
244.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,在寄存器标识安
全功能关闭时不允许执行第二类指令,执行则报出异常。
245.m

d

a7、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
246.将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;处理器需提供信息标识,表明当前由中断/异常产生导致转移,标识信息被记录在安全装置的专用寄存器中;将装置中专用边界寄存器的值,设置为第一类指令转移和中断/异常转移共同中转区域的页面标识值,和/或,将相应专用寄存器的值设置中转区域程序可访问栈区域边界值,和/或,将相应专用寄存器的值设置中转区域程序可访问其它用途数据所在区域边界值;转移至第一类指令转移和中断/异常转移共同的转移地址;其余操作与现有中断、异常的处理一致。
247.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时进行与现有中断、异常处理不同的部分。
248.m

d

a8、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
249.处理器根据专用寄存器中保存现场信息,恢复确保安全装置有效所需中断/异常现场信息到相应的专用寄存器,优选的,还要恢复中断/异常发生时是否需要检查指令边界标识信息。
250.优选的,如果安全装置包含专用寄存器指定安全功能是否开启,仅在寄存器标识安全功能开启时,恢复确保安全装置有效所需中断/异常现场信息。
251.保障装置的制作方法:
252.m

d

a9、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于中转区域:
253.设置专用寄存器,记录当前是否处于第一类指令转移和中断/异常转移共同的中转区域;
254.m

d

a10、识别需要保障的寄存器的方式:
255.通过识别寄存器编址信息来认定同类寄存器属性。优选的,将同类寄存器安排在连续编址范围内,通过识别高低端编址信息来认定同类寄存器。优选的,将寄存器安排在特定的连续编址范围内,通过识别编址信息中特定位类认定寄存器属性。
256.m

d

a11、访问专用寄存器时增加访问控制的功能:
257.通过特定指令对专用寄存器进行访问,优选的,仍沿用现有寄存器访问指令,并为其增加功能,以便能够即兼容现有访问规则,又兼顾寄存器访问规则。
258.进一步的:处理器通过专用寄存器当前是否可访问这一属性信息,来认定专用寄存器当前是否可访问,如果可访问,允许特定指令执行,否则报异常。
259.优选的,如果安全装置包含用于开关设置的专用寄存器,仅在专用寄存器标识为开启时履行更改的指令执行规则,否则沿用现有规则。
260.m

d

a12、设置允许及限制访问安全装置和保障装置的专用寄存器以及执行跨区域转移执行和专用寄存器访问指令的条件:
261.允许在关闭安全装置时设置安全装置和保障装置的专用寄存器;
262.允许第一类指令、第二类指令、中断/异常、中断返回、专用寄存器访问指令,设置安全装置和保障装置的专用寄存器;
263.允许中断/异常保存中断现场的安全装置和保障装置的专用寄存器中信息;
264.其余情况下不得改写安全装置和保障装置的专用寄存器。
265.在第一类指令执行转移和中断/异常产生转移的共同中转区域中,不允许执行第一类指令;允许执行第二类指令;允许执行专用寄存器访问指令;允许执行中断返回指令;
266.在非中转区域中,允许执行第一类指令,不允许执行第二类指令,不允许执行专用寄存器访问指令。优选的,不允许执行中断返回指令。
267.通过上述方法,本发明能够起到以下技术效果:
268.设置专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息,处理器通过寄存器时时获取这些信息,以此确保安全装置有效。特别的,专用寄存器组为基于保证信息安全目的访问控制提供了更为方便、有效的识别特征。
269.通过从寄存器中获取的内存区域边界信息,处理器可以通过它和当前程序计数器中地址值做比对,来进行指令边界检查。
270.通过从寄存器中获取的数据内存区域边界信息,以及设定的与不同种类数据区域匹配的读写指令,处理器可以据此判定数据访问是否超越区域边界。
271.安全装置还提出了区域间合法的转移方式:通过增加的第一类指令,可以发起跨区域转移动作,并转移到中转区域;通过增加的第二类指令,可以从中转区域中转移到目标区域;中断/异常产生时保护安全装置现场信息,中断返回时恢复安全装置现场信息,可以确保安全装置在中断现场有效。
272.中转区域的提出,可以把本该由第一类指令完成的区域间转移的合法性检查工作,转交中转区域中软件程序实现,这极大的降低了第一类指令的执行周期,为融入现有流水线整体设计,创造了基础。
273.保障装置的核心任务就是记录当前是否处于中转区域中,而且确保,只有在中转区域中,才能访问确保安全装置和保障装置有效的专用寄存器,同时限定第一类、第二类指令能否在中转区域、非中转区域中执行。
具体实施方式
274.下面对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
275.以下通过具体实施方式来具体说明本发明的技术方案。
276.实施例1:
277.在risc

v体系下,一种安全装置,和/或,以及与之匹配的保障装置的具体实施方式s1:
278.所述实施方式s1的特征为:在risc

v体系下,内存区域边界信息由内存地址值构成,第一类指令执行和中断/异常产生分别转移至不同中转区域,并通过专用存储设施记录
安全装置所需信息和保障装置所需的状态数据,本实施例优选的存储设施为:专用寄存器。
279.安全装置的实施方式:
280.s

a

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
281.处理器在运行过程中需动态获得一些数据以保证安全装置的正常运行,因此添加一些寄存器供处理器使用。在精简指令集rsic

v中,有4096个预设控制状态寄存器供使用,我们选择其中的一些作为增设的控制状态寄存器。为了与rsic兼容,除了满足其寄存器的编码规则与使用规范外,还为寄存器增添一种属性,即,与安全装置相关性,所述相关性是指:如果寄存器与安全装置相关,则对该寄存器的访问属性增加内容为:只有“当前模式安全装置失效”或“当前模式安全装置生效且当前处于中转区域”时,可访问,否则访问报异常;如果寄存器与安全装置不相关,则按照rsic

v现有规则对寄存器进行访问。
282.增设寄存器:csr_emsur(32/64位)
283.访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
284.功能描述:用来标识不同模式下安全装置是否生效。
285.寄存器中各个位信息含义:
286.0位(表示u模式下是否开启安全装置):
287.为0,表示关闭
288.为1,表示开启
289.1位:(表示s模式下是否开启安全装置)
290.为0,表示关闭
291.为1,表示开启
292.增设寄存器:csr_cmsattr(32/64位)
293.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
294.功能描述:用来标识当前是否检查指令边界
295.寄存器中各个位信息含义:
296.0位(是否检查指令边界标识位):
297.为0,表示需要检查
298.为1,表示不需要检查
299.增设寄存器:csr_cmslside(32/64位)
300.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
301.功能描述:用来保存连续内存区域低端地址值。
302.增设寄存器:csr_cmshside(32/64位)
303.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
304.功能描述:用来保存连续内存区域高端地址值。
305.增设寄存器:csr_cmsebp(32/64位)
306.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
307.功能描述:用来保存栈区域高端地址值。
308.增设寄存器:csr_cmsesp(32/64位)
309.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
310.功能描述:用来保存栈区域低端地址值。
311.增设寄存器:csr_cbmsebp(32/64位)
312.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
313.功能描述:用来保存其它种类数据所在连续内存区域高端地址值。
314.增设寄存器:csr_cbmsesp(32/64位)
315.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
316.功能描述:用来保存其它种类数据所在连续内存区域低端地址值。
317.增设寄存器:csr_mschaddr(32/64位)
318.访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
319.功能描述:用来保存第一类指令转移目标地址值。
320.增设寄存器:csr_utmslside(32/64位)
321.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
322.功能描述:中断或异常在u模式下产生时,用来临时保存csr_cmslside寄存器数值。
323.增设寄存器:csr_utmshside(32/64位)
324.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
325.功能描述:中断或异常在u模式下产生时,用来临时保存csr_cmshside寄存器数值。
326.增设寄存器:csr_utmsattr(32/64位)
327.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
328.功能描述:中断或异常在u模式下产生时,用来临时保存csr_cmsattr寄存器数值。
329.增设寄存器:csr_stmslside(32/64位)
330.访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
331.功能描述:中断或异常在s模式下产生时,用来临时保存csr_cmslside寄存器数值。
332.增设寄存器:csr_stmshside(32/64位)
333.访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
334.功能描述:中断或异常在s模式下产生时,用来临时保存csr_cmshside寄存器数值。
335.增设寄存器:csr_stmsattr(32/64位)
336.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
337.功能描述:中断或异常在s模式下产生时,用来临时保存csr_cmsattr寄存器数值。
338.增设寄存器:csr_smsirladdr(32/64位)
339.访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
340.功能描述:用来保存s模式下中断服务程序内存区域低端地址值。
341.增设寄存器:csr_smsirhaddr(32/64位)
342.访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
343.功能描述:用来保存s模式下中断服务程序内存区域高端地址值。
344.增设寄存器:csr_umsirladdr(32/64位)
345.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
346.功能描述:用来保存u模式下中断服务程序内存区域低端地址值。
347.增设寄存器:csr_umsirhaddr(32/64位)
348.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
349.功能描述:用来保存u模式下中断服务程序内存区域高端地址值。
350.s

a

a2、在安全装置中增加检查待执行的指令的地址是否跨边界的功能
351.只有在当前模式开启安全装置,且当前需要进行指令边界检查时,进行边界检查,即检查当前程序计数器中数值是否处于处理器认定的内存区域范围内,如果不超出范围,允许执行,否则报异常。具体包括:
352.只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1,且csr_cmsattr寄存器0位为0,的情况下,进行边界检查,检查内容是:如果pc小于csr_cmslside寄存器中数值或大于等于csr_cmshside寄存器中数值,报异常,否则正常执行。
353.检查时机:优选的,处理器通过tlb(translation lookaside buffer)识别到本次处理指令地址值与上次处理的指令地址值不属同一页面时或每次使用程序计数器的值时校验其合法性,二者选一。
354.优选的:进行边界检查时,安全机制开启/关闭检查、csr_cmsattr寄存器属性位检查、比较高端地址和低端地址的动作,可以通过增加流水线功能的方式同时进行,以此达到不增加流水线中指令执行周期,进而不降低流水线整体执行效率的目的。
355.s

a

a3、在安全装置中增加检查数据访问是否跨边界的功能
356.只有在当前模式开启安全装置的情况下,对访问普通数据区域的特定指令,进行
边界检查,即检查数据访问目标地址是否处于普通数据区域内,如果不超出范围,允许执行,否则报异常,具体包括:
357.增加load、store指令功能:
358.增加功能为:
359.只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,进行边界检查,检查内容是:如果数据访问内存地址值小于csr_cmslside寄存器中数值或大于等于csr_cmshside寄存器中数值,报异常,否则正常执行。
360.只有在当前模式开启安全装置的情况下,对访问栈区域的特定指令,进行边界检查,即检查数据访问目标地址是否处于栈区域内,如果不超出范围,允许执行,否则报异常,具体包括:
361.增加sload、sstore指令:
362.格式和功能与risc

v现有体系下load、store指令一致。
363.增加功能为:
364.只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,进行边界检查,检查内容是:如果访问内存地址值小于csr_cmsesp寄存器中数值或大于等于csr_cmsebp寄存器中数值,报异常,否则正常执行。csr_emsur寄存器为0时执行,报异常。
365.只有在当前模式开启安全装置的情况下,对访问其它种类数据所在区域的特定指令,进行边界检查,即检查数据访问目标地址是否处于其它种类数据所在区域内,如果不超出范围,允许执行,否则报异常,具体包括:
366.增加bload、bstore指令:
367.格式和功能与risc

v现有体系下load、store指令一致。
368.增加功能为:
369.只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,进行边界检查,检查内容是:如果访问内存地址值小于csr_cbmsesp寄存器中数值或大于等于csr_cbmsebp寄存器中数值,报异常,否则正常执行。csr_emsur寄存器为0时执行,报异常。
370.优选的:进行边界检查时,安全装置开启/关闭检查、比较高端地址和低端地址的动作,可以通过增加流水线功能的方式同时进行,以此达到不增加流水线中指令执行周期,进而不降低流水线整体执行效率的目的。
371.s

a

a4、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
372.采用优选方案,开启安全装置前提下,第一类指令可执行,不切换边界值,并标识中转区域中不做指令边界检查,保存下一条指令地址,并将程序计数器的值设置为中转代码的首地址。具体包括:
373.指令格式:jalrmsu ra rs
374.功能:
375.只有在当前模式开启安全装置前提下,即只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1,指令可执行,否则报异常;指令执行时,将csr_cmsattr寄
存器0位置1,用pc 4设置rd,rd默认为x1,即ra,用csr_mschaddr寄存器中数值设置pc。rs用来指定目标地址值。
376.s

a

a5、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
377.采用优选方案,开启安全装置前提下,第二类指令可执行,不切换边界值,并标识从中转区域转移到外部区域后,做指令边界检查,执行转移到的中转区域向外的转移。具体包括:
378.指令格式:jalrchmsu ra rs
379.功能:
380.只有在当前模式开启安全装置前提下,即只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1,指令可执行,否则报异常;指令执行时,将csr_cmsattr寄存器0位置0,用rs寄存器中数值设置pc。
381.优选的,rs中保存b指令中指定的目标地址值。
382.s

a

a6、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
383.将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;将装置中专用边界寄存器的值,设置为中断/异常转移中转区域的边界信息;转移至中断服务程序的入口地址;其余操作与现有中断、异常的处理一致。具体包括:
384.中断或异常产生时:
385.如果当前模式为u,则检查中断委托到的模式:
386.如果委托到u模式,则检查u模式下是否打开安全装置,即检查csr_emsur寄存器0位是否为1,如果为1,用csr_utmsattr寄存器保存csr_cmsattr寄存器的数值,把csr_cmsattr寄存器0位置1,分别用csr_utmslside、csr_utmshside寄存器保存csr_cmslside、csr_cmshside寄存器的数值,之后分别用csr_umsirladdr、csr_umsirhaddr这两个寄存器的值设置csr_cmslside、csr_cmshside寄存器,最后沿用risc

v现有规则转移至中断服务程序入口地址;
387.如果委托到s模式,则检查s模式下是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,则用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,把csr_cmsattr寄存器0位置1,分别用csr_stmslside、csr_stmshside寄存器保存csr_cmslside、csr_cmshside寄存器的数值,之后分别用csr_smsirladdr、csr_smsirhaddr这两个寄存器的值设置csr_cmslside、csr_cmshside寄存器,最后沿用risc

v现有规则转移至中断服务程序入口地址;
388.如果当前模式为s,且委托到的模式是s或u,则检查s模式是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,则用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,把csr_cmsattr寄存器0位置1,分别用csr_stmslside、csr_stmshside寄存器保存csr_cmslside、csr_cmshside寄存器的数值,之后分别用csr_smsirladdr、csr_smsirhaddr这两个寄存器的值设置csr_cmslside、csr_cmshside寄存器,最后沿用risc

v现有规则转移至中断服务程序入口地址。
389.s

a

a7、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
390.处理器根据专用寄存器中保存现场信息,恢复确保安全装置有效所需中断/异常现场信息到相应的专用寄存器,优选的,还要恢复中断/异常发生时是否需要检查指令边界标识信息。具体包括:
391.在当前模式打开安全装置的前提下,即在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的前提下,指令执行时,如果当前模式为s,则用csr_stmsattr寄存器数值设置csr_cmsattr寄存器的数值,用csr_stmslside、csr_stmshside寄存器恢复csr_cmslside、csr_cmshside寄存器的数值;如果当前模式为u,则用csr_utmsattr寄存器数值设置csr_cmsattr寄存器的数值,用csr_utmslside、csr_utmshside寄存器恢复csr_cmslside、csr_cmshside寄存器的数值。
392.保障装置的实施方式:
393.s

a

a8、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于中转区域:
394.沿用安全装置的寄存器:csr_cmsattr(32/64位)
395.访问属性:r/w:可读写;privilege:u;standard/not:非标准;与保障装置相关性:相关
396.功能描述:用来标识当前是否处于第一类指令转移到的中转区域,是否处于中断/异常产生转移到的中转区域。
397.寄存器中各个位信息含义:
398.0位(当前是否处于中转区域标志位):
399.为0,表示当前不处于中转区域
400.为1,表示当前处于中转区域
401.1位(当前处于中转区域种类标志位):
402.为0,表示当前处于第一类指令转移到的中转区域
403.为1,表示处于中断/异常产生转移到的中转区域
404.特别的:安全装置和保障装置共用csr_cmsattr寄存器,这是因为,安全装置中规定,只有在中转区域中不进行指令边界检查;保障装置也通过当前是否处于中转区域,来限制是否能访问与安全装置相关寄存器,以及是否能执行合法的跨区域转移执行,这样,csr_cmsattr寄存器0位,用同样的数值,既可以标识当前是否不需要指令检查,又可以标识当前是否处于中转区域,两者并不冲突。
405.s

a

a9、识别需要保障的寄存器的方式:
406.为了方便的识别到控制状态寄存器是否与安全装置相关,具体的处理方式为:
407.第一种:
408.在“r/w:可读写;privilege:s;standard/not:非标准”这一属性组合所对应的64个预设寄存器空间的某一空余的连续编址位置处,放置“r/w:可读写;privilege:s;standard/not:非标准”对应的与安全装置相关的控制状态寄存器;
409.硬件设备识别控制状态寄存器的时,只要判断是否处于特定的连续编址范围内,就可以分辨出与安全装置相关的控制状态寄存器。
410.第二种:
411.和第一种相比,为了更简化判断逻辑,把与安全装置相关控制状态寄存器的编址位置从高地址往低地址连续排列,如(0位到5位:从111111往低地址排),这样只要识别5位为1,就可以识别出它与安全装置相关。
412.s

a

a10、访问专用寄存器时增加访问控制的功能:
413.沿用并增加risc

v体系下csrr、csrw、csrwi指令功能,具体实现方式包括:
414.处理器通过增设寄存器中记录信息,来履行相关性规则,以及risc

v中现有控制状态寄存器访问规则:只有“当前模式安全装置关闭”或“当前模式安全装置开启且当前处于中转区域时,才可通过csrr、csrw、csrwi指令访问与安全装置相关的寄存器,否则访问报异常,即,只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为0,或者,csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1且csr_cmsattr寄存器0位为1,的情况下,才能通过csrr、csrw、csrwi指令访问相关寄存器;
415.特别的:如果当前模式为m,默认安全装置失效。
416.s

a

a11、允许及限制访问安全装置和保障装置的专用寄存器以及执行跨区域转移执行和专用寄存器访问指令的条件:
417.允许在关闭安全装置时设置安全装置和保障装置的专用寄存器,具体包括:在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为0的情况下,允许设置。
418.允许第一类指令、第二类指令、中断/异常、中断返回、专用寄存器访问指令,设置安全装置和保障装置的专用寄存器,具体包括:jalrmsu指令执行时以及中断/异常产生时,将csr_cmsattr寄存器0位置1;jalrchmsu指令执行时,用rd寄存器中数值设置csr_cmsattr寄存器,rd默认为x1,即ra,优选的,如果目标区域为非中转区域,ra寄存器0位置0,1位置0,如果目标区域为中断/异常转移中转区域,ra寄存器0位置1,1位置1;中断返回时,恢复csr_cmsattr寄存器数值;允许通过csrr、csrw、csrwi指令访问增设寄存器。
419.允许中断/异常保存中断现场的安全装置和保障装置的专用寄存器中信息,具体包括:保存的增设寄存器信息与安全装置和保障装置中保存增设寄存器信息一致。
420.其余情况下不得改写安全装置和保障装置的专用寄存器,具体包括:在安全装置开启的前提下,如果处于非中转区域,不允许设置与安全装置和保障装置相关的寄存器,即,在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,如果csr_cmsattr寄存器0位为0,不允许设置相关寄存器。
421.在第一类指令执行转移到的中转区域中,不允许执行第一类指令;允许执行第二类指令;允许执行专用寄存器访问指令,不允许执行中断返回指令,具体包括:在安全装置开启的前提下,即在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,如果csr_cmsattr寄存器0位为1,1位为0,不允许执行jalrmsu指令,允许执行jalrchmsu指令,允许执行csrr、csrw、csrwi指令,不允许执行中断返回指令;
422.在中断/异常产生转移到的中转区域中,不允许执行第二类指令;允许执行第一类指令;允许执行专用寄存器访问指令,允许执行中断返回指令,具体包括;在安全装置开启的前提下,即在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,如果csr_cmsattr寄存器0位为1,1位为1,不允许执行jalrchmsu指令,允许执行jalrmsu指令,允许执行csrr、csrw、csrwi指令,允许执行中断返回指令;
423.在非中转区域中,允许执行第一类指令,不允许执行第二类指令,不允许执行专用寄存器访问指令,不允许执行中断返回指令,具体包括:在安全装置开启的前提下,即,在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,如果csr_cmsattr寄存器0位为0,允许执行jalrmsu指令,不允许执行jalrchmsu指令,不允许执行csrr、csrw、csrwi指令,不允许执行中断返回指令。
424.实施例2:
425.在risc

v体系下,一种安全装置,和/或,以及与之匹配的保障装置的具体实施方式s2:
426.所述实施方式s2的特征为:在risc

v体系下,内存区域边界信息由内存地址值构成,第一类指令执行和中断/异常产生分别转移至相同中转区域,优选的,转移到共同代码位置,并通过专用存储设施记录安全装置所需信息和保障装置所需的状态数据,本实施例优选的存储设施为:专用寄存器。二者可以转移至共同中转区域的相同地址或不同地址,本制作方法优选转移到共同地址。
427.安全装置的实施方式:
428.s

b

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
429.在实施例1中s

a

a1所述内容基础上
430.将:
[0431]“增设寄存器:csr_cmsattr(32/64位)
[0432]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0433]
功能描述:用来标识当前是否检查指令边界
[0434]
寄存器中各个位信息含义:
[0435]
0位(是否检查指令边界标识位):
[0436]
为0,表示需要检查
[0437]
为1,表示不需要检查”[0438]
替换为:
[0439]“增设寄存器:csr_cmsattr(32/64位)
[0440]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0441]
功能描述:用来标识当前是否检查指令边界,以及标识转移至中转区域的原因
[0442]
寄存器中各个位信息含义:
[0443]
0位(是否检查指令边界标识位):
[0444]
为0,表示需要检查
[0445]
为1,表示不需要检查
[0446]
1位(转移至中转区域的原因):
[0447]
为0,由于第一类指令执行转移至中转区域
[0448]
为1,由于中断/异常产生转移至中转区域”[0449]
将:
[0450]“增设寄存器:csr_mschaddr(32/64位)
[0451]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0452]
功能描述:用来保存第一类指令转移目标地址值。”[0453]
替换为:
[0454]“增设寄存器:csr_umschaddr(32/64位)
[0455]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0456]
功能描述:用来保存u模式下第一类指令转移和中断/异常转移共同的目标地址值。
[0457]
增设寄存器:csr_smschaddr(32/64位)
[0458]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0459]
功能描述:用来保存s模式下第一类指令转移和中断/异常转移共同的目标地址值。”[0460]
将:
[0461]“增设寄存器:csr_smsirladdr(32/64位)
[0462]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0463]
功能描述:用来保存s模式下中断服务程序内存区域低端地址值。
[0464]
增设寄存器:csr_smsirhaddr(32/64位)
[0465]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0466]
功能描述:用来保存s模式下中断服务程序内存区域高端地址值。
[0467]
增设寄存器:csr_umsirladdr(32/64位)
[0468]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0469]
功能描述:用来保存u模式下中断服务程序内存区域低端地址值。
[0470]
增设寄存器:csr_umsirhaddr(32/64位)
[0471]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0472]
功能描述:用来保存u模式下中断服务程序内存区域高端地址值。”[0473]
替换为:
[0474]“增设寄存器:csr_smschladdr(32/64位)
[0475]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0476]
功能描述:用来保存s模式下第一类指令转移和中断/异常转移的中转区域的低端地址值。
[0477]
增设寄存器:csr_smschhaddr(32/64位)
[0478]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0479]
功能描述:用来保存s模式下第一类指令转移和中断/异常转移的中转区域的高端地址值。
[0480]
增设寄存器:csr_umschladdr(32/64位)
[0481]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0482]
功能描述:用来保存u模式下第一类指令转移和中断/异常转移的中转区域的低端地址值。
[0483]
增设寄存器:csr_umschhaddr(32/64位)
[0484]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0485]
功能描述:用来保存u模式下第一类指令转移和中断/异常转移的中转区域的高端地址值。”[0486]
其余内容一致。
[0487]
s

b

a2、在安全装置中增加检查待执行的指令的地址是否跨边界的功能与实施例1中s

a

a2所述内容一致。
[0488]
s

b

a3、在安全装置中增加检查数据访问是否跨边界的功能
[0489]
与实施例1中s

a

a3所述内容一致。
[0490]
s

b

a4、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
[0491]
采用优选方案,开启安全装置前提下,第一类指令可执行,不切换边界值,并标识中转区域中不做指令边界检查,标识当前是第一类指令执行导致转移,保存下一条指令地址,并将程序计数器的值设置为中转代码的首地址。具体包括:
[0492]
指令格式:jalrmsu ra rs
[0493]
功能:
[0494]
只有在当前模式开启安全装置前提下,即只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1,指令可执行,否则报异常;指令执行时,将csr_cmsattr寄存器0位置1,1位置0,用pc 4设置rd,rd默认为x1,即ra,用csr_mschaddr寄存器中数值设置pc。rs用来指定目标地址值。
[0495]
s

b

a5、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
[0496]
与实施例1中s

a

a5所述内容一致。
[0497]
s

b

a6、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
[0498]
将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;处理器需提供信息标识,表明当前由中断/异常产生导致转移,标识信息被记录在安全装置的专用寄存器中;将装置中专用边界寄存器的值,设置为第一类指令转移和中断/异常转移共同
中转区域的边界值;转移至第一类指令转移和中断/异常转移共同的转移地址;其余操作与现有中断、异常的处理一致。具体包括:
[0499]
中断或异常产生时:
[0500]
如果当前模式为u,则检查中断委托到的模式:
[0501]
如果委托到u模式,则检查u模式下是否打开安全装置,即检查csr_emsur寄存器0位是否为1,如果为1,用csr_utmsattr寄存器保存csr_cmsattr寄存器的数值,将csr_cmsattr寄存器0位置1,1位置1,分别用csr_utmslside、csr_utmshside寄存器保存csr_cmslside、csr_cmshside寄存器的数值,之后分别用csr_umschladdr、csr_umschhaddr这两个寄存器的值设置csr_cmslside、csr_cmshside寄存器,最后用csr_umschaddr寄存器中数值设置pc;
[0502]
如果委托到s模式,则检查s模式下是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,则用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,将csr_cmsattr寄存器0位置1,1位置1,分别用csr_stmslside、csr_stmshside寄存器保存csr_cmslside、csr_cmshside寄存器的数值,之后分别用csr_smschladdr、csr_smschhaddr这两个寄存器的值设置csr_cmslside、csr_cmshside寄存器,最后用csr_smschaddr寄存器中数值设置pc;
[0503]
如果当前模式为s,且委托到的模式是s或u,则检查s模式是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,则用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,将csr_cmsattr寄存器0位置1,1位置1,分别用csr_stmslside、csr_stmshside寄存器保存csr_cmslside、csr_cmshside寄存器的数值,将csr_cmsattr寄存器0位置1,1位置1,之后分别用csr_smschladdr、csr_smschhaddr这两个寄存器的值设置csr_cmslside、csr_cmshside寄存器,最后用csr_smschaddr寄存器中数值设置pc。
[0504]
s

b

a7、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
[0505]
处理器根据专用寄存器中保存现场信息,恢复确保安全装置有效所需中断/异常现场信息到相应的专用寄存器,优选的,还要恢复中断/异常发生时是否需要检查指令边界标识信息。具体包括:
[0506]
在当前模式打开安全装置的前提下,即在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的前提下,指令执行时,如果当前模式为s,则用csr_stmsattr寄存器数值设置csr_cmsattr寄存器的数值,用csr_stmslside、csr_stmshside寄存器恢复csr_cmslside、csr_cmshside寄存器的数值;如果当前模式为u,则用csr_utmsattr寄存器数值设置csr_cmsattr寄存器的数值,用csr_utmslside、csr_utmshside寄存器恢复csr_cmslside、csr_cmshside寄存器的数值。
[0507]
保障装置的实施方式:
[0508]
s

b

a8、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于中转区域:
[0509]
沿用安全装置的寄存器:csr_cmsattr(32/64位)
[0510]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与保障装置相关性:相关
[0532]
其余内容一致。
[0533]
实施例3:
[0534]
在risc

v体系下,一种安全装置,和/或,以及与之匹配的保障装置的具体实施方式s3:
[0535]
所述实施方式s3的特征为:在risc

v体系下,内存区域边界信息由内存地址值,和/或,页面标识值构成,第一类指令执行和中断/异常产生分别转移至不同中转区域,并通过专用存储设施记录安全装置所需信息和保障装置所需的状态数据,本制作方法优选的存储设施为:专用寄存器。特别的:内存区域边界信息可以以内存地址值,和/或,以页面标识的方式记录,本制作方法优选的记录方式为:指令,和/或,数据所在内存区域边界信息以页面标识的方式记录,栈区域以及其它用途数据所在内存区域边界信息以内存地址值方式记录。
[0536]
安全装置的实施方式:
[0537]
s

c

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
[0538]
在实施例1中s

a

a1所述内容基础上:
[0539]
将:
[0540]
csr_cmslside、csr_cmshside、csr_utmslside、csr_utmshside、csr_stmslside、csr_stmshside、csr_smsirladdr、csr_smsirhaddr、csr_umsirladdr、csr_umsirhaddr寄存器删除。
[0541]
增设寄存器:csr_smsirid(32/64位)
[0542]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0543]
功能描述:用来保存s模式下中断/异常产生后转移地址所在页面标识信息。
[0544]
增设寄存器:csr_umsirid(32/64位)
[0545]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0546]
功能描述:用来保存u模式下中断/异常产生后转移地址所在页面标识信息。
[0547]
增加csr_cmsattr寄存器信息:
[0548]
除0、1、2位外,其它位用来记录pc即程序计数器中地址值所在页面标识信息。
[0549]
其余内容一致。
[0550]
s

c

a2、增加页表项内容
[0551]
在现有页表结构的基础上,建立与其对应的数据结构,其中的每一项都对应一个页表项,结构中记录该页表项对应页面标识信息。将此结构体现在处理器的tlb中。
[0552]
s

c

a3、在安全装置中增加检查待执行的指令的地址是否跨边界的功能在实施例1中s

a

a2所述内容基础上:
[0553]
将:
[0554]“只有在当前模式开启安全装置,且当前需要进行指令边界检查时,进行边界检查,即检查当前程序计数器中数值是否处于处理器认定的内存空间范围内,如果不超出范围,允许执行,否则报异常。具体包括:
[0555]
只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1,且csr_cmsattr寄存器0位为0,的情况下,进行边界检查,检查内容是:如果pc小于csr_cmslside寄存器中数值或大于等于csr_cmshside寄存器中数值,报异常,否则正常执行。”[0556]
替换为:
[0557]“只有在当前模式开启安全装置,且当前需要进行指令边界检查时,进行边界检查,判断该指令地址值所在页面标识值是否与增设寄存器中保存的在内存区域页面标识值不一致,如是,处理器报出异常,如不是,可正常取址。具体包括:
[0558]
只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1,且csr_cmsattr寄存器0位为0,的情况下,进行边界检查,检查内容是:如果pc所处页面对应页表项对应数据结构中记录页面标识信息,与csr_cmsattr寄存器中记录的页面标识信息不一致,报异常,否则正常执行。”[0559]
其余内容一致。
[0560]
s

c

a4、在安全装置中增加检查数据访问是否跨边界的功能
[0561]
在实施例1中s

a

a3所述内容基础上:
[0562]
将:
[0563]“只有在当前模式开启安全装置的情况下,对访问普通数据区域的特定指令,进行边界检查,即检查数据访问内存地址是否处于普通数据区域内,如果不超出范围,允许执行,否则报异常,具体包括:
[0564]
增加load、store指令功能:
[0565]
增加功能为:
[0566]
只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,进行边界检查,检查内容是:如果数据访问内存地址值小于csr_cmslside寄存器中数值或大于等于csr_cmshside寄存器中数值,报异常,否则正常执行。”[0567]
替换为:
[0568]“只有在当前模式开启安全装置的情况下,对访问普通数据区域的特定指令,进行边界检查,即检查当前待操作的地址所在页面标识信息,是否与增设寄存器中保存的数据区所在内存区域页面标识值一致,如是,可执行;如不是,处理器报出异常,具体包括:
[0569]
增加load、store指令功能:
[0570]
增加功能为:
[0571]
只有在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的情况下,进行边界检查,检查内容是:访问内存地址值所处页面对应页表项对应数据结构中记录的页面标识信息,与csr_cmsattr寄存器中记录的页面标识信息是否一致,一致,正常执行,否则,报异常。”[0572]
其余内容一致。
[0573]
s

c

a5、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
[0574]
与实施例1中s

a

a4所述内容一致。
[0575]
s

c

a6、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
[0576]
与实施例1中s

a

a5所述内容一致。
[0577]
s

c

a7、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
[0578]
将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;将装置中边界寄存器的值,设置为中断/异常转移中转区域的页面标识信息;转移至中断服务程序的入口地址;其余操作与现有中断、异常的处理一致。具体包括:
[0579]
中断或异常产生时:
[0580]
如果当前模式为u,则检查中断委托到的模式:
[0581]
如果委托到u模式,则检查u模式下是否打开安全装置,即检查csr_emsur寄存器0位是否为1,如果为1,则,用csr_utmsattr寄存器保存csr_cmsattr寄存器的数值,之后用csr_umsirid寄存器中保存的u模式下中断/异常产生后转移地址所在页面标识信息,设置csr_cmsattr寄存器中页面标识信息相应的位,并把csr_cmsattr寄存器0位置1;最后沿用risc

v现有规则转移至中断服务程序入口地址;
[0582]
如果委托到s模式,则检查s模式下是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,则,用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,之后用csr_smsirid寄存器中保存的s模式下中断/异常产生后转移地址所在页面标识信息,设置csr_cmsattr寄存器中页面标识信息相应的位,并把csr_cmsattr寄存器0位置1;最后沿用risc

v现有规则转移至中断服务程序入口地址;
[0583]
如果当前模式为s,且委托到的模式是s或u,则检查s模式是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,则,用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,之后用csr_smsirid寄存器中保存的s模式下中断/异常产生后转移地址所在页面标识信息,设置csr_cmsattr寄存器中页面标识信息相应的位,并把csr_cmsattr寄存器0位置1;最后沿用risc

v现有规则转移至中断服务程序入口地址。
[0584]
s

c

a8、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
[0585]
处理器根据专用寄存器中保存现场信息,恢复确保安全装置有效所需中断/异常现场信息到相应的专用寄存器,优选的,还要恢复中断/异常发生时是否需要检查指令边界标识信息。具体包括:
[0586]
在当前模式打开安全装置的前提下,即在csr_emsur寄存器(如果当前s模式,1位,如果当前u模式,0位)为1的前提下,如果当前模式为s,则用csr_stmsattr寄存器数值恢复csr_cmsattr寄存器的数值;如果当前模式为u,则用csr_utmsattr寄存器数值恢复csr_cmsattr寄存器的数值。
[0587]
保障装置的实施方式:
[0588]
s

c

a9、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于中转区域:
[0589]
与实施例1中s

a

a8所述内容一致。
[0590]
s

c

a10、识别需要保障的寄存器的方式:
[0591]
与实施例1中s

a

a9所述内容一致。
[0592]
s

c

a11、访问专用寄存器时增加访问控制的功能:
[0593]
与实施例1中s

a

a10所述内容一致。
[0594]
s

c

a12、允许及限制访问安全装置和保障装置的专用寄存器以及执行跨区域转移执行和专用寄存器访问指令的条件:
[0595]
与实施例1中s

a

a11所述内容一致。
[0596]
实施例4:
[0597]
在risc

v体系下,一种安全装置,和/或,以及与之匹配的保障装置的具体实施方式s4:
[0598]
所述实施方式s4的特征为:内存区域边界信息由内存地址值,和/或,页面标识值构成,第一类指令执行和中断/异常产生分别转移至相同中转区域,优选的,转移到共同代码位置,并通过专用存储设施记录安全装置所需信息和保障装置所需的状态数据,本制作方法优选的存储设施为:专用寄存器。特别的:内存区域边界信息可以以内存地址值,和/或,以页面标识的方式记录,本制作方法优选的记录方式为:指令,和/或,数据所在内存区域边界信息以页面标识的方式记录,栈区域以及其它用途数据所在内存区域边界信息以内存地址值方式记录。
[0599]
安全装置的实施方式:
[0600]
s

d

a1、设置记录确保安全装置有效所需信息的专用寄存器组,用以记录各类内存区域边界信息、中断现场信息、跨区域所需特定地址信息、安全装置开启/关闭标识信息
[0601]
在实施例1中s

b

a1所述内容基础上:
[0602]
将:
[0603]
csr_cmslside、csr_cmshside、csr_utmslside、csr_utmshside、csr_stmslside、csr_stmshside、csr_smschladdr、csr_smschhaddr、csr_umschladdr、csr_umschhaddr寄存器删除。
[0604]
增设寄存器:csr_smschid(32/64位)
[0605]
访问属性:r/w:可读写;privilege:s;standard/not:非标准;与安全装置相关性:相关
[0606]
功能描述:用来保存s模式下第一类指令转移和中断/异常产生后转移地址所在共同的页面标识信息。
[0607]
增设寄存器:csr_umschid(32/64位)
[0608]
访问属性:r/w:可读写;privilege:u;standard/not:非标准;与安全装置相关性:相关
[0609]
功能描述:用来保存u模式下第一类指令转移和中断/异常产生后转移地址所在共同的页面标识信息。
[0610]
增加csr_cmsattr寄存器信息:
[0611]
除0、1、2位外,其它位用来记录pc即程序计数器中地址值所在页面标识信息。
[0612]
其余内容一致。
[0613]
s

d

a2、增加页表项内容
[0614]
与实施例3中s

c

a2所述内容一致。
[0615]
s

d

a3、在安全装置中增加检查待执行的指令的地址是否跨边界的功能与实施例
3中s

c

a3所述内容一致。
[0616]
s

d

a4、在安全装置中增加检查数据访问是否跨边界的功能
[0617]
与实施例3中s

c

a4所述内容一致。
[0618]
s

d

a5、在安全装置中增加第一类指令,发起跨区域的转移动作及设置确保安全装置有效所需信息:
[0619]
与实施例2中s

b

a4所述内容一致。
[0620]
s

d

a6、在安全装置中增加第二类指令,完成到目标区域的转移及设置确保安全装置有效所需信息:
[0621]
与实施例2中s

b

a5所述内容一致。
[0622]
s

d

a7、在安全装置中增加中断/异常产生时的功能,保存确保安全装置有效的现场信息及设置确保安全装置有效所需信息:
[0623]
将中断/异常发生时,将确保安全装置有效所需现场信息,保存进安全装置中相应的专用寄存器,优选的,还要保存中断/异常发生时是否需要检查指令边界标识信息;处理器需提供信息标识,表明当前由中断/异常产生导致转移,标识信息被记录在安全装置的专用寄存器中;将装置中专用边界寄存器的值,设置为第一类指令转移和中断/异常转移共同中转区域的页面标识信息;转移至第一类指令转移和中断/异常转移共同的转移地址;其余操作与现有中断、异常的处理一致。具体包括:
[0624]
中断或异常产生时:
[0625]
如果当前模式为u,则检查中断委托到的模式:
[0626]
如果委托到u模式,则检查u模式下是否打开安全装置,即检查csr_emsur寄存器0位是否为1,如果为1,用csr_utmsattr寄存器保存csr_cmsattr寄存器的数值,将csr_cmsattr寄存器0位置1,1位置1,之后用csr_umsirid寄存器中保存的u模式下第一类指令转移和中断/异常产生后转移地址所在共同的页面标识信息,设置csr_cmsattr寄存器中页面标识信息相应的位,最后用csr_umschaddr寄存器中数值设置pc;
[0627]
如果委托到s模式,则检查s模式下是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,将csr_cmsattr寄存器0位置1,1位置1,之后用csr_smsirid寄存器中保存的s模式下第一类指令转移和中断/异常产生后转移地址所在共同的页面标识信息,设置csr_cmsattr寄存器中页面标识信息相应的位,最后用csr_smschaddr寄存器中数值设置pc;
[0628]
如果当前模式为s,且委托到的模式是s或u,则检查s模式是否打开安全装置,即检查csr_emsur寄存器1位是否为1,如果为1,则用csr_stmsattr寄存器保存csr_cmsattr寄存器的数值,将csr_cmsattr寄存器0位置1,1位置1,之后用csr_smsirid寄存器中保存的s模式下第一类指令转移和中断/异常产生后转移地址所在共同的页面标识信息,设置csr_cmsattr寄存器中页面标识信息相应的位,最后用csr_smschaddr寄存器中数值设置pc。
[0629]
s

d

a8、在安全装置中增加中断返回时的功能,恢复确保安全装置有效的现场信息:
[0630]
与实施例3中s

c

a8所述内容一致。
[0631]
保障装置的实施方式:
[0632]
s

d

a9、设置记录保障装置所需的状态数据的专用寄存器组,记录当前是否处于
中转区域:
[0633]
与实施例2中s

b

a8所述内容一致。
[0634]
s

d

a10、识别需要保障的寄存器的方式:
[0635]
与实施例2中s

b

a9所述内容一致。
[0636]
s

d

a11、访问专用寄存器时增加访问控制的功能:
[0637]
与实施例2中s

b

a10所述内容一致。
[0638]
s

d

a12、允许及限制访问安全装置和保障装置的专用寄存器以及执行跨区域转移执行和专用寄存器访问指令的条件:
[0639]
与实施例2中s

b

a11所述内容一致。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献