84 lines
2.5 KiB
Plaintext
Executable File
84 lines
2.5 KiB
Plaintext
Executable File
#! /usr/bin/vvp
|
|
:ivl_version "12.0 (stable)";
|
|
:ivl_delay_selection "TYPICAL";
|
|
:vpi_time_precision + 0;
|
|
:vpi_module "/usr/lib64/ivl/system.vpi";
|
|
:vpi_module "/usr/lib64/ivl/vhdl_sys.vpi";
|
|
:vpi_module "/usr/lib64/ivl/vhdl_textio.vpi";
|
|
:vpi_module "/usr/lib64/ivl/v2005_math.vpi";
|
|
:vpi_module "/usr/lib64/ivl/va_math.vpi";
|
|
S_0x55fa39636f10 .scope module, "calculator" "calculator" 2 1;
|
|
.timescale 0 0;
|
|
.port_info 0 /INPUT 32 "A";
|
|
.port_info 1 /INPUT 32 "B";
|
|
.port_info 2 /INPUT 2 "op";
|
|
.port_info 3 /OUTPUT 32 "Y";
|
|
L_0x7feabdea7018 .functor BUFT 1, C4<0000000000000000000000000000zzzz>, C4<0>, C4<0>, C4<0>;
|
|
v0x55fa39635140_0 .net "A", 31 0, L_0x7feabdea7018; 1 drivers
|
|
o0x7feabdef0048 .functor BUFZ 4, C4<zzzz>; HiZ drive
|
|
v0x55fa39610eb0_0 .net "A_rand", 3 0, o0x7feabdef0048; 0 drivers
|
|
L_0x7feabdea7060 .functor BUFT 1, C4<00000000000000000000000000zzzzzz>, C4<0>, C4<0>, C4<0>;
|
|
v0x55fa3965a2a0_0 .net "B", 31 0, L_0x7feabdea7060; 1 drivers
|
|
o0x7feabdef00a8 .functor BUFZ 6, C4<zzzzzz>; HiZ drive
|
|
v0x55fa3965a360_0 .net "B_rand", 5 0, o0x7feabdef00a8; 0 drivers
|
|
v0x55fa3965a440_0 .var "Y", 31 0;
|
|
o0x7feabdef0108 .functor BUFZ 2, C4<zz>; HiZ drive
|
|
v0x55fa3965a570_0 .net "op", 1 0, o0x7feabdef0108; 0 drivers
|
|
E_0x55fa39647e70 .event anyedge, v0x55fa3965a570_0, v0x55fa39635140_0, v0x55fa3965a2a0_0;
|
|
.scope S_0x55fa39636f10;
|
|
T_0 ;
|
|
%wait E_0x55fa39647e70;
|
|
%load/vec4 v0x55fa3965a570_0;
|
|
%dup/vec4;
|
|
%pushi/vec4 0, 0, 2;
|
|
%cmp/u;
|
|
%jmp/1 T_0.0, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 1, 0, 2;
|
|
%cmp/u;
|
|
%jmp/1 T_0.1, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 2, 0, 2;
|
|
%cmp/u;
|
|
%jmp/1 T_0.2, 6;
|
|
%dup/vec4;
|
|
%pushi/vec4 3, 0, 2;
|
|
%cmp/u;
|
|
%jmp/1 T_0.3, 6;
|
|
%pushi/vec4 0, 0, 32;
|
|
%store/vec4 v0x55fa3965a440_0, 0, 32;
|
|
%jmp T_0.5;
|
|
T_0.0 ;
|
|
%load/vec4 v0x55fa39635140_0;
|
|
%load/vec4 v0x55fa3965a2a0_0;
|
|
%add;
|
|
%store/vec4 v0x55fa3965a440_0, 0, 32;
|
|
%jmp T_0.5;
|
|
T_0.1 ;
|
|
%load/vec4 v0x55fa39635140_0;
|
|
%load/vec4 v0x55fa3965a2a0_0;
|
|
%sub;
|
|
%store/vec4 v0x55fa3965a440_0, 0, 32;
|
|
%jmp T_0.5;
|
|
T_0.2 ;
|
|
%load/vec4 v0x55fa39635140_0;
|
|
%load/vec4 v0x55fa3965a2a0_0;
|
|
%mul;
|
|
%store/vec4 v0x55fa3965a440_0, 0, 32;
|
|
%jmp T_0.5;
|
|
T_0.3 ;
|
|
%load/vec4 v0x55fa39635140_0;
|
|
%load/vec4 v0x55fa3965a2a0_0;
|
|
%div;
|
|
%store/vec4 v0x55fa3965a440_0, 0, 32;
|
|
%jmp T_0.5;
|
|
T_0.5 ;
|
|
%pop/vec4 1;
|
|
%jmp T_0;
|
|
.thread T_0, $push;
|
|
# The file index is used to find the file name in the following table.
|
|
:file_names 3;
|
|
"N/A";
|
|
"<interactive>";
|
|
"calculator.v";
|