第三节 FPGA驱动数码管

  1. 原理图

    今天不太开心。
    项目名称:GFPGA驱动数码管。
    材料:FPGA开发板、共阳极数码管。
    实验内容:使用FPGA驱动一个数码管每秒依次显示1~E,至于为啥不显示F,因为我懒的改了。
    电气原理图如下。
    开发板的6个数码管的原理图
    第三节 FPGA驱动数码管_第1张图片
    FPGA和数码管的段码的定义
    第三节 FPGA驱动数码管_第2张图片
    数码管0的各位的I/O定义
    第三节 FPGA驱动数码管_第3张图片

  2. 编辑器

    接下来建立工程、编写代码。因为quartus自带的编辑器非常垃圾,所以我进行配置了关联Notepad++。配置细节tool–> options–>preferred Text Editor如图。
    第三节 FPGA驱动数码管_第4张图片
    对于Command-line中引号的内容你可以直接选择…然后找到notepad++双击添加就行。下面是代码。

  3. 代码部分

module Nixie (LEDs ,Nixies,clk,rst);

output [7:0] LEDs;
output [6:0] Nixies;
input  clk,rst;

reg [26:0] cnt;

reg [6:0] NixieDisplay;

reg [7:0] GE;

parameter 
    segment0  = 8'd1,
    segment1  = 8'd2,
    segment2  = 8'd3,
    segment3  = 8'd4,
    segment4  = 8'd5,
    segment5  = 8'd6,
    segment6  = 8'd7,
    segment7  = 8'd8,
    segment8  = 8'd9,
    segment9  = 8'd10,
    segment10 = 8'd11,
    segment11  = 8'd12,
    segment12  = 8'd13,
    segment13  = 8'd14,
    segment14  = 8'd15,
    segment15  = 8'd16;


parameter 
    duan0  = 8'Hc0,
    duan1  = 8'HF9,
    duan2  = 8'HA4,
    duan3  = 8'HB0,
    duan4  = 8'H99,
    duan5  = 8'H92,
    duan6  = 8'H82,
    duan7  = 8'HF8,
    duan8  = 8'H80,
    duan9  = 8'H90,
    duan10 = 8'H88,
    duan11 = 8'H83,
    duan12 = 8'Hc6,
    duan13 = 8'Ha1,
    duan14 = 8'H86,
    duan15 = 8'H8e;


always @(posedge clk or negedge rst)
    begin 
        if(!rst) 
                begin
                    cnt = 0;

                    GE  = 0;
                end
        else 
            begin
                cnt = cnt + 27'b1;

                if(cnt >= 27'H2FAF080) 
                    begin 
                        cnt = 0;
                        GE = GE + 8'b1;
                        if(GE == 8'd16) GE = 0;
                    end 
            end 
    end

always @(posedge clk)
    begin
        case(GE)
            segment0:  NixieDisplay = duan0[6:0];
            segment1:  NixieDisplay = duan1[6:0];
            segment2:  NixieDisplay = duan2[6:0];
            segment3:  NixieDisplay = duan3[6:0];
            segment4:  NixieDisplay = duan4[6:0];
            segment5:  NixieDisplay = duan5[6:0];
            segment6:  NixieDisplay = duan6[6:0];
            segment7:  NixieDisplay = duan7[6:0];
            segment8:  NixieDisplay = duan8[6:0];
            segment9:  NixieDisplay = duan9[6:0];
            segment10: NixieDisplay = duan10[6:0];
            segment11: NixieDisplay = duan11[6:0];
            segment12: NixieDisplay = duan12[6:0];
            segment13: NixieDisplay = duan13[6:0];
            segment14: NixieDisplay = duan14[6:0];
            segment15: NixieDisplay = duan15[6:0];

            default:  NixieDisplay = duan0[6:0];
        endcase
    end

    assign Nixies = NixieDisplay;
    assign LEDs  = GE;

endmodule
烧录进FPGA即可看到数码管在一每秒更换一次的速度进行工作。当然我多加了几个LED来指示状态。代码解析下节继续。

你可能感兴趣的:(FPGA学习)