搜索
bottom↓
回复: 2

为何下面verilog中变量bps_start_r被赋值为1'bz?

[复制链接]

出0入0汤圆

发表于 2012-11-1 16:53:20 | 显示全部楼层 |阅读模式
为何下面verilog中变量bps_start_r被赋值为1'bz?赋值为1'bz 有什么意义?
//--------------------------------------------------------------------------------------
module my_uart_tx(clk,rst_n,clk_bps,rx_data,rx_int,rs232_tx,bps_start);
input clk;    // 50MHz主时钟
input rst_n;  //低电平复位信号
input clk_bps;       // clk_bps的高电平为接收或者发送数据位的中间采样点
input[7:0] rx_data;  //接收数据寄存器
input rx_int;     //接收数据中断信号,接收到数据期间始终为高电平,在次利用它的下降沿来启动发送数据
output rs232_tx;  // RS232发送数据信号
output bps_start; //接收或者要发送数据,波特率时钟启动信号置位
//---------------------------------------------------------
reg rx_int0,rx_int1,rx_int2;    //rx_int信号寄存器,捕捉下降沿滤波用
wire neg_rx_int;  // rx_int下降沿标志位
always @ (posedge clk or negedge rst_n) begin
    if(!rst_n) begin
           rx_int0 <= 1'b0;
           rx_int1 <= 1'b0;
           rx_int2 <= 1'b0;
       end
    else begin
           rx_int0 <= rx_int;
           rx_int1 <= rx_int0;
           rx_int2 <= rx_int1;
       end
end
assign neg_rx_int =  ~rx_int1 & rx_int2;  //捕捉到下降沿后,neg_rx_int拉地保持一个主时钟周期

//---------------------------------------------------------
reg[7:0] tx_data; //待发送数据的寄存器
//---------------------------------------------------------
reg bps_start_r;
reg tx_en; //发送数据使能信号,高有效
reg[3:0] num;

always @ (posedge clk or negedge rst_n) begin
    if(!rst_n) begin
           bps_start_r <= 1'bz;
           tx_en <= 1'b0;
           tx_data <= 8'd0;
       end
    else if(neg_rx_int) begin   //接收数据完毕,准备把接收到的数据发回去
           bps_start_r <= 1'b1;
           tx_data <= rx_data;  //把接收到的数据存入发送数据寄存器
           tx_en <= 1'b1;       //进入发送数据状态中
       end
    else if(num==4'd11) begin   //数据发送完成,复位
           bps_start_r <= 1'bz;
           tx_en <= 1'b0;
       end
end
assign bps_start = bps_start_r;
//---------------------------------------------------------
reg rs232_tx_r;

always @ (posedge clk or negedge rst_n) begin
    if(!rst_n) begin
           num <= 4'd0;
           rs232_tx_r <= 1'b1;
       end
    else if(tx_en) begin
           if(clk_bps)   begin
                  num <= num+1'b1;
                  case (num)
                     4'd0:  rs232_tx_r <= 1'b0; //发送起始位
                     4'd1:  rs232_tx_r <= tx_data[0];   //发送bit0
                     4'd2:  rs232_tx_r <= tx_data[1];   //发送bit1
                     4'd3: rs232_tx_r <= tx_data[2]; //发送bit2
                     4'd4: rs232_tx_r <= tx_data[3]; //发送bit3
                     4'd5: rs232_tx_r <= tx_data[4]; //发送bit4
                     4'd6: rs232_tx_r <= tx_data[5]; //发送bit5
                     4'd7:  rs232_tx_r <= tx_data[6];   //发送bit6
                     4'd8: rs232_tx_r <= tx_data[7]; //发送bit7
                     4'd9: rs232_tx_r <= 1'b0;   //发送结束位
                      default: rs232_tx_r <= 1'b1;
                     endcase
              end
           else if(num==4'd11) num <= 4'd0;   //复位
       end
end
assign rs232_tx = rs232_tx_r;
endmodule

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2012-11-1 17:28:02 | 显示全部楼层
赋值为1'bz表示引脚为高阻,可用于输入.

出0入0汤圆

 楼主| 发表于 2012-11-16 17:40:59 | 显示全部楼层
thank you   
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 07:10

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表