#! /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_0x7fbaa1007ac0 .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_0x7fbaa1005e00 .param/l "BPS" 0 2 14, +C4<00000000000000011100001000000000>; P_0x7fbaa1005e40 .param/l "B_MAX" 1 2 16, +C4<00000000000000000000000110110010>; P_0x7fbaa1005e80 .param/l "CLK_FREQ" 0 2 13, +C4<00000010111110101111000010000000>; v0x7fbaa10069a0_0 .var "baud_cnt", 15 0; o0x7fbaa1432038 .functor BUFZ 1, C4; HiZ drive v0x7fbaa10179c0_0 .net "start_en", 0 0, o0x7fbaa1432038; 0 drivers o0x7fbaa1432068 .functor BUFZ 1, C4; HiZ drive v0x7fbaa1017a60_0 .net "sys_clk", 0 0, o0x7fbaa1432068; 0 drivers o0x7fbaa1432098 .functor BUFZ 1, C4; HiZ drive v0x7fbaa1017af0_0 .net "sys_rst", 0 0, o0x7fbaa1432098; 0 drivers v0x7fbaa1017b90_0 .var "temp_tx_data", 7 0; v0x7fbaa1017c80_0 .var "tx_busy", 0 0; v0x7fbaa1017d20_0 .var "tx_d_cnt", 3 0; o0x7fbaa1432158 .functor BUFZ 8, C4; HiZ drive v0x7fbaa1017dd0_0 .net "tx_data", 7 0, o0x7fbaa1432158; 0 drivers v0x7fbaa1017e80_0 .var "txd", 0 0; E_0x7fbaa1005110/0 .event negedge, v0x7fbaa1017af0_0; E_0x7fbaa1005110/1 .event posedge, v0x7fbaa1017a60_0; E_0x7fbaa1005110 .event/or E_0x7fbaa1005110/0, E_0x7fbaa1005110/1; .scope S_0x7fbaa1007ac0; T_0 ; %wait E_0x7fbaa1005110; %load/vec4 v0x7fbaa1017af0_0; %cmpi/e 0, 0, 1; %jmp/0xz T_0.0, 4; %pushi/vec4 0, 0, 8; %assign/vec4 v0x7fbaa1017b90_0, 0; %jmp T_0.1; T_0.0 ; %load/vec4 v0x7fbaa10179c0_0; %flag_set/vec4 8; %jmp/0xz T_0.2, 8; %load/vec4 v0x7fbaa1017dd0_0; %assign/vec4 v0x7fbaa1017b90_0, 0; T_0.2 ; T_0.1 ; %jmp T_0; .thread T_0; .scope S_0x7fbaa1007ac0; T_1 ; %wait E_0x7fbaa1005110; %load/vec4 v0x7fbaa1017af0_0; %cmpi/e 0, 0, 1; %jmp/0xz T_1.0, 4; %pushi/vec4 0, 0, 1; %assign/vec4 v0x7fbaa1017c80_0, 0; %jmp T_1.1; T_1.0 ; %load/vec4 v0x7fbaa10179c0_0; %flag_set/vec4 8; %jmp/0xz T_1.2, 8; %pushi/vec4 1, 0, 1; %assign/vec4 v0x7fbaa1017c80_0, 0; %jmp T_1.3; T_1.2 ; %load/vec4 v0x7fbaa1017d20_0; %pad/u 32; %cmpi/e 9, 0, 32; %flag_get/vec4 4; %jmp/0 T_1.6, 4; %load/vec4 v0x7fbaa10069a0_0; %pad/u 32; %pushi/vec4 404, 0, 32; %cmp/e; %flag_get/vec4 4; %and; T_1.6; %flag_set/vec4 8; %jmp/0xz T_1.4, 8; %pushi/vec4 0, 0, 1; %assign/vec4 v0x7fbaa1017c80_0, 0; %jmp T_1.5; T_1.4 ; %load/vec4 v0x7fbaa1017c80_0; %assign/vec4 v0x7fbaa1017c80_0, 0; T_1.5 ; T_1.3 ; T_1.1 ; %jmp T_1; .thread T_1; .scope S_0x7fbaa1007ac0; T_2 ; %wait E_0x7fbaa1005110; %load/vec4 v0x7fbaa1017af0_0; %cmpi/e 0, 0, 1; %jmp/0xz T_2.0, 4; %pushi/vec4 0, 0, 16; %assign/vec4 v0x7fbaa10069a0_0, 0; %jmp T_2.1; T_2.0 ; %load/vec4 v0x7fbaa1017c80_0; %flag_set/vec4 8; %jmp/0xz T_2.2, 8; %load/vec4 v0x7fbaa10069a0_0; %pad/u 32; %cmpi/e 433, 0, 32; %jmp/0xz T_2.4, 4; %pushi/vec4 0, 0, 16; %assign/vec4 v0x7fbaa10069a0_0, 0; %jmp T_2.5; T_2.4 ; %load/vec4 v0x7fbaa10069a0_0; %addi 1, 0, 16; %assign/vec4 v0x7fbaa10069a0_0, 0; T_2.5 ; %jmp T_2.3; T_2.2 ; %pushi/vec4 0, 0, 16; %assign/vec4 v0x7fbaa10069a0_0, 0; T_2.3 ; T_2.1 ; %jmp T_2; .thread T_2; .scope S_0x7fbaa1007ac0; T_3 ; %wait E_0x7fbaa1005110; %load/vec4 v0x7fbaa1017af0_0; %cmpi/e 0, 0, 1; %jmp/0xz T_3.0, 4; %pushi/vec4 0, 0, 4; %assign/vec4 v0x7fbaa1017d20_0, 0; %jmp T_3.1; T_3.0 ; %load/vec4 v0x7fbaa1017c80_0; %flag_set/vec4 8; %jmp/0xz T_3.2, 8; %load/vec4 v0x7fbaa10069a0_0; %pad/u 32; %cmpi/e 433, 0, 32; %jmp/0xz T_3.4, 4; %load/vec4 v0x7fbaa1017d20_0; %addi 1, 0, 4; %assign/vec4 v0x7fbaa1017d20_0, 0; %jmp T_3.5; T_3.4 ; %load/vec4 v0x7fbaa1017d20_0; %assign/vec4 v0x7fbaa1017d20_0, 0; T_3.5 ; %jmp T_3.3; T_3.2 ; %pushi/vec4 0, 0, 4; %assign/vec4 v0x7fbaa1017d20_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";