Files
LF-Build-RISCV/chapter2/calculator
2025-08-18 07:18:32 +03:00

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";