在sv中关于流操作的⼀些⼼得武汉空气质量指数
逆行性
遗忘闲得⽆聊,写个博客记录⼀下最近在使⽤流操作符的⼀些⼼得。随着IC验证的⼀些深⼊,我从⼀个设计⼈员转成了彻底的验证⼈员了。在验证的过程经常遇到组包,解包的⼀些事情。尤其在做⼀些⽹络协议的时候,组包和解包成为了⼀个必须的过程。 举⼀个例⼦,MAC帧的组成,SMAC,DMAC,TYPE,MAC_PAYLOAD,CRC. 由这5个元素构成⼀个mac帧。
但是这个帧从总线上拿到的时候,往往⼤家都是做⼀个计数器,如果是前0-5byte是SMAC,6-11是DMAC,等等。是这样解包和组包的,这样的解包和组包也是可以的。我这⾥给⼤家提供另外⼀种解包和组包的⽅式。使⽤流操作符 >>;
bit[47:0] SMAC,DMAC;
bit[15:0] MAC_TYPE;
bit[7:0] MAC_PAYLOAD;
bit[31:0] CRC;
核糖体结合位点
河流 电影bit[31:0] data_payload[];
拆包:
{ << {SMAC,DMAC,MAC_PAYLOAD,CRC}} = data_payload;
组包:
data_payload = { << {SMAC,DMAC,MAC_PAYLOAD,CRC}} ;
流操作还有⼀些其他的⽤途:例如做byte的反转之类的,在⽹络传输的时候我们需要从⾼到底的反转各个byte,这个时候我们通常会写⼀个函数,如果⽤流操作就不需要了啦 bit[63:0] data;冲动控制障碍
data = {<< byte{data}};搞定,其实这种反转,不但可以byte反转,还有其他各种类型的反转。
中国图书馆学会