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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3254|回復: 0
收起左側

基于fpga的串口收發代碼(工業環境下)

[復制鏈接]
ID:223626 發表于 2017-7-31 17:35 | 顯示全部樓層 |閱讀模式
以下是串口發送部分
module xiaoze_tx(
                 input  clk,
                                          
                                          input  rst_n,
                                          
                                          input  send_en,
                                          
                                          input [3:0] bps_set,
                                          
                                          input [7:0] data_in,
                                          
                                          
                                          output reg tx_done,
                                          
                                          output reg data_out,
                                          
                                          output reg tx_state,
                                          
                                          
                                         //************************測試******************
                                          output reg  bps_clk,
                 output reg [3:0] shift
                                          );
                                          
        //************************************
       
reg  bps_clk;

reg [3:0] shift;

reg [15:0] bps;

reg [15:0] bps_cnt;

reg [7:0] data_in_a;

reg [7:0] data_in_b;
               
               
               
        //************************************
               
               
        always@(posedge clk  or  negedge rst_n)
       
          if(!rst_n)  bps <= 16'd 5207; //默認值為9600
       
     else begin
            case(bps_set)
                   4'd 0 : bps <= 16'd 5207; //9600
                       
                   4'd 1 : bps <= 16'd 2603; //19200
                       
              4'd 2 : bps <= 16'd 1301; //38400
                       
                   4'd 3 : bps <= 16'd 867;  //57600
                       
              4'd 4 : bps <= 16'd 433;  //115200
                       
                   default : bps <= 16'd 5207;  //默認值為9600
                 endcase
   end
          
          
