#! /usr/bin/vvp :ivl_version "11.0 (stable)"; :ivl_delay_selection "TYPICAL"; :vpi_time_precision + 0; :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/system.vpi"; :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/vhdl_sys.vpi"; :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/vhdl_textio.vpi"; :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/v2005_math.vpi"; :vpi_module "/usr/lib/x86_64-linux-gnu/ivl/va_math.vpi"; S_0x55928b0bbf60 .scope module, "timerTB" "timerTB" 2 1; .timescale 0 0; v0x55928b0d05d0_0 .var "clock", 0 0; v0x55928b0d0690_0 .net "count", 5 0, v0x55928b0d0000_0; 1 drivers v0x55928b0d0760_0 .var "counter", 2 0; v0x55928b0d0860_0 .var "gate", 0 0; v0x55928b0d0930_0 .var "reset", 0 0; v0x55928b0d0a20_0 .var "way", 0 0; S_0x55928b0bc0f0 .scope module, "uut" "timer" 2 9, 3 1 0, S_0x55928b0bbf60; .timescale 0 0; .port_info 0 /INPUT 1 "clock"; .port_info 1 /INPUT 1 "reset"; .port_info 2 /INPUT 1 "gate"; .port_info 3 /INPUT 3 "counter"; .port_info 4 /INPUT 1 "way"; .port_info 5 /OUTPUT 6 "count"; v0x55928b0a8600_0 .net "clock", 0 0, v0x55928b0d05d0_0; 1 drivers v0x55928b0d0000_0 .var "count", 5 0; v0x55928b0d00e0_0 .var "countReg", 5 0; v0x55928b0d01a0_0 .net "counter", 2 0, v0x55928b0d0760_0; 1 drivers v0x55928b0d0280_0 .net "gate", 0 0, v0x55928b0d0860_0; 1 drivers v0x55928b0d0390_0 .net "reset", 0 0, v0x55928b0d0930_0; 1 drivers v0x55928b0d0450_0 .net "way", 0 0, v0x55928b0d0a20_0; 1 drivers E_0x55928b0b8e60 .event edge, v0x55928b0d00e0_0; E_0x55928b0b9330 .event posedge, v0x55928b0a8600_0; .scope S_0x55928b0bc0f0; T_0 ; %pushi/vec4 43, 0, 6; %store/vec4 v0x55928b0d00e0_0, 0, 6; %end; .thread T_0; .scope S_0x55928b0bc0f0; T_1 ; %wait E_0x55928b0b9330; %load/vec4 v0x55928b0d0390_0; %flag_set/vec4 8; %jmp/0xz T_1.0, 8; %pushi/vec4 0, 0, 6; %assign/vec4 v0x55928b0d00e0_0, 0; %jmp T_1.1; T_1.0 ; %load/vec4 v0x55928b0d0280_0; %flag_set/vec4 8; %jmp/0xz T_1.2, 8; %load/vec4 v0x55928b0d0450_0; %load/vec4 v0x55928b0d00e0_0; %pushi/vec4 63, 0, 6; %cmp/ne; %flag_get/vec4 4; %and; %flag_set/vec4 8; %jmp/0xz T_1.4, 8; %load/vec4 v0x55928b0d00e0_0; %load/vec4 v0x55928b0d01a0_0; %pad/u 6; %add; %assign/vec4 v0x55928b0d00e0_0, 0; %jmp T_1.5; T_1.4 ; %load/vec4 v0x55928b0d0450_0; %nor/r; %load/vec4 v0x55928b0d00e0_0; %pushi/vec4 0, 0, 6; %cmp/ne; %flag_get/vec4 4; %and; %flag_set/vec4 8; %jmp/0xz T_1.6, 8; %load/vec4 v0x55928b0d00e0_0; %load/vec4 v0x55928b0d01a0_0; %pad/u 6; %sub; %assign/vec4 v0x55928b0d00e0_0, 0; T_1.6 ; T_1.5 ; T_1.2 ; T_1.1 ; %jmp T_1; .thread T_1; .scope S_0x55928b0bc0f0; T_2 ; %wait E_0x55928b0b8e60; %load/vec4 v0x55928b0d00e0_0; %store/vec4 v0x55928b0d0000_0, 0, 6; %jmp T_2; .thread T_2, $push; .scope S_0x55928b0bbf60; T_3 ; %pushi/vec4 0, 0, 1; %store/vec4 v0x55928b0d05d0_0, 0, 1; T_3.0 ; %delay 5, 0; %load/vec4 v0x55928b0d05d0_0; %inv; %store/vec4 v0x55928b0d05d0_0, 0, 1; %jmp T_3.0; %end; .thread T_3; .scope S_0x55928b0bbf60; T_4 ; %vpi_call 2 19 "$dumpfile", "lab5t.vcd" {0 0 0}; %vpi_call 2 20 "$dumpvars" {0 0 0}; %pushi/vec4 0, 0, 1; %store/vec4 v0x55928b0d0930_0, 0, 1; %pushi/vec4 1, 0, 1; %store/vec4 v0x55928b0d0860_0, 0, 1; %pushi/vec4 2, 0, 3; %store/vec4 v0x55928b0d0760_0, 0, 3; %pushi/vec4 1, 0, 1; %store/vec4 v0x55928b0d0a20_0, 0, 1; %pushi/vec4 1, 0, 1; %store/vec4 v0x55928b0d0930_0, 0, 1; %pushi/vec4 1, 0, 1; %store/vec4 v0x55928b0d0860_0, 0, 1; %pushi/vec4 2, 0, 3; %store/vec4 v0x55928b0d0760_0, 0, 3; %pushi/vec4 1, 0, 1; %store/vec4 v0x55928b0d0a20_0, 0, 1; %delay 200, 0; %vpi_call 2 25 "$finish" {0 0 0}; %end; .thread T_4; # The file index is used to find the file name in the following table. :file_names 4; "N/A"; ""; "timerTB.v"; "timer.v";