diff options
-rw-r--r-- | doc/using/Simulation.rst | 9 | ||||
-rw-r--r-- | src/grt/grt-vcd.adb | 24 |
2 files changed, 25 insertions, 8 deletions
diff --git a/doc/using/Simulation.rst b/doc/using/Simulation.rst index 58bfa20f2..820b90c14 100644 --- a/doc/using/Simulation.rst +++ b/doc/using/Simulation.rst @@ -279,6 +279,13 @@ Export waveforms Do not write date in the VCD file. +.. option:: --vcd-4states + + Only use the verilog states ``0/1/x/z`` to represent ``std_ulogic`` + values. The VCD file produced should be fully compatible with any + VCD reader. The default is to write ``std_ulogic`` as they are (so + keeping states ``U/W/L/H/-``), which is supported by several VCD readers. + .. option:: --fst=<FILENAME> Write the waveforms into an `fst` file. @@ -328,4 +335,4 @@ Export hierarchy and references .. option:: --psl-report-uncovered - Reports warning for each uncovered PSL cover point when simulation ends.
\ No newline at end of file + Reports warning for each uncovered PSL cover point when simulation ends. diff --git a/src/grt/grt-vcd.adb b/src/grt/grt-vcd.adb index 7d59701d4..128241d61 100644 --- a/src/grt/grt-vcd.adb +++ b/src/grt/grt-vcd.adb @@ -59,6 +59,9 @@ package body Grt.Vcd is -- Can be set to FALSE to make vcd comparaison easier. Flag_Vcd_Date : Boolean := True; + -- Only use 4 states (01zx) for std_ulogic. + Flag_Vcd_4states : Boolean := False; + Stream : FILEs; procedure My_Vcd_Put (Str : String) @@ -83,10 +86,6 @@ package body Grt.Vcd is Stream := NULL_Stream; end My_Vcd_Close; - -- VCD filename. - -- Stream corresponding to the VCD filename. - --Vcd_Stream : FILEs; - -- Index type of the table of vcd variables to dump. type Vcd_Index_Type is new Integer; @@ -104,6 +103,10 @@ package body Grt.Vcd is Flag_Vcd_Date := False; return True; end if; + if Opt'Length = 13 and then Opt (F + 5 .. F + 12) = "-4states" then + Flag_Vcd_4states := True; + return True; + end if; if Opt'Length > 6 and then Opt (F + 5) = '=' then if Vcd_Close /= null then Error ("--vcd: file already set"); @@ -139,6 +142,7 @@ package body Grt.Vcd is begin Put_Line (" --vcd=FILENAME dump signal values into a VCD file"); Put_Line (" --vcd-nodate do not write date in VCD file"); + Put_Line (" --vcd-4states reduce std_logic to verilog 0/1/x/z"); end Vcd_Help; procedure Vcd_Newline is @@ -681,14 +685,20 @@ package body Grt.Vcd is is type Map_Type is array (Ghdl_E8 range 0 .. 8) of Character; -- "UX01ZWLH-" - -- Map_Vlg : constant Map_Type := "xx01zz01x"; + Map_Vlg : constant Map_Type := "xx01zz01x"; Map_Std : constant Map_Type := "UX01ZWLH-"; + C : Character; begin if V not in Map_Type'Range then - Vcd_Putc ('?'); + C := '?'; else - Vcd_Putc (Map_Std (V)); + if Flag_Vcd_4states then + C := Map_Vlg (V); + else + C := Map_Std (V); + end if; end if; + Vcd_Putc (C); end Vcd_Put_Stdlogic; procedure Vcd_Put_Integer32 (V : Ghdl_U32) |