//******************************************


   always@(posedge clk  or  negedge rst_n)

     if(!rst_n) bps_cnt <= 16'd 0;
       
     else if(tx_state == 1'b 1)  bps_cnt <= (bps_cnt == bps)? 16'd 0 : bps_cnt + 1'd 1;
         
          else   bps_cnt <= 16'd 0;
          
          
//*******************************************


   always@(posedge clk  or  negedge rst_n)

     if(!rst_n)  bps_clk <= 1'b 0;

     else if(bps_cnt == 16'd 1)  bps_clk <= 1'b 1;

     else  bps_clk = 1'b 0;
         
         
//*******************************************
       

   always@(posedge clk  or  negedge rst_n)
       
     if(!rst_n)  shift <= 4'd 0;
       
     else if(tx_done == 1'b 1) shift <=  4'd 0;
       
     else if(bps_clk == 1'b 1)  shift <= shift + 1'd 1;

          else  shift <= shift;
          
          
//*******************************************

   always@(posedge clk  or  negedge rst_n)
          
          if(!rst_n) begin
            data_in_a <= 8'b 0;
       data_in_b <= 8'b 0;
     end
          
          
          else begin
            data_in_a <= data_in;          
              data_in_b <= data_in_a;
          end
          
//*********************************************

  always@(posedge clk  or  negedge rst_n)
          
          if(!rst_n)  data_out <= 1'b 1; //rx默認為高電平
          
          else begin
            case(shift)
                   4'd 0 :  data_out <= 1'b 1;//默認值
                       
                   4'd 1 :  data_out <= 1'b 0; //起始位
                       
                   4'd 2 :  data_out <= data_in_b[0];
                       
              4'd 3 :  data_out <= data_in_b[1];
                       
              4'd 4 :  data_out <= data_in_b[2];
                       
              4'd 5 :  data_out <= data_in_b[3];
                       
                   4'd 6 :  data_out <= data_in_b[4];
                       
              4'd 7 :  data_out <= data_in_b[5];
                       
              4'd 8 :  data_out <= data_in_b[6];
                       
              4'd 9 :  data_out <= data_in_b[7];
                       
                   4'd 10 :  data_out <= 1'b 1;//停止位
                       
              4'd 11 :  data_out <= 1'b 1;//默認值
                       
                        default : data_out <= 1'b 1;//默認值
                endcase
        end
       
       
//*********************************************
       
always@(posedge clk  or  negedge rst_n)

  if(!rst_n)  tx_done <= 1'b 0;

  else if(shift == 4'd 11)  tx_done <= 1'b 1;

  else  tx_done <= 1'b 0;

//**********************************************

always@(posedge clk  or  negedge rst_n)

  if(!rst_n)  tx_state <= 1'b 0;

  else if(send_en == 1'b 1)  tx_state <= 1'b 1;

  else if(tx_done == 1'b 1)  tx_state <= 1'b 0;

  else  tx_state <= tx_state;


  endmodule   
//以下是串口接收部分
module xiaoze_rx(
                 input  clk,
                                          
                                          input  rst_n,
                                          
                                          input  data_in,
                                          
                                          input [2:0] bps,
                                          
                                          
                                          output reg rx_stop,
                                          
                                          output reg rx_state,
                                          
                                          output reg [7:0] data_out
                 );
                                          
//**********************數據定義區**************************

              reg [8:0] bps_set;
                                  
                                  reg  data_a;
                                  
                                  reg  data_b;
                                  
                                  reg  data_c;
                                  
                                  reg  data_d;
                                  
                                  wire  nedge;
                                  
                                  reg [8:0] cnt;
                                  
                                  reg  bps_clk;
                                  
                                  reg [7:0] shift;
                                 
                                  reg [2:0] data_read [7:0];
                                 
                                  reg [2:0] data_start;
                                  
                                  reg [2:0] data_stop;
                                 
                                  reg  start_n;   

//*********************************************************  

//波特率設置模塊

   always@(posedge clk  or  negedge rst_n)
       
          if(!rst_n)  bps_set <= 9'd 324;

          else begin
            case(bps)
                   3'd 0 : bps_set<= 9'd 324;  //9600
                       
                        3'd 1 : bps_set<= 9'd 162;  //19200
                       
                        3'd 2 : bps_set<= 9'd 80;   //38400
                          
                        3'd 3 : bps_set<= 9'd 53;   //57600
                       
                        3'd 4 : bps_set<= 9'd 26;   //115200
            endcase
     end
          
//************************************************************

//消除亞穩態

    always@(posedge clk  or  negedge rst_n)
         
          if(!rst_n) begin
            data_a <= 1'b 0;
                 data_b <= 1'b 0;
          end
          
          else begin
            data_a <= data_in;
            data_b <= data_a;
          end
         
//****************************************************************

//接收啟動模塊

   always@(posedge clk  or  negedge rst_n)
         
          if(!rst_n) begin
            data_c <= 1'b 0;
                 data_d <= 1'b 0;
          end
          
          else begin
            data_c <= data_b;
                 data_d <= data_c;
          end
         
//******************************************************************

//分頻計數模塊

   always@(posedge clk  or  negedge rst_n)
         
          if(!rst_n)  cnt <= 9'd 0;
          
          else if(rx_state) cnt <= (cnt == bps_set)?  9'd 0 : cnt + 1'd 1;
          
          else  cnt <= 9'd 0;

//******************************************************************

//波特率時鐘模塊

   always@(posedge clk  or  negedge rst_n)
         
          if(!rst_n)  bps_clk <= 1'b 0;

     else if(cnt == bps_set)  bps_clk <= 1'b 1;

     else bps_clk <= 1'b 0;

//******************************************************************

//移位計數模塊


   always@(posedge clk  or  negedge rst_n)
         
         if(!rst_n)  shift <= 8'd 0;
         
         else if(rx_stop)  shift <= 8'd 0;
       
    else if(bps_clk)  shift <= shift + 1'd 1;
       
    else  shift <= shift;

//*******************************************************************

//傳送完成標志位設置,如果起始位接收失敗也要清零

   always@(posedge clk  or  negedge rst_n)
         
         if(!rst_n)  rx_stop <= 1'b 0;
       
    else if(shift == 9'd 159  || (shift == 9'd 11 && data_read[0][2])) rx_stop <= 1'b 1;

    else  rx_stop <= 1'b 0;

//*********************************************************************
           
//數據讀取模塊

   always@(posedge clk  or  negedge rst_n)

   if(!rst_n) begin
       
         data_start <= 3'd 0;
       
         data_read[0] <= 3'd 0;
          
         data_read[1] <= 3'd 0;
          
         data_read[2] <= 3'd 0;
          
         data_read[3] <= 3'd 0;
          
         data_read[4] <= 3'd 0;
          
         data_read[5] <= 3'd 0;
          
         data_read[6] <= 3'd 0;
          
         data_read[7] <= 3'd 0;
          
          data_stop <= 3'd 0;
        end
       
        else if(bps_clk)  begin  // *else if (bps_clk)
          case(shift)
            0 : begin
                   data_start <= 3'd 0;
       
              data_read[0] <= 3'd 0;
          
         data_read[1] <= 3'd 0;

         data_read[2] <= 3'd 0;

         data_read[3] <= 3'd 0;

         data_read[4] <= 3'd 0;

         data_read[5] <= 3'd 0;

         data_read[6] <= 3'd 0;

         data_read[7] <= 3'd 0;

         data_stop <= 3'd 0;
                 end
              5,6,7,8,9,10 : data_start <= data_start + data_b;
                       
                        21,22,23,24,25,26 : data_read [0] <= data_read [0] + data_b;
                       
                        37,38,39,40,41,42 : data_read [1] <= data_read [1] + data_b;
                       
                        53,54,55,56,57,58 : data_read [2] <= data_read [2] + data_b;
                       
                        69,70,71,72,73,74 : data_read [3] <= data_read [3] + data_b;
                       
                        85,86,87,88,89,90 : data_read [4] <= data_read [4] + data_b;
                       
                        102,103,104,105,106,107 : data_read [5] <= data_read [5] + data_b;
                       
                        117,118,119,120,121,122 : data_read [6] <= data_read [6] + data_b;
                       
                        133,134,135,136,137,138 : data_read [7] <= data_read [7] + data_b;
                       
                        149,150,151,152,153,154 : data_stop<= data_stop + data_b;
     endcase
   end
       
//************************************************************************

//數據校準模塊

   always@(posedge clk  or  negedge rst_n)

     if(!rst_n)  data_out <= 8'd 0;
         
          else if (shift == 8'd 159) begin
       data_out[0] <=data_read[0][2];
            
       data_out[1] <=data_read[1][2];
            
            data_out[2] <=data_read[2][2];
            
       data_out[3] <=data_read[3][2];
            
       data_out[4] <=data_read[4][2];
            
       data_out[5] <=data_read[5][2];
            
            data_out[6] <=data_read[6][2];
            
       data_out[7] <=data_read[7][2];
         end
         
//*************************************************************************

//狀態位設置模塊

   always@(posedge clk  or  negedge rst_n)

   if(!rst_n) rx_state <= 1'b 0;

   else if(nedge && shift < 8'd 5)  rx_state <= 1'b 1;
       
        else if(rx_stop)   rx_state <= 1'b 0;

        else  rx_state <= rx_state;


//*************************************************************************   

            
assign nedge = (data_d  && (!data_c));


endmodule   
          
            
            
            
          
          

       


          
          

回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 欧美a∨| 狠狠操婷婷 | 午夜电影网| 欧美猛交| 影视先锋av资源噜噜 | 别c我啊嗯国产av一毛片 | 精品视频一区二区 | 色综合激情| 狠狠躁夜夜躁人人爽天天高潮 | 欧美色人| 伊人无码高清 | 伊人影院在线观看 | 福利电影在线 | 一道本不卡视频 | 精品国产乱码久久久久久久久 | 久久国内精品 | 亚洲一区二区三区免费视频 | 国产成人免费 | 久久男人| 欧美a在线 | 精品国产乱码久久久久久影片 | 国产精品欧美一区二区 | 精品欧美色视频网站在线观看 | 亚洲精品久久久久久久久久久久久 | 99久久免费精品国产男女高不卡 | 国产精品一区二区精品 | 手机看片1 | 午夜在线小视频 | 国产欧美日韩综合精品一区二区 | 日韩精品免费播放 | 超碰国产在线 | 日韩国产黄色片 | 亚洲码欧美码一区二区三区 | 日韩欧美在线一区 | 欧美成人黄色小说 | 日本激情视频中文字幕 | 日韩在线视频一区二区三区 | 爱高潮www亚洲精品 中文字幕免费视频 | 亚洲高清视频在线 | av免费入口| 国产四虎 |