当前位置: 首页 > news >正文

西安公司企业网站建设wordpress手机动漫主题

西安公司企业网站建设,wordpress手机动漫主题,前端企业网站开发,网站电子备案4、UART接收器 UART接收器负责接收串行比特流#xff0c;去除起始位和停止位#xff0c;并以并行格式将数据保存到与主机数据总线相连的寄存器里。接收器无法获得发送时钟#xff0c;因此尽管数据以标准比特率到达#xff0c;但数据未必与接收主机内的时钟同步。同步问题可…4、UART接收器 UART接收器负责接收串行比特流去除起始位和停止位并以并行格式将数据保存到与主机数据总线相连的寄存器里。接收器无法获得发送时钟因此尽管数据以标准比特率到达但数据未必与接收主机内的时钟同步。同步问题可以用同步器等方法解决数据的采集可以使用一个更高频率的本地时钟进行采样。为保证采样是在比特时间的中间进行应对Sample_clock时钟周期进行计数如下图所示。采样方法必须保证1能够检测到起始位到达2能够采样到8个数据位3能够把采样数据送到本地总线。 虽然可以采用更高的采样频率但本例中Sample_clock的频率定为已知发送时钟频率的8倍。这可以保证Sample_clock前沿与起始位之间的少许差异不会影响采样因为只需在起始位对应的比特时间之内采样完成即可。具体来说就是当串行输入被采样为低电平后表示起始位到来而后将再进行三次采样增加可信度在此后的连续数据位都将在比特时间的中间附近被采样即控制两次采样间隔时间是比特时间这是通过数据通路中的计数器来实现的。 下图给出了接收器的内部框图包括控制单元和数据通路可以看到其中控制单元和主机之间的接口信号已经控制单元和数据通路之间的控制信号与状态信号。 控制单元的输入信号及其作用 read_not_ready_in表示主机未准备好接收。 Ser_in_0当Serial_in 0时有效是由数据通路提供的状态信号。 SC_eq_3当Sample_counter 3时有效是由数据通路提供的状态信号。 BC_er_8当Sample_count 7时有效是由数据通路提供的状态信号。 Sample_counter对两次采样间隔进行计数。 Bit_counter计数已采样的数据位数。 控制单元的输出信号及其作用 read_not_ready_out表示接收机已接收到8位数据。 clr_Sample_counter控制数据通路的Sample_counter计数器清零。 inc_Sample_counter控制数据通路的Sample_counter计数值加1。 clr_Bit_counter控制数据通路的Bit_counters计数器清零。 inc_Bit_counter控制数据通路的Bit_counters计数值加1。 shift控制数据通路的RCV_shftreg向LSB方向移位。 load控制数据通路的RCV_shftreg数据传送到RCV_datareg。 Error1最后一个数据位采样结束后主机还没有准备好接收数据时有效。 Error2停止位丢失时有效。 接收器控制器状态机ASMD如下图所示。该状态机包括idle、starting和receiving三个状态。状态之间的转移由Sample_clk来同步。低有效的同步复位输入rst_b使状态机进入idle状态直到状态信号Ser_in_0变为高电平串行输入为0后状态机进入starting状态。在starting状态下状态机重复采样Serial_in以确认是否是有效起始位。在Sample_clock的下一个有效沿clr_Sample_counter和inc_Sample_counter需根据采样值确认是增加计数值还是清零若接下来的连续三次采样值均为0则认定为有效起始位状态机转移到receiving状态并将给出clr_Sample_counter信号控制Sample_counter清零。在receiving状态下inc_Sample_counter将控制Sample_counter计数值增加以进行8个时钟周期的计时对每个有效比特在其比特时间的中间采样总共采样7位数据位1位校验位Bit_counter增加。若采样的不是校验位则inc_Bit_counter和shift持续有效。信号shift有效时串行输入将载入接收器的移位寄存器RCV_shftreg的MSB位且寄存器最左边的7位将向LSB方向移动。 module UART_RCVR #(parameter word_size 8, half_word word_size / 2)(output [word_size - 1 : 0]RCV_datareg,output read_not_ready_out,Error1, Error2,input Serial_in,read_not_ready_in,Sample_clk,rst_b );wire Ser_in_0, SC_eq_3, SC_lt_7, BC_eq_8,clr_Sample_counter, inc_Sample_counter,clr_Bit_counter, inc_Bit_counter,shift, load;Control_Unit M0(read_not_ready_out, Error1, Error2, clr_Sample_counter,inc_Sample_counter, clr_Bit_counter, inc_Bit_counter,shift, load, read_not_ready_in, Ser_in_0, SC_er_3,SC_lt_7, BC_er_8, Sample_clk, rst_b);Datapath_Unit M1(RCV_datareg, Ser_in_0, SC_eq_3, SC_lt_7, BC_eq_8, Serial_in,clr_Sample_counter, inc_Sample_counter, clr_Bit_counter,inc_Bit_counter, shift, load, Sample_clk, rst_b);endmodulemodule Control_Unit #(parameter word_size 8, half_word word_size / 2,Num_state_bits 2)(output reg read_not_ready_out,Error1, Error2, clr_Sample_counter,inc_Sample_counter, clr_Bit_counter, inc_Bit_counter,shift, loadinput read_not_ready_in, Ser_in_0, SC_er_3,SC_lt_7, BC_er_8, Sample_clk, rst_b );localparam idle 2b00,starting 2b01,receiving 2b10;reg [word_size - 1 : 0] RCV_shftreg;reg [Num_state_bits - 1 : 0] state, next_state;always(posedge Sample_clk)if(rst_b 0)state idle;elsestate next_state;always(*)beginread_not_ready_out 0;clr_Sample_counter 0;clr_Bit_counter 0;inc_Sample_counter 0;inc_Bit_counter 0;shift 0;Error1 0;Error2 0;load 0;next_state idle;case(state)idle: if(Ser_in_0 1)next_state starting;elsenext_state idle;starting: if(Ser_in_0 0)beginnext_state idle;clr_Sample_counter 1;endelse if(SC_eq_3 1)beginnext_state receiving;clr_Sample_counter 1;endelse beginnext_state starting;inc_Sample_counter 1; endreceiving: if(SC_lt_7 1)begininc_Sample_conter 1;next_state receiving;endelse beginclr_Sample_counter 1;if(!BC_eq_8)beginnext_state receiving; shift 1;inc_Bit_counter 1; endelse beginnext_state idle;read_not_ready_out 1;clr_Bit_counter 1;if(read_not_ready_in 1) Error1 1;else if(Ser_in_0 1)Error2 1;elseLoad 1;endenddefault: next_state idle;endcase end endmodulemodule Datapath_Unit #(parameter word_size 8, half_word word_size / 2,Num_counter_bits 4)(output reg [word_size - 1 : 0] RCV_datareg,output Ser_in_0,SC_eq_3, SC_lt_7, BC_eq_8,input Serial_in, clr_Sample_counter, inc_Sample_counter, clr_Bit_counter,inc_Bit_counter, shift, load, Sample_clk, rst_b );reg [word_size - 1 : 0] RCV_shftreg;reg [Num_counter_bits - 1 : 0] Sample_counter;reg [Number_counter_bits : 0] Bit_counter;assign Ser_in_0 (Serial_in 0);assign BC_eq_8 (Bit_counter word_size);assign SC_lt_7 (Sample_counter word_size - 1);assign SC_eq_3 (Sample_counter half_word - 1);always(posedge Sample_clk)if(rst_b 0)beginSample_counter 0;Bit_counter 0;RCV_datareg 0;RCV_shftreg 0;endelse beginif(clr_Sample_counter 1)Sample_counter 0;else if(inc_Sample_counter 1)Sample_counter Sample_counter 1;if(clr_Bit_counter 1)Bit_counter Bit_counter;else if(inc_Bit_counter 1)Bit_counter Bit_counter 1;if(shift 1)RCV_shftreg {Serial_in, RCV_shftreg[word_size - 1 : 1]};else if(load 1)RCV_datareg RCV_shftreg;end endmodule 以上内容来源于《Verilog HDL高级数字设计》有删改
http://www.pierceye.com/news/693718/

