initial
This commit is contained in:
83
chapter2/calculator
Executable file
83
chapter2/calculator
Executable file
@@ -0,0 +1,83 @@
|
||||
#! /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";
|
Reference in New Issue
Block a user