#! /usr/local/Cellar/icarus-verilog/12.0/bin/vvp :ivl_version "12.0 (stable)"; :ivl_delay_selection "TYPICAL"; :vpi_time_precision + 0; :vpi_module "/usr/local/Cellar/icarus-verilog/12.0/lib/ivl/system.vpi"; :vpi_module "/usr/local/Cellar/icarus-verilog/12.0/lib/ivl/vhdl_sys.vpi"; :vpi_module "/usr/local/Cellar/icarus-verilog/12.0/lib/ivl/vhdl_textio.vpi"; :vpi_module "/usr/local/Cellar/icarus-verilog/12.0/lib/ivl/v2005_math.vpi"; :vpi_module "/usr/local/Cellar/icarus-verilog/12.0/lib/ivl/va_math.vpi"; S_0x7fef0a6042d0 .scope module, "uart_tx" "uart_tx" 2 1; .timescale 0 0; .port_info 0 /INPUT 1 "sys_clk"; .port_info 1 /INPUT 1 "sys_rst"; .port_info 2 /INPUT 1 "start_en"; .port_info 3 /INPUT 8 "tx_data"; .port_info 4 /OUTPUT 1 "txd"; .port_info 5 /OUTPUT 1 "tx_busy"; P_0x7fef0a604440 .param/l "BPS" 0 2 12, +C4<00000000000000011100001000000000>; P_0x7fef0a604480 .param/l "B_MAX" 1 2 13, +C4<00000000000000000000000110110010>; P_0x7fef0a6044c0 .param/l "CLK_FREQ" 0 2 11, +C4<00000010111110101111000010000000>; v0x7fef0a604760_0 .var "baud_cnt", 15 0; o0x7fef0a432038 .functor BUFZ 1, C4; HiZ drive v0x7fef0a515b20_0 .net "start_en", 0 0, o0x7fef0a432038; 0 drivers o0x7fef0a432068 .functor BUFZ 1, C4; HiZ drive v0x7fef0a515bd0_0 .net "sys_clk", 0 0, o0x7fef0a432068; 0 drivers o0x7fef0a432098 .functor BUFZ 1, C4; HiZ drive v0x7fef0a515c80_0 .net "sys_rst", 0 0, o0x7fef0a432098; 0 drivers v0x7fef0a515d10_0 .var "temp_tx_data", 7 0; v0x7fef0a515da0_0 .var "tx_busy", 0 0; v0x7fef0a515e40_0 .var "tx_d_cnt", 3 0; o0x7fef0a432158 .functor BUFZ 8, C4; HiZ drive v0x7fef0a515ef0_0 .net "tx_data", 7 0, o0x7fef0a432158; 0 drivers v0x7fef0a515fa0_0 .var "txd", 0 0; E_0x7fef0a604540/0 .event negedge, v0x7fef0a515c80_0; E_0x7fef0a604540/1 .event posedge, v0x7fef0a515bd0_0; E_0x7fef0a604540 .event/or E_0x7fef0a604540/0, E_0x7fef0a604540/1; .scope S_0x7fef0a6042d0; T_0 ; %wait E_0x7fef0a604540; %load/vec4 v0x7fef0a515c80_0; %cmpi/e 0, 0, 1; %jmp/0xz T_0.0, 4; %pushi/vec4 0, 0, 8; %assign/vec4 v0x7fef0a515d10_0, 0; %pushi/vec4 0, 0, 1; %assign/vec4 v0x7fef0a515da0_0, 0; %jmp T_0.1; T_0.0 ; %load/vec4 v0x7fef0a515b20_0; %flag_set/vec4 8; %jmp/0xz T_0.2, 8; %load/vec4 v0x7fef0a515ef0_0; %assign/vec4 v0x7fef0a515d10_0, 0; %pushi/vec4 1, 0, 1; %assign/vec4 v0x7fef0a515da0_0, 0; %jmp T_0.3; T_0.2 ; %load/vec4 v0x7fef0a515e40_0; %pad/u 32; %cmpi/e 9, 0, 32; %flag_get/vec4 4; %jmp/0 T_0.6, 4; %load/vec4 v0x7fef0a604760_0; %pad/u 32; %pushi/vec4 433, 0, 32; %cmp/e; %flag_get/vec4 4; %and; T_0.6; %flag_set/vec4 8; %jmp/0xz T_0.4, 8; %pushi/vec4 0, 0, 8; %assign/vec4 v0x7fef0a515d10_0, 0; %pushi/vec4 0, 0, 1; %assign/vec4 v0x7fef0a515da0_0, 0; %jmp T_0.5; T_0.4 ; %load/vec4 v0x7fef0a515d10_0; %assign/vec4 v0x7fef0a515d10_0, 0; %load/vec4 v0x7fef0a515da0_0; %assign/vec4 v0x7fef0a515da0_0, 0; T_0.5 ; T_0.3 ; T_0.1 ; %jmp T_0; .thread T_0; .scope S_0x7fef0a6042d0; T_1 ; %wait E_0x7fef0a604540; %load/vec4 v0x7fef0a515c80_0; %cmpi/e 0, 0, 1; %jmp/0xz T_1.0, 4; %pushi/vec4 0, 0, 16; %assign/vec4 v0x7fef0a604760_0, 0; %jmp T_1.1; T_1.0 ; %load/vec4 v0x7fef0a515b20_0; %flag_set/vec4 8; %jmp/0xz T_1.2, 8; %pushi/vec4 0, 0, 16; %assign/vec4 v0x7fef0a604760_0, 0; %jmp T_1.3; T_1.2 ; %load/vec4 v0x7fef0a515da0_0; %flag_set/vec4 8; %jmp/0xz T_1.4, 8; %load/vec4 v0x7fef0a604760_0; %pad/u 32; %cmpi/e 433, 0, 32; %jmp/0xz T_1.6, 4; %pushi/vec4 0, 0, 16; %assign/vec4 v0x7fef0a604760_0, 0; %jmp T_1.7; T_1.6 ; %load/vec4 v0x7fef0a604760_0; %addi 1, 0, 16; %assign/vec4 v0x7fef0a604760_0, 0; T_1.7 ; %jmp T_1.5; T_1.4 ; %pushi/vec4 0, 0, 16; %assign/vec4 v0x7fef0a604760_0, 0; T_1.5 ; T_1.3 ; T_1.1 ; %jmp T_1; .thread T_1; .scope S_0x7fef0a6042d0; T_2 ; %wait E_0x7fef0a604540; %load/vec4 v0x7fef0a515c80_0; %cmpi/e 0, 0, 1; %jmp/0xz T_2.0, 4; %pushi/vec4 0, 0, 4; %assign/vec4 v0x7fef0a515e40_0, 0; %jmp T_2.1; T_2.0 ; %load/vec4 v0x7fef0a515b20_0; %flag_set/vec4 8; %jmp/0xz T_2.2, 8; %pushi/vec4 0, 0, 4; %assign/vec4 v0x7fef0a515e40_0, 0; %jmp T_2.3; T_2.2 ; %load/vec4 v0x7fef0a515da0_0; %flag_set/vec4 8; %jmp/0xz T_2.4, 8; %load/vec4 v0x7fef0a604760_0; %pad/u 32; %cmpi/e 433, 0, 32; %jmp/0xz T_2.6, 4; %load/vec4 v0x7fef0a515e40_0; %addi 1, 0, 4; %assign/vec4 v0x7fef0a515e40_0, 0; %jmp T_2.7; T_2.6 ; %load/vec4 v0x7fef0a515e40_0; %assign/vec4 v0x7fef0a515e40_0, 0; T_2.7 ; %jmp T_2.5; T_2.4 ; %pushi/vec4 0, 0, 4; %assign/vec4 v0x7fef0a515e40_0, 0; T_2.5 ; T_2.3 ; T_2.1 ; %jmp T_2; .thread T_2; .scope S_0x7fef0a6042d0; T_3 ; %wait E_0x7fef0a604540; %load/vec4 v0x7fef0a515c80_0; %cmpi/e 0, 0, 1; %jmp/0xz T_3.0, 4; %pushi/vec4 1, 0, 1; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.1; T_3.0 ; %load/vec4 v0x7fef0a515da0_0; %flag_set/vec4 8; %jmp/0xz T_3.2, 8; %load/vec4 v0x7fef0a515e40_0; %dup/vec4; %pushi/vec4 0, 0, 4; %cmp/u; %jmp/1 T_3.4, 6; %dup/vec4; %pushi/vec4 1, 0, 4; %cmp/u; %jmp/1 T_3.5, 6; %dup/vec4; %pushi/vec4 2, 0, 4; %cmp/u; %jmp/1 T_3.6, 6; %dup/vec4; %pushi/vec4 3, 0, 4; %cmp/u; %jmp/1 T_3.7, 6; %dup/vec4; %pushi/vec4 4, 0, 4; %cmp/u; %jmp/1 T_3.8, 6; %dup/vec4; %pushi/vec4 5, 0, 4; %cmp/u; %jmp/1 T_3.9, 6; %dup/vec4; %pushi/vec4 6, 0, 4; %cmp/u; %jmp/1 T_3.10, 6; %dup/vec4; %pushi/vec4 7, 0, 4; %cmp/u; %jmp/1 T_3.11, 6; %dup/vec4; %pushi/vec4 8, 0, 4; %cmp/u; %jmp/1 T_3.12, 6; %dup/vec4; %pushi/vec4 9, 0, 4; %cmp/u; %jmp/1 T_3.13, 6; %pushi/vec4 1, 0, 1; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.4 ; %pushi/vec4 0, 0, 1; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.5 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 0, 2; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.6 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 1, 2; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.7 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 2, 3; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.8 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 3, 3; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.9 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 4, 4; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.10 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 5, 4; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.11 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 6, 4; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.12 ; %load/vec4 v0x7fef0a515d10_0; %parti/s 1, 7, 4; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.13 ; %pushi/vec4 1, 0, 1; %assign/vec4 v0x7fef0a515fa0_0, 0; %jmp T_3.15; T_3.15 ; %pop/vec4 1; %jmp T_3.3; T_3.2 ; %pushi/vec4 1, 0, 1; %assign/vec4 v0x7fef0a515fa0_0, 0; T_3.3 ; T_3.1 ; %jmp T_3; .thread T_3; # The file index is used to find the file name in the following table. :file_names 3; "N/A"; ""; "uart_tx.v";