优化代码, 防止发送过快或者晶振导致计数器误差, start_en在busy结束之前出现导致计数器不再工作

main
阳光少年 8 months ago
parent 6ed71a9a79
commit 3816e69714

@ -26,7 +26,7 @@ always @(posedge sys_clk or negedge sys_rst) begin
temp_tx_data <= tx_data; //
tx_busy <= 'b1; //
end
else if (tx_d_cnt == 'b1001 && baud_cnt == (B_MAX / 16 * 15)-1) begin // ,
else if (tx_d_cnt == 'b1001 && baud_cnt == B_MAX-1) begin //
temp_tx_data <= 'b0;
tx_busy <= 0;
end
@ -41,6 +41,9 @@ always @(posedge sys_clk or negedge sys_rst) begin
if (sys_rst == 1'b0) begin
baud_cnt <= 'b0;
end
else if (start_en) begin // ,
baud_cnt <= 'b0;
end
//
else if (tx_busy) begin
if (baud_cnt == B_MAX-'b1) begin // 0 0~433 434
@ -60,6 +63,9 @@ always @(posedge sys_clk or negedge sys_rst) begin
if (sys_rst == 1'b0) begin
tx_d_cnt <= 'b0;
end
else if (start_en) begin // ,
tx_d_cnt <= 'b0;
end
//
else if (tx_busy) begin
if (baud_cnt == B_MAX-'b1) begin

@ -7,7 +7,7 @@
: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;
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";
@ -15,148 +15,268 @@ S_0x7fbaa1007ac0 .scope module, "uart_tx" "uart_tx" 2 1;
.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;
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<z>; HiZ drive
v0x7fef0a515b20_0 .net "start_en", 0 0, o0x7fef0a432038; 0 drivers
o0x7fef0a432068 .functor BUFZ 1, C4<z>; HiZ drive
v0x7fef0a515bd0_0 .net "sys_clk", 0 0, o0x7fef0a432068; 0 drivers
o0x7fef0a432098 .functor BUFZ 1, C4<z>; 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<zzzzzzzz>; 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_0x7fbaa1005110;
%load/vec4 v0x7fbaa1017af0_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 v0x7fbaa1017b90_0, 0;
%assign/vec4 v0x7fef0a515d10_0, 0;
%pushi/vec4 0, 0, 1;
%assign/vec4 v0x7fef0a515da0_0, 0;
%jmp T_0.1;
T_0.0 ;
%load/vec4 v0x7fbaa10179c0_0;
%load/vec4 v0x7fef0a515b20_0;
%flag_set/vec4 8;
%jmp/0xz T_0.2, 8;
%load/vec4 v0x7fbaa1017dd0_0;
%assign/vec4 v0x7fbaa1017b90_0, 0;
%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_0x7fbaa1007ac0;
.scope S_0x7fef0a6042d0;
T_1 ;
%wait E_0x7fbaa1005110;
%load/vec4 v0x7fbaa1017af0_0;
%wait E_0x7fef0a604540;
%load/vec4 v0x7fef0a515c80_0;
%cmpi/e 0, 0, 1;
%jmp/0xz T_1.0, 4;
%pushi/vec4 0, 0, 1;
%assign/vec4 v0x7fbaa1017c80_0, 0;
%pushi/vec4 0, 0, 16;
%assign/vec4 v0x7fef0a604760_0, 0;
%jmp T_1.1;
T_1.0 ;
%load/vec4 v0x7fbaa10179c0_0;
%load/vec4 v0x7fef0a515b20_0;
%flag_set/vec4 8;
%jmp/0xz T_1.2, 8;
%pushi/vec4 1, 0, 1;
%assign/vec4 v0x7fbaa1017c80_0, 0;
%pushi/vec4 0, 0, 16;
%assign/vec4 v0x7fef0a604760_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;
%load/vec4 v0x7fef0a515da0_0;
%flag_set/vec4 8;
%jmp/0xz T_1.4, 8;
%pushi/vec4 0, 0, 1;
%assign/vec4 v0x7fbaa1017c80_0, 0;
%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 ;
%load/vec4 v0x7fbaa1017c80_0;
%assign/vec4 v0x7fbaa1017c80_0, 0;
%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_0x7fbaa1007ac0;
.scope S_0x7fef0a6042d0;
T_2 ;
%wait E_0x7fbaa1005110;
%load/vec4 v0x7fbaa1017af0_0;
%wait E_0x7fef0a604540;
%load/vec4 v0x7fef0a515c80_0;
%cmpi/e 0, 0, 1;
%jmp/0xz T_2.0, 4;
%pushi/vec4 0, 0, 16;
%assign/vec4 v0x7fbaa10069a0_0, 0;
%pushi/vec4 0, 0, 4;
%assign/vec4 v0x7fef0a515e40_0, 0;
%jmp T_2.1;
T_2.0 ;
%load/vec4 v0x7fbaa1017c80_0;
%load/vec4 v0x7fef0a515b20_0;
%flag_set/vec4 8;
%jmp/0xz T_2.2, 8;
%load/vec4 v0x7fbaa10069a0_0;
%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.4, 4;
%pushi/vec4 0, 0, 16;
%assign/vec4 v0x7fbaa10069a0_0, 0;
%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 ;
%load/vec4 v0x7fbaa10069a0_0;
%addi 1, 0, 16;
%assign/vec4 v0x7fbaa10069a0_0, 0;
%pushi/vec4 0, 0, 4;
%assign/vec4 v0x7fef0a515e40_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;
.scope S_0x7fef0a6042d0;
T_3 ;
%wait E_0x7fbaa1005110;
%load/vec4 v0x7fbaa1017af0_0;
%wait E_0x7fef0a604540;
%load/vec4 v0x7fef0a515c80_0;
%cmpi/e 0, 0, 1;
%jmp/0xz T_3.0, 4;
%pushi/vec4 0, 0, 4;
%assign/vec4 v0x7fbaa1017d20_0, 0;
%pushi/vec4 1, 0, 1;
%assign/vec4 v0x7fef0a515fa0_0, 0;
%jmp T_3.1;
T_3.0 ;
%load/vec4 v0x7fbaa1017c80_0;
%load/vec4 v0x7fef0a515da0_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;
%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 ;
%load/vec4 v0x7fbaa1017d20_0;
%assign/vec4 v0x7fbaa1017d20_0, 0;
%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 0, 0, 4;
%assign/vec4 v0x7fbaa1017d20_0, 0;
%pushi/vec4 1, 0, 1;
%assign/vec4 v0x7fef0a515fa0_0, 0;
T_3.3 ;
T_3.1 ;
%jmp T_3;

Loading…
Cancel
Save