342 lines
8.9 KiB
Plaintext
342 lines
8.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_0x55a2c2765ba0 .scope module, "bib3AdvancedTB" "bib3AdvancedTB" 2 1;
|
|
.timescale 0 0;
|
|
v0x55a2c2780cc0_0 .var "basla", 0 0;
|
|
v0x55a2c2780d80_0 .net "bitti", 0 0, v0x55a2c27805f0_0; 1 drivers
|
|
v0x55a2c2780e50_0 .var "buyruk", 8 0;
|
|
v0x55a2c2780f50_0 .var "clk", 0 0;
|
|
v0x55a2c2781020_0 .var/i "i", 31 0;
|
|
v0x55a2c27810c0 .array "memory", 15 0, 8 0;
|
|
v0x55a2c2781160_0 .net "sonuc", 3 0, v0x55a2c2780b40_0; 1 drivers
|
|
S_0x55a2c2765d30 .scope module, "uut" "bib3Advanced" 2 10, 3 1 0, S_0x55a2c2765ba0;
|
|
.timescale 0 0;
|
|
.port_info 0 /INPUT 1 "clk";
|
|
.port_info 1 /INPUT 1 "basla";
|
|
.port_info 2 /INPUT 9 "buyruk";
|
|
.port_info 3 /OUTPUT 4 "sonuc";
|
|
.port_info 4 /OUTPUT 1 "bitti";
|
|
v0x55a2c2723c00_0 .var/i "a", 31 0;
|
|
v0x55a2c2780470_0 .var/i "b", 31 0;
|
|
v0x55a2c2780550_0 .net "basla", 0 0, v0x55a2c2780cc0_0; 1 drivers
|
|
v0x55a2c27805f0_0 .var "bitti", 0 0;
|
|
v0x55a2c27806b0_0 .net "buyruk", 8 0, v0x55a2c2780e50_0; 1 drivers
|
|
v0x55a2c27807e0_0 .var/i "c", 31 0;
|
|
v0x55a2c27808c0_0 .net "clk", 0 0, v0x55a2c2780f50_0; 1 drivers
|
|
v0x55a2c2780980_0 .var/i "count", 31 0;
|
|
v0x55a2c2780a60_0 .var/i "i", 31 0;
|
|
v0x55a2c2780b40_0 .var "sonuc", 3 0;
|
|
E_0x55a2c275ba20 .event posedge, v0x55a2c27808c0_0;
|
|
.scope S_0x55a2c2765d30;
|
|
T_0 ;
|
|
%wait E_0x55a2c275ba20;
|
|
%load/vec4 v0x55a2c2780550_0;
|
|
%flag_set/vec4 8;
|
|
%jmp/0xz T_0.0, 8;
|
|
%pushi/vec4 0, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 6, 4;
|
|
%dup/vec4;
|
|
%pushi/vec4 0, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.3, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 1, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.4, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 2, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.5, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 3, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.6, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 4, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.7, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 5, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.8, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 6, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.9, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 7, 0, 3;
|
|
%cmp/u;
|
|
%jmp/1 T_0.10, 6;
|
|
%pushi/vec4 0, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.3 ;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 3, 3;
|
|
%pad/u 4;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 0, 2;
|
|
%pad/u 4;
|
|
%add;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.4 ;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 3, 3;
|
|
%pad/u 4;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 0, 2;
|
|
%pad/u 4;
|
|
%sub;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.5 ;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 3, 3;
|
|
%pad/u 4;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 0, 2;
|
|
%pad/u 4;
|
|
%and;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.6 ;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 3, 3;
|
|
%pad/u 4;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%parti/s 3, 0, 2;
|
|
%pad/u 4;
|
|
%or;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.7 ;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55a2c2780a60_0, 0, 32;
|
|
T_0.12 ;
|
|
%load/vec4 v0x55a2c2780a60_0;
|
|
%cmpi/s 4, 0, 32;
|
|
%flag_or 5, 4;
|
|
%jmp/0xz T_0.13, 5;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%load/vec4 v0x55a2c2780a60_0;
|
|
%part/s 1;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%load/vec4 v0x55a2c2780a60_0;
|
|
%addi 1, 0, 32;
|
|
%part/s 1;
|
|
%cmp/e;
|
|
%jmp/0xz T_0.14, 4;
|
|
%pushi/vec4 15, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%jmp T_0.15;
|
|
T_0.14 ;
|
|
%pushi/vec4 0, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
T_0.15 ;
|
|
; show_stmt_assign_vector: Get l-value for compressed += operand
|
|
%load/vec4 v0x55a2c2780a60_0;
|
|
%pushi/vec4 1, 0, 32;
|
|
%add;
|
|
%store/vec4 v0x55a2c2780a60_0, 0, 32;
|
|
%jmp T_0.12;
|
|
T_0.13 ;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.8 ;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55a2c2723c00_0, 0, 32;
|
|
T_0.16 ;
|
|
%load/vec4 v0x55a2c2723c00_0;
|
|
%cmpi/s 5, 0, 32;
|
|
%flag_or 5, 4;
|
|
%jmp/0xz T_0.17, 5;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%load/vec4 v0x55a2c2723c00_0;
|
|
%part/s 1;
|
|
%pad/u 32;
|
|
%cmpi/e 1, 0, 32;
|
|
%jmp/0xz T_0.18, 4;
|
|
%pushi/vec4 15, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%jmp T_0.19;
|
|
T_0.18 ;
|
|
%pushi/vec4 0, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
T_0.19 ;
|
|
; show_stmt_assign_vector: Get l-value for compressed += operand
|
|
%load/vec4 v0x55a2c2723c00_0;
|
|
%pushi/vec4 1, 0, 32;
|
|
%add;
|
|
%store/vec4 v0x55a2c2723c00_0, 0, 32;
|
|
%jmp T_0.16;
|
|
T_0.17 ;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.9 ;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55a2c2780980_0, 0, 32;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55a2c2780470_0, 0, 32;
|
|
T_0.20 ;
|
|
%load/vec4 v0x55a2c2780470_0;
|
|
%cmpi/s 5, 0, 32;
|
|
%flag_or 5, 4;
|
|
%jmp/0xz T_0.21, 5;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%load/vec4 v0x55a2c2780470_0;
|
|
%part/s 1;
|
|
%pad/u 32;
|
|
%cmpi/e 1, 0, 32;
|
|
%jmp/0xz T_0.22, 4;
|
|
%load/vec4 v0x55a2c2780980_0;
|
|
%addi 1, 0, 32;
|
|
%store/vec4 v0x55a2c2780980_0, 0, 32;
|
|
T_0.22 ;
|
|
; show_stmt_assign_vector: Get l-value for compressed += operand
|
|
%load/vec4 v0x55a2c2780470_0;
|
|
%pushi/vec4 1, 0, 32;
|
|
%add;
|
|
%store/vec4 v0x55a2c2780470_0, 0, 32;
|
|
%jmp T_0.20;
|
|
T_0.21 ;
|
|
%load/vec4 v0x55a2c2780980_0;
|
|
%pushi/vec4 2, 0, 32;
|
|
%mod/s;
|
|
%cmpi/e 0, 0, 32;
|
|
%jmp/0xz T_0.24, 4;
|
|
%pushi/vec4 15, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%jmp T_0.25;
|
|
T_0.24 ;
|
|
%pushi/vec4 0, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
T_0.25 ;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.10 ;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55a2c2780980_0, 0, 32;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55a2c27807e0_0, 0, 32;
|
|
T_0.26 ;
|
|
%load/vec4 v0x55a2c27807e0_0;
|
|
%cmpi/s 5, 0, 32;
|
|
%flag_or 5, 4;
|
|
%jmp/0xz T_0.27, 5;
|
|
%load/vec4 v0x55a2c27806b0_0;
|
|
%load/vec4 v0x55a2c27807e0_0;
|
|
%part/s 1;
|
|
%pad/u 32;
|
|
%cmpi/e 1, 0, 32;
|
|
%jmp/0xz T_0.28, 4;
|
|
%load/vec4 v0x55a2c2780980_0;
|
|
%addi 1, 0, 32;
|
|
%store/vec4 v0x55a2c2780980_0, 0, 32;
|
|
T_0.28 ;
|
|
; show_stmt_assign_vector: Get l-value for compressed += operand
|
|
%load/vec4 v0x55a2c27807e0_0;
|
|
%pushi/vec4 1, 0, 32;
|
|
%add;
|
|
%store/vec4 v0x55a2c27807e0_0, 0, 32;
|
|
%jmp T_0.26;
|
|
T_0.27 ;
|
|
%load/vec4 v0x55a2c2780980_0;
|
|
%pushi/vec4 2, 0, 32;
|
|
%mod/s;
|
|
%cmpi/e 0, 0, 32;
|
|
%jmp/0xz T_0.30, 4;
|
|
%pushi/vec4 0, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
%jmp T_0.31;
|
|
T_0.30 ;
|
|
%pushi/vec4 15, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
T_0.31 ;
|
|
%pushi/vec4 1, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%jmp T_0.11;
|
|
T_0.11 ;
|
|
%pop/vec4 1;
|
|
%jmp T_0.1;
|
|
T_0.0 ;
|
|
%pushi/vec4 0, 0, 1;
|
|
%assign/vec4 v0x55a2c27805f0_0, 0;
|
|
%pushi/vec4 0, 0, 4;
|
|
%assign/vec4 v0x55a2c2780b40_0, 0;
|
|
T_0.1 ;
|
|
%jmp T_0;
|
|
.thread T_0;
|
|
.scope S_0x55a2c2765ba0;
|
|
T_1 ;
|
|
%load/vec4 v0x55a2c2780f50_0;
|
|
%inv;
|
|
%store/vec4 v0x55a2c2780f50_0, 0, 1;
|
|
%delay 5, 0;
|
|
%jmp T_1;
|
|
.thread T_1;
|
|
.scope S_0x55a2c2765ba0;
|
|
T_2 ;
|
|
%vpi_call 2 25 "$dumpfile", "bib3Advanced.vcd" {0 0 0};
|
|
%vpi_call 2 26 "$dumpvars" {0 0 0};
|
|
%pushi/vec4 0, 0, 1;
|
|
%store/vec4 v0x55a2c2780f50_0, 0, 1;
|
|
%pushi/vec4 0, 0, 1;
|
|
%store/vec4 v0x55a2c2780cc0_0, 0, 1;
|
|
%pushi/vec4 0, 0, 9;
|
|
%store/vec4 v0x55a2c2780e50_0, 0, 9;
|
|
%vpi_call 2 28 "$readmemb", "memory.mem", v0x55a2c27810c0 {0 0 0};
|
|
%delay 10, 0;
|
|
%pushi/vec4 1, 0, 1;
|
|
%store/vec4 v0x55a2c2780cc0_0, 0, 1;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55a2c2781020_0, 0, 32;
|
|
T_2.0 ;
|
|
%load/vec4 v0x55a2c2781020_0;
|
|
%cmpi/s 16, 0, 32;
|
|
%flag_or 5, 4;
|
|
%jmp/0xz T_2.1, 5;
|
|
%ix/getv/s 4, v0x55a2c2781020_0;
|
|
%load/vec4a v0x55a2c27810c0, 4;
|
|
%store/vec4 v0x55a2c2780e50_0, 0, 9;
|
|
%delay 10, 0;
|
|
; show_stmt_assign_vector: Get l-value for compressed += operand
|
|
%load/vec4 v0x55a2c2781020_0;
|
|
%pushi/vec4 1, 0, 32;
|
|
%add;
|
|
%store/vec4 v0x55a2c2781020_0, 0, 32;
|
|
%jmp T_2.0;
|
|
T_2.1 ;
|
|
%pushi/vec4 0, 0, 1;
|
|
%store/vec4 v0x55a2c2780cc0_0, 0, 1;
|
|
%delay 10, 0;
|
|
%vpi_call 2 36 "$finish" {0 0 0};
|
|
%end;
|
|
.thread T_2;
|
|
# The file index is used to find the file name in the following table.
|
|
:file_names 4;
|
|
"N/A";
|
|
"<interactive>";
|
|
"bib3AdvancedTB.v";
|
|
"bib3Advanced.v";
|