当前位置:首页 > 单片机 > FPGA之旅
[导读]本篇是FPGA之旅设计的第十二例,在前面的例程中,完成了DS18B20温度传感器数据的采集,并且将采集到的数据显示在数码管上。由于本例将对温湿度传感器DHT11进行采集,而且两者的数据采集过程类似,所以可以参考一下前面的例程。本例将通过signal top实时采集波形,确定采集到的数据是正确了(数据中带了校验)。

一. 简介

本篇是FPGA之旅设计的第十二例,在前面的例程中,完成了DS18B20温度传感器数据的采集,并且将采集到的数据显示在数码管上。由于本例将对温湿度传感器DHT11进行采集,而且两者的数据采集过程类似,所以可以参考一下前面的例程。本例将通过signal top实时采集波形,确定采集到的数据是正确了(数据中带了校验)。


二. DHT11传感器简介

应用电路如下,和DS18B20一样,只需要一根数据线与FPGA进行通信。每次通信都是FPGA发起的,随后DHT11会输出40bit的数据给FPGA。温度测试范围为0-50℃,湿度测试范围为20-90%RH(相对湿度),简单了解一下即可。


三. 数据传输过程

数据传输一共包括三个部分

  • 开始采集 : FPGA拉低数据线,然后释放,等等DHT11响应

  • 数据采集 : 这部分一共需要传输40bit的数据,分别为(高到底) 8bit湿度整数位,8bit湿度小数位,8bit温度整数位,8bit温度小数位,8bit校验和。校验和 = 数据之和,通过这个可以判断接收到的数据是否正确。

  • 采集结束:从机拉低约50us后,主机拉低

官方图如下,下面详细说明一下各个部分。


1

开始采集

从图中可以看到,开始采集包括两个部分,主机和从机。主机先拉低总线18ms,然后拉高20-40us后释放总线,然后从机响应拉低总线80us后,拉高总线80us,就完成了。这里的拉低拉高时间都不是一个固定值,可以根据实际情况来决定。


2

数据传输

开始采集结束后,就是数据传输了,一根总线最关心的问题就是如何表示数据1和数据0了。


数据0表示如下

数据1表示如下


可以看到,无论是数据0还是数据1,总线拉低的时间都是一样的,所以在判断数据0和数据1,只需要根据高电平的持续时间即可。


3

采集结束

在从机拉低50us后,FPGA将总线拉高即可。


以上就是DHT11数据传输的全部内容,还是比较容易的哈。



四. 代码实现

(一). 状态机确定


通过上面的时序图,可以确定,采集过程可以大致分为六个阶段,其中请求部分可以分为FPGA请求和DHT11应答两个部分,具体如下。

localparam S_IDLE          = 'd0;  //空闲态localparam S_START_FPGA    =    'd1; //FPGA请求采集数据开始localparam S_START_DHT11   = 'd2;  //DHT11开始请求应答localparam S_DATA          =    'd3; //数据传输localparam S_STOP          = 'd4;  //数据结束localparam S_DOEN          =    'd5; //数据采集完成

(二). 计时周期数确定


在时序图中,提到了18ms,26-28us,20-40us,50us,70us,80us等等,但是经过分析后,并不需要定义这么多个计时周期数,只需要定义两个即可。为什么只定义这两个就可以了呢?


在时序图中,需要FPGA判断时间的,有两个位置,一个是FPGA拉低18ms以上,另外一个是判断数据表示是数据0还是数据1。第一个很清楚就是18ms。数据0表示的数据位26-28us,为了保险起见,这里设置为35us,如果高电平的持续时间低于35us,那么就表示数据0。

//时钟为50MHZ,20nslocalparam  TIME18ms = 'd1000_099;    //开始态的拉低18ms,900_000个时钟周期,这里适当的延长了拉低时间。localparam  TIME35us = 'd1_750; //数据传输过程中,数据0拉高的出现

在编写代码的时候,低电平是不需要处理的,只需要通过下降沿当前的传输状态即可。例如说在dht11响应的阶段,只需要判断是否产生了下降沿,至于其高电平和低电平各种持续了多长的时间,这个可以忽略。


(三). 状态转移编写


从状态转移条件可以看到,都是通过下降沿,和周期计数来作为条件进行转移的。

always@(*)begin case(state) S_IDLE: if(dht11_req == 1'b1) //数据采集请求过来进入开始态 next_state <= S_START_FPGA; else next_state <= S_IDLE; S_START_FPGA:  if((DHT11_Cnt >= TIME18ms) && dht11_negedge == 1'b1) //FPGA请求结束结束 next_state <= S_START_DHT11; else next_state <= S_START_FPGA; S_START_DHT11: if((DHT11_Cnt > TIME35us) && dht11_negedge == 1'b1) //延时一段时间后,通过判断dht11总线的下降沿,是否结束响应 next_state <= S_DATA; else next_state <= S_START_DHT11; S_DATA: if(DHT11Bit_Cnt == 'd39 && dht11_negedge == 1'b1) //接收到40bit数据后,进入停止态 next_state <= S_STOP; else next_state <= S_DATA; S_STOP: if(DHT11_Cnt == TIME35us + TIME35us) //数据传输完成后,等待总线拉低50us,这里是70us next_state <= S_DOEN; else next_state <= S_STOP; S_DOEN: next_state <= S_IDLE;  default: next_state <= S_IDLE; endcaseend


(四). 采集数据存储


根据手册的指示,先发送高位,后发送低位,按照条件来进行存储即可。

/*接收数据存储*/always@(posedge sys_clk or negedge rst_n)begin if(rst_n == 1'b0) dht11_data <= 'd0; else if(state == S_DATA) if((DHT11_Cnt <= TIME35us + 'd3000) && dht11_negedge == 1'b1) //'d3000为低电平时间(这个是有必要的),高电平持续时间低于35us认为是数据0 dht11_data <= {dht11_data[38:0],1'b0}; else if(dht11_negedge == 1'b1) dht11_data <= {dht11_data[38:0],1'b1}; else dht11_data <= dht11_data; else dht11_data <= dht11_data;end

最后通过signal tap获取到的数据如下。

计数校验和,2C + 02 + 1C + 06 = 50,可以知道数据采集正确。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