找回密码
 注册
关于网站域名变更的通知
查看: 282|回复: 1
打印 上一主题 下一主题

转——modelsim独立仿真教程 

[复制链接]
  • TA的每日心情
    开心
    2019-11-20 15:00
  • 签到天数: 2 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2019-3-26 07:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    转——modelsim独立仿真教程
    6 h: k# R; z8 Z) r: A' }# W8 V

    0 S2 s- z2 K) v8 |" e

    & E" i# T4 ]  K9 r4 I* q

    * ^1 ]/ W/ k& F
    一.GUI界面的仿真步骤
    - U& Y2 j: h7 G" |) C
    1.首先把你需要仿真的设计文本和仿真文本全部放在同一个文件夹下面,注意,文件夹路径不能包含中文。0 [8 }8 f. k% P4 H/ |) n

      S, n% l, V! _* ~$ S! f" [我的设计文件:counter.v
    - B1 @2 q# _# C) U0 y, o( z`timescale 1ns / 1ns$ H7 c% _' ?1 x9 Y4 B9 e0 F
    module counter (count, clk, reset);
    $ ~2 i, I: @6 ^* k( x1 ooutput [7:0] count;
    . G$ b0 R/ ]( G" f9 Y( z4 @' e/ Vinput clk, reset;
    # W$ f0 g7 m7 p$ w2 P$ h' |/ k
    " r* X8 [/ u; p1 lreg [7:0] count;1 Y8 H8 L$ _+ \" V/ H) [
    parameter tpd_reset_to_count = 3;- a3 o6 B/ E& B# Z: X. q+ ?
    parameter tpd_clk_to_count   = 2;
    : O& H2 ^1 x5 ?* M4 x3 r3 E) i4 y- F' h5 ~) m8 ?3 G; r
    function [7:0] increment;! [2 H, V7 P/ a9 {' p, J
    input [7:0] val;
    + U: {8 y7 S7 ereg [3:0] i;; _. O' s) o/ l- m) O
    reg carry;! a0 Y( I" x5 t0 Z  B
      begin+ A! B) N& ^; P; `/ h
        increment = val;
    4 }4 A- o4 L2 E& c8 r7 J    carry = 1'b1;
    5 w" \) H3 Z7 P    /* 9 l, I+ g% k% q1 R3 P
         * Exit this loop when carry == zero, OR all bits processed
    4 _2 `1 i# m. k     */ ) n: \6 w+ A% ?$ N9 K1 D+ o9 s
        for (i = 4'b0; ((carry == 4'b1) && (i <= 7));  i = i+ 4'b1)( X. r: }% k( e# d5 b, m  Q
           begin1 b3 ?. E/ `, g% `8 S" g4 P
             increment = val ^ carry;; s, s8 F( `' W
             carry = val & carry;, i8 {9 e2 y! D, _6 z( k
           end! l" |6 M+ E+ i6 e/ g0 t
      end      
    * e) s% A' D# Nendfunction  G1 _% Q" l' J8 ~! z; b
    ; H( E5 @1 l( [1 C" w5 m) I
    always @ (posedge clk or posedge reset)
    8 S3 L7 _: U& e9 v& ~  if (reset)! W1 W% k3 f& A, V  C
         count = #tpd_reset_to_count 8'h00;+ i# {+ U8 e# V+ z+ }0 k1 x
      else
      b0 Z) ^, j# C     count <= #tpd_clk_to_count increment(count);$ F5 s1 x. U1 n$ M$ {
    7 S8 s, A, M! d# Z9 H) M9 G# P
    /***************************************************************** ( u' `* V8 ^6 n- o" b
    Use the following block to make the design synthesizable.3 d" \; k! S  s  p
    2 V+ x/ A* U& F1 H+ S
    always @ (posedge clk or posedge reset)- m" D8 f3 R4 d+ L1 C: F# X
      if (reset)! g) C5 `2 ]$ m) ?
         count = 8'h00;- f# x9 w) ?: l9 I$ a: z) r5 y' i
      else
    $ L$ W- w9 ]9 p+ A9 y5 `- N7 N     count <= count + 8'h01;
    / Q9 z9 S# S5 ]  B******************************************************************/
    ! B$ Q0 Q8 `& q$ |. o8 z% ~& Oendmodule$ G, r6 q  L2 a% L

    + a" @  n- T2 J! [% v, k3 ~我的仿真文件:tcounter.v- h: Y5 ~$ U( ~4 p1 R; G* o+ l* X; ^
    `timescale 1ns / 1ns3 a* ~$ q! W$ \' c2 A
    module test_counter;
    3 E. `' K! y, u1 E& C; h' R! D% O0 N
    1 Q) [# T+ K5 preg clk, reset;4 `3 o2 K, M0 A6 H0 x: p2 `
    wire [7:0] count;- M+ h4 Z4 M. E! h# i$ l
    ( Q* `; w* ^1 o. W+ |; L' m
    counter dut (count, clk, reset);
    4 y7 U  y3 G5 u" p# l& y" h( _: b
    , Y2 _/ G2 P- l9 Finitial // Clock generator
    * V4 K; ?. M  P; U3 k/ n1 ]  begin% L: h- d1 T+ e9 u* `2 D
        clk = 0;; t/ V* e' Z( A6 f) h, `( d
        forever #10 clk = !clk;, }) E% U. S. a6 U, w3 P" K5 u
      end
    ) {8 N4 D* a! D# W; [  
    ) P8 h: Y5 G+ H! S. v  ~5 i+ Iinitial    // Test stimulus' a+ w! N7 {$ R# X9 p
      begin: D: J/ V& s( q1 V% C: l) A
        reset = 0;) v2 I( I& C- D6 ]/ k9 z* ~/ ]/ S9 f
        #5 reset = 1;( ~3 D1 P& z- z  W- c  c
        #4 reset = 0;
    : ~, k+ P' B6 S. n* I  end5 G* e$ H/ P* M
      9 J  ?2 f$ H: i  U
    initial9 `( g1 d* w( |8 {
        $monitor($stime,, reset,, clk,,, count); 9 q" ]4 Y- T1 V2 H: Q$ [
       
    7 K0 H7 o9 V8 z  d. A: Kendmodule6 v, n) Y9 B( Z

    % w* A% `; t/ u6 N- w) e
      A! A) ?8 Q+ s# p5 G2.打开modelsim软件,选择“File > Change Directory”,把目录改为我们在步骤1所创建的文件夹下,如下图所示
    & N4 Z+ |. q; P& ~4 X " f: x2 ^! K% e

    / z" ?, n! c/ c6 N: \" c3.选择“File > New > Library”,创建一个新的工作库,如下图所示:
    . g& L; q  N8 ?6 Z7 l! _+ P" W " L( D5 x( ~8 P8 J( h* N7 A) h

    ) d2 O" x. d  [, a: s4.选择“Compile > Compile”,编译我们的设计文件和仿真文件,如下图所示:* Y3 L" C, |0 e' L

    8 c9 u. f- L" @) W8 a; i 7 u/ _8 \( V3 F+ S  k1 h' }9 }

    * K2 n# Z% Z/ O1 d" Y. [+ t5.最关键的步骤来了,那些老教程就是缺少这步骤中的关键操作,而导致没有波形输出:可视化并加载我们的设计工程,如下图所示:
    ; E, q) B3 L/ j. u0 t0 T& U$ \# F
    2 \, b& e+ x6 Q* @4 Y
    & D$ B5 o* A+ N9 l2 `
    ' w7 ^) S- c% V% z  Z( R# d: D/ P' N* P' k
    6.选择软件右下方的“sim”,再鼠标右击,选择“AddTo > Wave > All items in region”,添加观测信号给波形窗口,如下图所示:0 o/ i9 h- F& Y/ V+ _

    + W/ n9 S: m6 S6 G" ?! R. R
    3 _/ f' G( I5 h# w$ g$ g0 |7.选择软件左下方“wave”,运行仿真,如下图所示:
    $ A: K, t' `+ m$ ^* o8 F% Y- }5 G
    ) z; b, o4 G3 }3 Q0 I! r2 z
    # g. ~% c; ]* r5 E; m" R7 G& y4 c" y! {7 l' Z* d
    以上就是GUI界面的仿真步骤了。( u# z' a' i8 }, Q2 Y+ B

    9 b  H" M$ l+ W二.脚本方式的仿真步骤
    ' T/ S. Q! ~* D+ K* I; r/ p6 `8 n0 r: v8 X) {" z
    我个人是不喜欢上述的GUI界面的仿真步骤,太罗嗦了,我喜欢更简单直接的脚本方式的仿真步骤,几行指令即可完成仿真。/ _8 A) E0 x0 I( Y5 O' o3 P6 V

    8 |. ?$ n& Z6 N7 S! O% H下面就是几条主要指令,具体实现,大家还是看modelsim自带英语文档吧。
    5 o/ h7 p" b( l  s/ o  S$ k: A( Y' e- T  |6 P$ z
    vlib work      //建库" V! Z3 k% d9 G! _8 f. D. `0 H+ v* Y
    + X8 @3 U; S, a: }4 e
    vmap work work   //映射
    % E5 V) L4 N8 S2 V; u/ j+ S* W) U6 K0 m7 R
    vlog counter.v tcounter.v      //编译文本,此指令需要建立project才能运行
    7 m$ @# P& ^1 ]9 j* o$ ?
    6 u) j9 D5 m1 `4 ~vopt +acc test_counter -o testcounter_opt  //可视化module( B) C' x+ u- B0 S* c
    ! z6 ]7 _" [" k3 I
    vsim testcounter_opt   //加载工程; `) m. T) g8 d" t& m$ o- e6 s3 e

    7 L5 V$ e) R" [( c& kadd wave *    //添加观测信号5 g1 ~% Y4 Z9 A* |5 }

    1 a( I- O' R1 k3 e0 yrun -all    //运行全部
    ) g' |3 l: ]' L- d( T! M+ u
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-7-29 22:22 , Processed in 0.125000 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表