178 lines
4.9 KiB
Plaintext
178 lines
4.9 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_0x56335d23e170 .scope module, "tetrisTB" "tetrisTB" 2 1;
|
|
.timescale 0 0;
|
|
v0x56335d253500_0 .net "bitti_mi", 0 0, v0x56335d200370_0; 1 drivers
|
|
v0x56335d2535c0_0 .net "cevrim", 3 0, v0x56335d200c00_0; 1 drivers
|
|
v0x56335d253690_0 .var "clk", 0 0;
|
|
v0x56335d253790_0 .var "p", 2 0;
|
|
v0x56335d253860_0 .net "yukseklik", 3 0, v0x56335d253090_0; 1 drivers
|
|
S_0x56335d23e300 .scope module, "uut" "tetris" 2 9, 3 1 0, S_0x56335d23e170;
|
|
.timescale 0 0;
|
|
.port_info 0 /INPUT 3 "parca";
|
|
.port_info 1 /INPUT 1 "clk";
|
|
.port_info 2 /OUTPUT 4 "yukseklik";
|
|
.port_info 3 /OUTPUT 1 "bitti_mi";
|
|
.port_info 4 /OUTPUT 4 "cevrim";
|
|
v0x56335d200370_0 .var "bitti_mi", 0 0;
|
|
v0x56335d200c00_0 .var "cevrim", 3 0;
|
|
v0x56335d252ee0_0 .net "clk", 0 0, v0x56335d253690_0; 1 drivers
|
|
v0x56335d252fb0_0 .net "parca", 2 0, v0x56335d253790_0; 1 drivers
|
|
v0x56335d253090_0 .var "yukseklik", 3 0;
|
|
v0x56335d2531c0_0 .var "yukseklik1", 3 0;
|
|
v0x56335d2532a0_0 .var "yukseklik2", 3 0;
|
|
v0x56335d253380_0 .var "yukseklik3", 3 0;
|
|
E_0x56335d238670 .event posedge, v0x56335d252ee0_0;
|
|
.scope S_0x56335d23e300;
|
|
T_0 ;
|
|
%pushi/vec4 0, 0, 4;
|
|
%store/vec4 v0x56335d200c00_0, 0, 4;
|
|
%pushi/vec4 0, 0, 1;
|
|
%store/vec4 v0x56335d200370_0, 0, 1;
|
|
%pushi/vec4 0, 0, 4;
|
|
%store/vec4 v0x56335d253090_0, 0, 4;
|
|
%pushi/vec4 0, 0, 4;
|
|
%store/vec4 v0x56335d2531c0_0, 0, 4;
|
|
%pushi/vec4 0, 0, 4;
|
|
%store/vec4 v0x56335d2532a0_0, 0, 4;
|
|
%pushi/vec4 0, 0, 4;
|
|
%store/vec4 v0x56335d253380_0, 0, 4;
|
|
%end;
|
|
.thread T_0;
|
|
.scope S_0x56335d23e300;
|
|
T_1 ;
|
|
%wait E_0x56335d238670;
|
|
%load/vec4 v0x56335d200370_0;
|
|
%nor/r;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_1.0, 8;
|
|
%load/vec4 v0x56335d252fb0_0;
|
|
%parti/s 1, 0, 2;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_1.2, 8;
|
|
%load/vec4 v0x56335d2531c0_0;
|
|
%addi 1, 0, 4;
|
|
%assign/vec4 v0x56335d2531c0_0, 0;
|
|
T_1.2 ;
|
|
%load/vec4 v0x56335d252fb0_0;
|
|
%parti/s 1, 1, 2;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_1.4, 8;
|
|
%load/vec4 v0x56335d2532a0_0;
|
|
%addi 1, 0, 4;
|
|
%assign/vec4 v0x56335d2532a0_0, 0;
|
|
T_1.4 ;
|
|
%load/vec4 v0x56335d252fb0_0;
|
|
%parti/s 1, 2, 3;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_1.6, 8;
|
|
%load/vec4 v0x56335d253380_0;
|
|
%addi 1, 0, 4;
|
|
%assign/vec4 v0x56335d253380_0, 0;
|
|
T_1.6 ;
|
|
%load/vec4 v0x56335d200c00_0;
|
|
%addi 1, 0, 4;
|
|
%assign/vec4 v0x56335d200c00_0, 0;
|
|
%load/vec4 v0x56335d200c00_0;
|
|
%cmpi/e 15, 0, 4;
|
|
%jmp/0xz T_1.8, 4;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x56335d200370_0, 0;
|
|
T_1.8 ;
|
|
T_1.0 ;
|
|
%jmp T_1;
|
|
.thread T_1;
|
|
.scope S_0x56335d23e300;
|
|
T_2 ;
|
|
%wait E_0x56335d238670;
|
|
%load/vec4 v0x56335d200370_0;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_2.0, 8;
|
|
%load/vec4 v0x56335d2532a0_0;
|
|
%load/vec4 v0x56335d2531c0_0;
|
|
%cmp/u;
|
|
%flag_get/vec4 4;
|
|
%flag_get/vec4 5;
|
|
%or;
|
|
%load/vec4 v0x56335d253380_0;
|
|
%load/vec4 v0x56335d2531c0_0;
|
|
%cmp/u;
|
|
%flag_get/vec4 4;
|
|
%flag_get/vec4 5;
|
|
%or;
|
|
%and;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_2.2, 8;
|
|
%load/vec4 v0x56335d2531c0_0;
|
|
%assign/vec4 v0x56335d253090_0, 0;
|
|
%jmp T_2.3;
|
|
T_2.2 ;
|
|
%load/vec4 v0x56335d2531c0_0;
|
|
%load/vec4 v0x56335d2532a0_0;
|
|
%cmp/u;
|
|
%flag_get/vec4 4;
|
|
%flag_get/vec4 5;
|
|
%or;
|
|
%load/vec4 v0x56335d253380_0;
|
|
%load/vec4 v0x56335d2532a0_0;
|
|
%cmp/u;
|
|
%flag_get/vec4 4;
|
|
%flag_get/vec4 5;
|
|
%or;
|
|
%and;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_2.4, 8;
|
|
%load/vec4 v0x56335d2532a0_0;
|
|
%assign/vec4 v0x56335d253090_0, 0;
|
|
%jmp T_2.5;
|
|
T_2.4 ;
|
|
%load/vec4 v0x56335d253380_0;
|
|
%assign/vec4 v0x56335d253090_0, 0;
|
|
T_2.5 ;
|
|
T_2.3 ;
|
|
T_2.0 ;
|
|
%jmp T_2;
|
|
.thread T_2;
|
|
.scope S_0x56335d23e170;
|
|
T_3 ;
|
|
%load/vec4 v0x56335d253690_0;
|
|
%inv;
|
|
%store/vec4 v0x56335d253690_0, 0, 1;
|
|
%delay 1, 0;
|
|
%jmp T_3;
|
|
.thread T_3;
|
|
.scope S_0x56335d23e170;
|
|
T_4 ;
|
|
%vpi_call 2 22 "$dumpfile", "tetris.vcd" {0 0 0};
|
|
%vpi_call 2 23 "$dumpvars" {0 0 0};
|
|
%pushi/vec4 0, 0, 1;
|
|
%store/vec4 v0x56335d253690_0, 0, 1;
|
|
%pushi/vec4 2, 0, 3;
|
|
%store/vec4 v0x56335d253790_0, 0, 3;
|
|
%delay 2, 0;
|
|
%pushi/vec4 3, 0, 3;
|
|
%store/vec4 v0x56335d253790_0, 0, 3;
|
|
%delay 2, 0;
|
|
%pushi/vec4 2, 0, 3;
|
|
%store/vec4 v0x56335d253790_0, 0, 3;
|
|
%delay 2, 0;
|
|
%pushi/vec4 0, 0, 3;
|
|
%store/vec4 v0x56335d253790_0, 0, 3;
|
|
%delay 30, 0;
|
|
%vpi_call 2 28 "$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";
|
|
"<interactive>";
|
|
"tetrisTB.v";
|
|
"tetris.v";
|