【FPGA开发技巧】Modelsim仿真中,显示状态机的名称,而非编码数字

示例

被仿真的文件名为:cmd_handle.v,其中有r_st_current和r_st_next两个状态机变量。

该模块在tb文件中,被例化的名称为cmd_handle_u0

按照如下格式写:cmd_handle_u0.r_st_current

示例tb文件:

c 复制代码
`timescale 1ns / 1ps
//
// Company: 
// Engineer: 
// 
// Create Date: 2025/04/10 21:54:40
// Design Name: 
// Module Name: tb_cmd_handle
// Project Name: 
// Target Devices: 
// Tool Versions: 
// Description: 
// 
// Dependencies: 
// 
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
// 
//


module tb_cmd_handle();
cmd_handle #(
    .P_SYSTEM_CLK (50_000_000   ),   //输入时钟频率
    .P_BAUD_RATA  (115200       ),   //波特率    
    .P_DATA_WIDTH (8            ),   //Uart数据位宽
    .P_STOP_WIDTH (1            ),   //停止位位宽 1 or 2
    .P_CHECK      (2            )    //0为奇校验,1为偶校验    
)cmd_handle_u0
(
    .i_clk           (clk   ),
    .i_rst           (rst   ),
    
    .i_uart_rx       (w_uart_tx),
    .o_uart_tx       (w_uart_rx),
    
    .o_start_gain    (),
    .o_gain_speed    ()
);

//--------------------------------------------------------------------------
//--    状态机名称查看器
//--------------------------------------------------------------------------
//1个ASSIC码字符宽度是8位,例如"IDLE"有4个字符则需要32位宽
//80宽度可以容纳10个字符
	reg [79:0]              r_st_next          ;
    reg [79:0]              r_st_current          ;
	
//这段参数声明是一定要有的,否则在仿真时会报未声明变量的错误,如下图
localparam  P_ST_IDLE  = 0 ,
            P_ST_READ  = 1 ,
            P_ST_HEAD  = 2 ,
            P_ST_READ2 = 3 ,
            P_ST_A     = 4 ,
            P_ST_DATA  = 5 ,
            P_ST_ANYS  = 6 ;
			
	always @(*) begin
		case(cmd_handle_u0.r_st_current)
			P_ST_IDLE :     r_st_current = "P_ST_IDLE " ;
			P_ST_READ :     r_st_current = "P_ST_READ ";
			P_ST_HEAD :     r_st_current = "P_ST_HEAD ";
			P_ST_READ2:     r_st_current = "P_ST_READ2";
			P_ST_A    :	    r_st_current = "P_ST_A    ";
			P_ST_DATA :     r_st_current = "P_ST_DATA ";
			P_ST_ANYS :     r_st_current = "P_ST_ANYS ";
			default:r_st_current = "P_ST_IDLE ";
		endcase
	end

	always @(*) begin
		case(cmd_handle_u0.r_st_next)
			P_ST_IDLE :     r_st_next = "P_ST_IDLE " ;
			P_ST_READ :     r_st_next = "P_ST_READ ";
			P_ST_HEAD :     r_st_next = "P_ST_HEAD ";
			P_ST_READ2:     r_st_next = "P_ST_READ2";
			P_ST_A    :	    r_st_next = "P_ST_A    ";
			P_ST_DATA :     r_st_next = "P_ST_DATA ";
			P_ST_ANYS :     r_st_next = "P_ST_ANYS ";
			default:        r_st_next = "P_ST_IDLE ";
		endcase
	end

endmodule

直接运行仿真,就可以:

相关推荐
云雾J视界9 小时前
FPGA在AI时代的角色重塑:硬件可重构性与异构计算的完美结合
fpga开发·边缘计算·gpu·vitis·ai推理·azure云·异构编程
s09071361 天前
FPGA中CIC设计注意事项
算法·fpga开发·cic滤波器
Aaron15881 天前
RFSOC+VU13P在无线信道模拟中的技术应用分析
数据结构·人工智能·算法·fpga开发·硬件架构·硬件工程·射频工程
碎碎思1 天前
BerkeleyLab Bedrock:为 FPGA 与加速计算打造的开源基石
fpga开发·开源
zidan14121 天前
xilinx常用文档说明
fpga开发
ShiMetaPi1 天前
GM-3568JHF丨ARM+FPGA异构开发板系列教程:外设教程 04 WIFI
网络·arm开发·fpga开发·智能路由器·fpga
FPGA_小田老师1 天前
FPGA基础知识(二十):Xilinx Block Memory IP核(5)--ROM 详解
fpga开发·rom·coe文件格式·导入coe·block memory
FPGA_无线通信1 天前
压缩解压缩算法 BFP-8bit
fpga开发
红糖果仁沙琪玛1 天前
AD7616驱动开发-FPGA
驱动开发·fpga开发
坏孩子的诺亚方舟1 天前
FPGA系统架构设计实践13_FPGA系统功能安全
fpga开发·系统架构·功能安全概念