久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 522|回復: 2
打印 上一主題 下一主題
收起左側

VERILONG串口單秒發數據簡單實例

[復制鏈接]
跳轉到指定樓層
樓主
/*+++++++TOP++++++++++++*/

module uart_tx(
    input                wire            sclk,
        input                wire                  rst_n,
        output                reg         uart_tx
    );

parameter                  CLK_FREQ             =24000000;        //時鐘頻率50M
parameter                  UART_BAUD             = 115200;        //時鐘頻率50M
parameter                  MAX_BIT_COUNT         = 31;        //時鐘頻率50M
localparam                 MAX_BAUD_CNT         = CLK_FREQ / UART_BAUD;//434

reg [7:0] write_data;   //發送數據

//運行計數器
reg [31:0] run_cnt;        //波特率計數器
always @(posedge sclk or negedge rst_n)
begin
    if(rst_n == 1'b0)
        run_cnt <= 32'd0;
    else if(run_cnt == CLK_FREQ)
         run_cnt <= 0;
    else
        run_cnt <= run_cnt + 1;
end

//波特率計數器
reg [8:0] baud_cnt;        //波特率計數器
reg en_baud_cnt;        //波特率計數器開關
always @(posedge sclk or negedge rst_n)
begin
    if(rst_n == 1'b0)
        baud_cnt <= 8'd0;
    else if(en_baud_cnt == 1'b1) begin
        if(baud_cnt == MAX_BAUD_CNT)
            baud_cnt <= 8'd0;
        else
            baud_cnt <= baud_cnt + 1;
    end
    else
        baud_cnt <= baud_cnt;
end

//發送位計數器
reg [4:0] bit_cnt = 0;        //波特率計數器
always @(posedge sclk or negedge rst_n)
begin
    if(rst_n == 1'b0)
        bit_cnt <= 4'd0;
    else if(baud_cnt == MAX_BAUD_CNT)
        begin
            if(bit_cnt ==  MAX_BIT_COUNT)
                bit_cnt <= 4'd0;
            else
                bit_cnt <= bit_cnt + 1;
        end
    else
        bit_cnt <= bit_cnt;
end

//位發送邏輯
always @(posedge sclk or negedge rst_n)
begin
    if(rst_n == 1'b0)
        uart_tx <= 1'b0;
    else if(baud_cnt == MAX_BAUD_CNT/2)
        begin
            if(bit_cnt ==  0)
                uart_tx <= 1'b0;
            else if(bit_cnt == MAX_BIT_COUNT)
                uart_tx <= 1'b1;
            else
            begin
            case(bit_cnt)
                1:uart_tx <= write_data[0];
                2:uart_tx <= write_data[1];
                3:uart_tx <= write_data[2];
                4:uart_tx <= write_data[3];
                5:uart_tx <= write_data[4];
                6:uart_tx <= write_data[5];
                7:uart_tx <= write_data[6];
                8:uart_tx <= write_data[7];
                default:uart_tx <= uart_tx;
            endcase
            end
            //uart_tx <= write_data[bit_cnt-1];
        end
    else
        uart_tx <= uart_tx;
end

always @(posedge sclk or negedge rst_n)
begin
    if(rst_n == 1'b0)
        en_baud_cnt <= 1'b0;
    else if(run_cnt == 0) begin
        en_baud_cnt <= 1'b1;
    end
    else if(bit_cnt ==  MAX_BIT_COUNT && baud_cnt == MAX_BAUD_CNT)
        en_baud_cnt <= 1'b0;
    else
        en_baud_cnt <= en_baud_cnt;
end

always @(posedge sclk or negedge rst_n)
begin
    if(rst_n == 1'b0)
        write_data <= 8'd0;
    else if(run_cnt == 0)
        write_data <= write_data + 1;
    else
        write_data <= write_data;
end

endmodule






畫紅線的一個小問題,有沒有人幫我解釋一下?
寄存器是八位的最大數值255


但是
MAX_BAUD_CNT數值是434這個應該怎么理解?

IMG_20241224_212921.jpg (324.31 KB, 下載次數: 0)

IMG_20241224_212921.jpg
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:275826 發表于 2024-12-25 17:00 | 只看該作者
reg [8:0] baud_cnt;是9位
回復

使用道具 舉報

板凳
ID:285416 發表于 2024-12-26 18:32 來自觸屏版 | 只看該作者
對對對  我,low   真是一起語醒夢中人   謝謝
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产高清视频在线 | 久久麻豆精品 | 91黄在线观看 | 亚洲国产精品一区 | 久久久久中文字幕 | 中文字幕一二三区 | 99久久久无码国产精品 | 中文久久 | 一级黄色在线 | 国产成人福利视频 | 99亚洲精品 | 精品国产乱码久久久久久丨区2区 | 亚洲性爰 | 日本在线你懂的 | 99久久精品国产毛片 | 久久精品国产久精国产 | 在线视频亚洲 | 免费毛片网站在线观看 | 国产精彩视频在线观看 | 亚洲成人综合在线 | 国产激情视频 | 亚洲国产一区二区三区, | 免费日韩av网站 | 免费视频二区 | 亚洲精品久久久久久一区二区 | 欧美视频福利 | 资源首页二三区 | 精品欧美乱码久久久久久1区2区 | 国产亚洲精品久久yy50 | 亚洲视频在线一区 | 97精品超碰一区二区三区 | 亚洲一区二区高清 | 一区二区中文 | 色婷婷av777 av免费网站在线 | 日韩一区和二区 | 午夜精品一区二区三区在线观看 | 国产日韩欧美 | 亚洲免费观看视频 | 精品国产乱码久久久久久蜜柚 | 亚洲精品九九 | 九一精品|