verilog/labs/lab4/lab4o
2024-07-05 19:15:16 +03:00

115 lines
3.0 KiB
Plaintext

#! /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_0x55d6490fdb70 .scope module, "lab4tb" "lab4tb" 2 1;
.timescale 0 0;
v0x55d64910fee0_0 .var "s1", 8 0;
v0x55d64910ffa0_0 .net "s2", 3 0, v0x55d6490c37f0_0; 1 drivers
S_0x55d6490fdd00 .scope module, "uut" "lab4" 2 6, 3 1 0, S_0x55d6490fdb70;
.timescale 0 0;
.port_info 0 /INPUT 9 "signal";
.port_info 1 /OUTPUT 4 "S";
v0x55d6490c37f0_0 .var "S", 3 0;
v0x55d6490c3c00_0 .net "signal", 8 0, v0x55d64910fee0_0; 1 drivers
E_0x55d6490c2340 .event edge, v0x55d6490c3c00_0;
.scope S_0x55d6490fdd00;
T_0 ;
%wait E_0x55d6490c2340;
%pushi/vec4 0, 0, 4;
%store/vec4 v0x55d6490c37f0_0, 0, 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 1, 8, 5;
%pad/u 32;
%cmpi/e 1, 0, 32;
%jmp/0xz T_0.0, 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 3, 3;
%pad/u 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 0, 2;
%pad/u 4;
%add;
%store/vec4 v0x55d6490c37f0_0, 0, 4;
%jmp T_0.1;
T_0.0 ;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 1, 7, 4;
%pad/u 32;
%cmpi/e 1, 0, 32;
%jmp/0xz T_0.2, 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 3, 3;
%pad/u 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 0, 2;
%pad/u 4;
%sub;
%store/vec4 v0x55d6490c37f0_0, 0, 4;
%jmp T_0.3;
T_0.2 ;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 1, 6, 4;
%pad/u 32;
%cmpi/e 1, 0, 32;
%jmp/0xz T_0.4, 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 3, 3;
%pad/u 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 0, 2;
%pad/u 4;
%and;
%store/vec4 v0x55d6490c37f0_0, 0, 4;
%jmp T_0.5;
T_0.4 ;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 1, 6, 4;
%pad/u 32;
%cmpi/e 0, 0, 32;
%jmp/0xz T_0.6, 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 3, 3;
%pad/u 4;
%load/vec4 v0x55d6490c3c00_0;
%parti/s 3, 0, 2;
%pad/u 4;
%or;
%store/vec4 v0x55d6490c37f0_0, 0, 4;
T_0.6 ;
T_0.5 ;
T_0.3 ;
T_0.1 ;
%jmp T_0;
.thread T_0, $push;
.scope S_0x55d6490fdb70;
T_1 ;
%vpi_call 2 12 "$dumpfile", "lab4v.vcd" {0 0 0};
%vpi_call 2 13 "$dumpvars" {0 0 0};
%pushi/vec4 297, 0, 9;
%store/vec4 v0x55d64910fee0_0, 0, 9;
%delay 10, 0;
%pushi/vec4 169, 0, 9;
%store/vec4 v0x55d64910fee0_0, 0, 9;
%delay 10, 0;
%pushi/vec4 105, 0, 9;
%store/vec4 v0x55d64910fee0_0, 0, 9;
%delay 10, 0;
%pushi/vec4 41, 0, 9;
%store/vec4 v0x55d64910fee0_0, 0, 9;
%delay 10, 0;
%vpi_call 2 19 "$display", "Done" {0 0 0};
%end;
.thread T_1;
# The file index is used to find the file name in the following table.
:file_names 4;
"N/A";
"<interactive>";
"lab4tb.v";
"lab4.v";