本帖最后由 q247341184 于 2017-8-23 20:40 编辑
基于原子哥的dht11例程修改代码,经测试没有错误和异常。移植数码管显示模块后也无异常,当在主函数读取温度模块后加入显示函数后,数据读取出现异常。无法正确读数,是指的从传感器传出来的数据是错的,用XCOM监控,用printf函数取值得到,具体如下面主函数部分。一开始推测是管脚冲突,经仔细检查后,排除管脚冲突原因。两个部分独立运行时是完好的,也排除代码异常问题。望指点一下思路, 还有什么原因可能导致这种情况的发生?
主函数的运行部分:
[mw_shl_code=c,true]
while(1)
{
if(t%10==0) //每100ms读取一次
{
DHT22_Read_Data(&temperature,&humidity); //读取温湿度值
printf("temp=%d!",temperature); //显示温度
printf("humidi=%d!",humidity); //显示湿度
DisPlayNum(temperature); //加入此行后数据读取异常
}
delay_ms(200);
t++;
} [/mw_shl_code]
显示函数:
[mw_shl_code=c,true]void DisPlayNum(int n)
{
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE); //使能AFIO时钟
//由于PB4的功能就是GPIO,所以没有使能功能时钟
GPIO_PinRemapConfig(GPIO_Remap_SWJ_NoJTRST,ENABLE); //关闭JTRST,即开启重映射
for (i=0;i<4;i++)
{
GPIO_ResetBits(GPIOB,GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7| //PB4-PB7是位选口
GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11| //PB8-PB15是段选口
GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15 );
switch (i) //位选数,,分别对应左数1、2、3、4
{
case 0:
GPIO_SetBits(GPIOB,GPIO_Pin_7);
break;
case 1:
GPIO_SetBits(GPIOB,GPIO_Pin_6);
break;
case 2:
GPIO_SetBits(GPIOB,GPIO_Pin_5);
break;
case 3:
GPIO_SetBits(GPIOB,GPIO_Pin_4);
break;
}
switch (a%10) //输出示数
{
case 0:
GPIO_SetBits(GPIOB,GPIO_Pin_14|GPIO_Pin_15); // 0
break;
case 1:
GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15); // 1
break;
case 2:
GPIO_SetBits(GPIOB,GPIO_Pin_10|GPIO_Pin_13|GPIO_Pin_15); // 2
break;
case 3:
GPIO_SetBits(GPIOB,GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_15); // 3
break;
case 4:
GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_15); // 4
break;
case 5:
GPIO_SetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_12|GPIO_Pin_15); // 5
break;
case 6:
GPIO_SetBits(GPIOB,GPIO_Pin_9|GPIO_Pin_15); // 6
break;
case 7:
GPIO_SetBits(GPIOB,GPIO_Pin_11|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15); // 7
break;
case 8:
GPIO_SetBits(GPIOB,GPIO_Pin_15); // 8
break;
case 9:
GPIO_SetBits(GPIOB,GPIO_Pin_12|GPIO_Pin_15); // 9
break;
case 10:
GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11| //负号
GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_15 );
break;
case 11:
GPIO_SetBits(GPIOB,GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11| //null
GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15 );
break;
}
s = s / 10; //此行放输出逻辑。
delay_ms(1);
} [/mw_shl_code]
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
原子哥,我想分为三点继续这个问题;
1、我曾经试过仿真,没有得到该有的现象,正常的现象应该是主机发送一段1·10ms的低电平后拉高,然后传感器发出相应拉低80us再拉高以示即将传输数据。可是现实情况是主机周期性拉低至少18ms再拉高都没有响应。我个人分析出现这种现象应该是没有问题的,因为我认为软件仿真本身就无法连接传感器,所以周期性拉低电平再拉高是我目前认为的正常现象。
2、因为之前的时候我也认为有可能是时序问题,所以我做过一个可能不太靠谱的测试,就是将主函数代码中的Display函数替换成一个for循环的空循环,循环200000次,软件仿真时设置晶振是8MHz,折合时间约0.025秒,我认为足够长到干扰时序逻辑了。用for循环替换Display函数的现象是可以正常读数,没有问题。但是切换回Display函数就无法正确读数。
以上是我对这个问题做过的尝试和自己的理解,如果哪里有错误是我没有注意到的或者我理解错的等等,还请批评指正,指点思路。非常感谢。
以下是仿真测试的图:
一周热门 更多>