在sv中关于流操作的一些心得

在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反转,还有其他各种类型的反转。
中国图书馆学会

本文发布于:2024-09-20 20:37:57,感谢您对本站的认可!

本文链接:https://www.17tex.com/xueshu/365901.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:组包   时候   解包   反转   遗忘
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议