相关推荐recommended
数码管移位循环显示数字verilog代码ego1开发板
作者:mmseoamin日期:2024-02-04

名称:数码管移位循环显示数字verilog代码ego1开发板

软件:VIVADO

语言:Verilog

代码功能:

采用EGO1中的两组数码管,让该8个数码管循环显示:01234567,12345678,23456789....

电路的输入信号en进行启动或暂停;用按键控制循环,按一下显示下一组数。

FPGA代码Verilog/VHDL代码资源下载:www.hdlcode.com

本代码已在ego1开发板验证,开发板如下,其他开发板可以修改管脚适配:

数码管移位循环显示数字verilog代码ego1开发板,ego1开发板.png,第1张

代码下载:数码管移位循环显示数字verilog代码ego1开发板名称:数码管移位循环显示数字verilog代码ego1开发板(代码在文末下载)软件:VIVADO语言:Verilog代码功能:采用EGO1中的两组数码管,让该8个数码管循环显示:01234567,12345678,23456789....电路的输入信号en进行启动或暂停;用按键控制循环,按一下显示下一组数。FPGA代码Verilog/VHDL代码资源下载:www.hdlcode.com本代码已在e数码管移位循环显示数字verilog代码ego1开发板,icon-default.png?t=N7T8,第2张http://www.hdlcode.com/index.php?m=home&c=View&a=index&aid=312

1. 工程文件

数码管移位循环显示数字verilog代码ego1开发板,第3张

2. 程序文件

数码管移位循环显示数字verilog代码ego1开发板,第4张

3. 程序编译

数码管移位循环显示数字verilog代码ego1开发板,第5张

4. RTL图

数码管移位循环显示数字verilog代码ego1开发板,第6张

5. 管脚分配

数码管移位循环显示数字verilog代码ego1开发板,第7张

6. Testbench

数码管移位循环显示数字verilog代码ego1开发板,第8张

7. 仿真图

整体仿真图

数码管移位循环显示数字verilog代码ego1开发板,第9张

按键消抖模块

数码管移位循环显示数字verilog代码ego1开发板,第10张

显示模块

数码管移位循环显示数字verilog代码ego1开发板,第11张

部分代码展示:

module Numeric_Display(
input clk,//标准时钟,100MHz
input reset,//复位信号,低有效 
input SW_en,//使能
input shift_key_p,//移位
output reg [7:0] segment_strobe_1,
output reg [3:0] bit_strobe_1,  //高电平点亮,高电平选通
output reg [7:0] segment_strobe_2,
output reg [3:0] bit_strobe_2//高电平点亮,高电平选通
);
reg [39:0] data_in;//输入8位数据
   always @(posedge clk or negedge reset)  
   if(reset==0)
         data_in<=40'h0123456789;
   else if(SW_en==1)begin//使能
      if (shift_key_p)//按下移位
         data_in<={data_in[35:0],data_in[39:36]};//移位
   end
   reg [15:0] counter=16'd0;   
   always @(posedge clk)     
      begin
         if (counter == 16'hffff)
            counter <= 16'h0000;
         else
            counter <= counter + 1;//计数
      end
      
reg [3:0] display_data_1; 
reg [3:0] display_data_2; 
//数码管1位选控制
   always @(posedge clk)
      case (counter[15:14])
         2'd0 : begin
            display_data_1 <= data_in[31:28];
            bit_strobe_1 <=4'b1000;
            end
         2'd1 :begin
            display_data_1 <= data_in[27:24];
            bit_strobe_1 <=4'b0100;
            end
         2'd2 :begin
            display_data_1 <= data_in[23:20];
            bit_strobe_1 <=4'b0010;       
            end
         2'd3 :begin
            display_data_1 <= data_in[19:16];
            bit_strobe_1 <=4'b0001;            
            end
      endcase