相关文章:

  • 给个网站做导航违法吗游戏推广员每天做什么
  • 交互式网站开发技术全国企业信用公示信息公示网官网
  • 大连网站设计公司排名班级优化大师的功能有哪些
  • 旅游网站建设的概念ppt模板自己制作
  • 重庆网站建设首选承越网站开发建设方案
  • 创建一个网站的费用网站服务器租用报价
  • 潍坊企化网站建设大型免费网站制作
  • 松原网站制作网页制作的基本步骤流程
  • 太原网站建设制作机构西安网络seo公司
  • 移动网站建设报价表抖音代运营商
  • 镇平县两学一做网站服装网站建设推荐
  • 苏州建网站的公wordpress添加侧栏广告
  • 企业商城网站 .networdpress模板作者怎样去除
  • 强生网站还要怎样做衡水网站推广的网络公司
  • 茂名建站公司南通长城建设集团有限公司网站
  • 网络平台怎么建立网站吗做暧暧视频网站安全吗
  • 免费域名x网站网站前期准备工作
  • 陕西网站建设公司排名智能优化网站
  • 做瞹瞹网站萍乡做网站的公司有哪些
  • 网站建设的类型有几种wordpress搜索返回页面内容
  • 建设网站备案与不备案区别招远建网站首选公司
  • 四川住房和城乡建设厅网站三类人员软文网站备案如何查询
  • 个人与企业签订网站开发合同网页制作教程实例
  • 做网站遇到竞争对手怎么办wordpress中文版邮件发送
  • 美橙互联旗下网站渐变网站
  • 做网站域名需要在哪里备案微信答题小程序
  • 购物网站页面布局个人站长做导航网站
  • wordpress 增强编辑器网站暂时关闭 seo
  • 重庆网站设计开发培训广西省住房和城乡建设厅官网
  • 购物网站模板免费下载网站排名快速提升工具