[SystemVerilog] $sformat/$sformatf を記述してみる。

SystemVerilogの String関係で前に書いていたのですが、
システムタスクを忘れていました。

  • サンプルコード

  • module testbench ();
    
      int a;
      string s;
    
      initial begin
        a = 1;
        $sformat(s, "*** data is %d", a);
        a = 10; $display("%s", s);
        a = 100; $display(s);
      end
    
    endmodule: testbench
  • 実行結果

  • # run -all 
    # *** data is           1
    # *** data is           1
    #  quit 
    

はて?どうもおかしいですね。
残念ながら、その時点の値を変数「s」にセットするようです。


  • サンプルコード2

  • module testbench ();
    
      int a;
      string s;
    
      initial begin
        a =   1; #1; $display(s);
        a =  10; #1; $display(s);
        a = 100; #1; $display(s);
      end
    
      always_comb begin
        $sformat(s, "*** data is %d", a);
      end
    
    endmodule: testbench
  • 実行結果

  • # run -all 
    # *** data is           1
    # *** data is          10
    # *** data is         100
    #  quit 
    

というように書けばいい感じ。


参考

関連記事

コメントの投稿

非公開コメント

プロフィール

Kocha

Author:Kocha
なんでもチャレンジ!(^o^)/
E-mail
github:Kocha
イベントカレンダー

カレンダー
05 | 2017/06 | 07
- - - - 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 -
カテゴリ
OVP (4)
最新記事
最新コメント
アーカイブ
リンク
Twitter
アクセス人数