You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
169 lines
4.7 KiB
Plaintext
169 lines
4.7 KiB
Plaintext
#! /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<z>; HiZ drive
|
|
v0x7fbaa10179c0_0 .net "start_en", 0 0, o0x7fbaa1432038; 0 drivers
|
|
o0x7fbaa1432068 .functor BUFZ 1, C4<z>; HiZ drive
|
|
v0x7fbaa1017a60_0 .net "sys_clk", 0 0, o0x7fbaa1432068; 0 drivers
|
|
o0x7fbaa1432098 .functor BUFZ 1, C4<z>; 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<zzzzzzzz>; 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";
|
|
"<interactive>";
|
|
"uart_tx.v";
|