verilator/test_regress/t/t_trace_complex_fst_sc.out
Geza Lore 95c4ade718
Unify code generation for trace declarations in both trace formats (#4612)
This patch adds some abstract enums to pass to the trace decl* APIs, so
the VCD/FST specific code can be kept in verilated_{vcd,fst}_*.cc, and
removed from V3Emit*. It also reworks the generation of the trace init
functions (those that call 'decl*' for the signals) such that the scope
hierarchy is traversed precisely once during initialization, which
simplifies the FST writer. This later change also has the side effect of
fixing tracing of nested interfaces when traced via an interface
reference - see the change in the expected t_interface_ref_trace - which
previously were missed.
2023-10-24 16:33:29 +01:00

289 lines
4.8 KiB
Plaintext

$date
Tue Oct 24 11:09:24 2023
$end
$version
fstWriter
$end
$timescale
1ps
$end
$scope module top $end
$scope module $unit $end
$var bit 1 ! global_bit $end
$upscope $end
$scope module t $end
$var wire 1 " clk $end
$var integer 32 # cyc [31:0] $end
$var bit 2 $ v_strp [1:0] $end
$var bit 4 % v_strp_strp [3:0] $end
$var bit 2 & v_unip_strp [1:0] $end
$var bit 2 ' v_arrp [2:1] $end
$var bit 4 ( v_arrp_arrp [3:0] $end
$var bit 4 ) v_arrp_strp [3:0] $end
$var bit 1 * v_arru[1] $end
$var bit 1 + v_arru[2] $end
$var bit 1 , v_arru_arru[3][1] $end
$var bit 1 - v_arru_arru[3][2] $end
$var bit 1 . v_arru_arru[4][1] $end
$var bit 1 / v_arru_arru[4][2] $end
$var bit 2 0 v_arru_arrp[3] [2:1] $end
$var bit 2 1 v_arru_arrp[4] [2:1] $end
$var bit 2 2 v_arru_strp[3] [1:0] $end
$var bit 2 3 v_arru_strp[4] [1:0] $end
$var real 64 4 v_real $end
$var real 64 5 v_arr_real[0] $end
$var real 64 6 v_arr_real[1] $end
$var logic 64 7 v_str32x2 [63:0] $end
$attrbegin misc 07 t.enumed_t 4 ZERO ONE TWO THREE 00000000000000000000000000000000 00000000000000000000000000000001 00000000000000000000000000000010 00000000000000000000000000000011 1 $end
$attrbegin misc 07 "" 1 $end
$var int 32 8 v_enumed [31:0] $end
$attrbegin misc 07 "" 1 $end
$var int 32 9 v_enumed2 [31:0] $end
$attrbegin misc 07 t.enumb_t 4 BZERO BONE BTWO BTHREE 000 001 010 011 2 $end
$attrbegin misc 07 "" 2 $end
$var logic 3 : v_enumb [2:0] $end
$var logic 6 ; v_enumb2_str [5:0] $end
$var logic 8 < unpacked_array[-2] [7:0] $end
$var logic 8 = unpacked_array[-1] [7:0] $end
$var logic 8 > unpacked_array[0] [7:0] $end
$var bit 1 ? LONGSTART_a_very_long_name_which_will_get_hashed_a_very_long_name_which_will_get_hashed_a_very_long_name_which_will_get_hashed_a_very_long_name_which_will_get_hashed_LONGEND $end
$scope module a_module_instantiation_with_a_very_long_name_that_once_its_signals_get_concatenated_and_inlined_will_almost_certainly_result_in_them_getting_hashed $end
$var parameter 32 @ PARAM [31:0] $end
$upscope $end
$scope module p2 $end
$var parameter 32 A PARAM [31:0] $end
$upscope $end
$scope module p3 $end
$var parameter 32 B PARAM [31:0] $end
$upscope $end
$scope module unnamedblk1 $end
$var integer 32 C b [31:0] $end
$scope module unnamedblk2 $end
$var integer 32 D a [31:0] $end
$upscope $end
$upscope $end
$upscope $end
$upscope $end
$enddefinitions $end
#0
$dumpvars
b00000000000000000000000000000000 D
b00000000000000000000000000000000 C
b00000000000000000000000000000011 B
b00000000000000000000000000000010 A
b00000000000000000000000000000100 @
0?
b00000000 >
b00000000 =
b00000000 <
b000000 ;
b000 :
b00000000000000000000000000000000 9
b00000000000000000000000000000000 8
b0000000000000000000000000000000000000000000000000000000011111111 7
r0 6
r0 5
r0 4
b00 3
b00 2
b00 1
b00 0
0/
0.
0-
0,
0+
0*
b0000 )
b0000 (
b00 '
b00 &
b0000 %
b00 $
b00000000000000000000000000000000 #
0"
1!
$end
#10
1"
b00000000000000000000000000000001 #
b11 $
b1111 %
b11 &
b11 '
b1111 (
b1111 )
b11 0
b11 1
b11 2
b11 3
r0.1 4
r0.2 5
r0.3 6
b0000000000000000000000000000000100000000000000000000000011111110 7
b00000000000000000000000000000001 8
b00000000000000000000000000000010 9
b111 :
b00000000000000000000000000000101 C
b00000000000000000000000000000101 D
#11
#12
#13
#14
#15
0"
#16
#17
#18
#19
#20
1"
b110 :
b00000000000000000000000000000100 9
b00000000000000000000000000000010 8
b0000000000000000000000000000001000000000000000000000000011111101 7
r0.6 6
r0.4 5
r0.2 4
b00 3
b00 2
b00 1
b00 0
b0000 )
b0000 (
b00 '
b00 &
b0000 %
b00 $
b00000000000000000000000000000010 #
b111111 ;
#21
#22
#23
#24
#25
0"
#26
#27
#28
#29
#30
1"
b110110 ;
b00000000000000000000000000000011 #
b11 $
b1111 %
b11 &
b11 '
b1111 (
b1111 )
b11 0
b11 1
b11 2
b11 3
r0.3 4
r0.6000000000000001 5
r0.8999999999999999 6
b0000000000000000000000000000001100000000000000000000000011111100 7
b00000000000000000000000000000011 8
b00000000000000000000000000000110 9
b101 :
#31
#32
#33
#34
#35
0"
#36
#37
#38
#39
#40
1"
b100 :
b00000000000000000000000000001000 9
b00000000000000000000000000000100 8
b0000000000000000000000000000010000000000000000000000000011111011 7
r1.2 6
r0.8 5
r0.4 4
b00 3
b00 2
b00 1
b00 0
b0000 )
b0000 (
b00 '
b00 &
b0000 %
b00 $
b00000000000000000000000000000100 #
b101101 ;
#41
#42
#43
#44
#45
0"
#46
#47
#48
#49
#50
1"
b100100 ;
b00000000000000000000000000000101 #
b11 $
b1111 %
b11 &
b11 '
b1111 (
b1111 )
b11 0
b11 1
b11 2
b11 3
r0.5 4
r1 5
r1.5 6
b0000000000000000000000000000010100000000000000000000000011111010 7
b00000000000000000000000000000101 8
b00000000000000000000000000001010 9
b011 :
#51
#52
#53
#54
#55
0"
#56
#57
#58
#59
#60
1"
b010 :
b00000000000000000000000000001100 9
b00000000000000000000000000000110 8
b0000000000000000000000000000011000000000000000000000000011111001 7
r1.8 6
r1.2 5
r0.6 4
b00 3
b00 2
b00 1
b00 0
b0000 )
b0000 (
b00 '
b00 &
b0000 %
b00 $
b00000000000000000000000000000110 #
b011011 ;
#61
#62
#63
#64