Rocket - core - EventSet

https://mp.weixin.qq.com/s/0GSNIf0wCApPi8XYwa8MdQ

 

简单介绍EventSet的实现。

 

 

1. EventSet

 

定义事件集合:

 

0) 类参数

 

EventSet类包含两个类参数:

a. gate: (UInt, UInt) => Bool:使用两个参数,返回一个Bool;

b. events:事件序列;

c. event:事件的类型为:(String, () => Bool),这是一个二元组:第一个是事件名字符串,第二个是事件返回是否触发的方法;

 

1) size

 

返回事件集合中事件的个数。

 

2) hits

 

表示事件是否触发,把每个事件是否触发的Bool整合成为UInt返回。

 

3) check

 

使用掩码和gate方法来过滤hits,以检察某个事件是否触发。

 

4) dump

 

打印触发的事件的名称。

 

5) withCovers

 

为每个事件添加覆盖测试。

 

2. EventSets

 

定义多个事件集合:

 

0) 数据成员

 

a. 类参数:eventsSets:事件集合的序列;

b. eventSetIdBits:事件集合的ID所占用的位宽;

 

1) maskEventSelector

 

这是一个动(词)名(词)结构,对event selector进行mask,取出有效的事件选择位:

其中:

a. 参数eventSel是一个事件选择器;

b. setMask表示事件集合的ID占用的有效位数;eventSetIdBits是为时间集合ID分配的总位数,这里是8;但是不一定用完这8位,由eventSets.size决定;

c. maskMask从名称可知其是一个二级掩码,即事件集合掩码的掩码;多个事件集合中事件最多的集合中的事件数决定了事件集合掩码的位数;

d. 左移eventSetIdBits位,表示低eventSetIdBits位是事件集合ID的掩码,高位是事件集合中事件的掩码;

e. 由此可知,eventSel也是一个二级结构,低eventSetIdBits位表示选择的事件集合的ID,高位则表示该事件集合中事件的掩码;

f. setMask | maskMask表示事件选择器中的全部有效位,eventSel与之相与则表示取出eventSel中的有效位,而忽略其余的无效位;

 

2) decode

 

解出event selector这个二级结构:

 

3) evaluate

 

根据事件选择器,确定其中的事件是否发生:

其中:

a. 首先使用decode解出事件集合set,事件集合中事件的掩码mask;

b. 对各个事件集合使用mask进行check;

c. 选择相应事件集合的check结果返回;

 

posted @ 2022-03-22 19:59  wjcdx  阅读(106)  评论(0编辑  收藏  举报