FPGA--(verilog)行为级描述和结构级描述


1、在使用verilog描述电路时,既可以进行行为级的描述,也可以进行结构级的描述。
      ①行为级描述:侧重对模块行为功能的 抽象 描述
      ②结构级描述:侧重对模块内部结构实现的 具体 描述
2、行为级描述
     ①描述体的组成
      ※由多个 并行运行的 过程块组成。
      ※过程块由 过程语句(initial和always)和 块语句(串行块begin-end和并行块fork-join)组成。
      ※块语句由 过程赋值语句和 高级程序语句构成。
            ◇过程赋值语句:阻塞与非阻塞式赋值。
            ◇高级程序语句:C语言如if-else、case、while、wait等组成。
     ②行为级描述模块的构成图
    
 Verilog Code 
//例:全加器行为级描述
module fadder(sum,a,b,cin);//模块定义
output sum,cout;//端口声明
input a,b,cin;//端口声明
reg sum,cout;//数据类型声明

always @(a or b or cin)//过程语句
   
    begin//高级程序语句
      sum=a^b^cin;//过程赋值语句
      cout=(a&b)|(b&cin)|(a&cin);//过程赋值语句
    end
endmodule//结束行
 
3、结构级描述
    ①描述体的组成
        ※ 门级描述:对由基本逻辑门(and、or、not、xor等)互连而成的具有一定功能的电路模块的描述。
        ※ 结构级描述:将上述逻辑门用一个个功能模块替换,就拓展到一般意义的结构级描述。
    ②结构级描述模块
      例:全加器门级
      
 Verilog Code 
//例:全加器结构级描述
module fadder(sum,a,b,cin);//模块定义
    output sum,cout;//端口声明
    input a,b,cin;//端口声明
    /*******门级互连*****/
    xor U0(sum,a,b,cin);
    and U1(net1,a,b);
    and U2(net2,a,cin);
    and U3(net3,b,cin);
    or U4(cout,net1,net2,net3);
endmodule//结束行


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM