STM32微控制器综合实训10 基于CAN总线的超声波测距仪设计实验

实验10 基于CAN总线的超声波测距仪设计实验
利用CAN总线来实现数据的传送。

代码讲解(c8t6)

温度传感器ds18b20

DS18B20_Init

//初始化DS18B20的IO口 DQ 同时检测DS的存在  
//返回1:不存在  
//返回0:存在           
u8 DS18B20_Init(void)  
{
         
  GPIO_InitTypeDef  GPIO_InitStructure;              
  
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);     
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;               //PORTA.8 推挽输出      
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                  
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;      
  GPIO_Init(GPIOA, &GPIO_InitStructure);      
  
  GPIO_SetBits(GPIOA,GPIO_Pin_8);    //输出1 
       
  DS18B20_Rst();    
  
  return DS18B20_Check();  
  
}  

这段代码只有DS18B20_Rst和DS18B20_Check我们没有见到过,我们先对DS18B20_Rst go to definition

DS18B20_Rst

//复位DS18B20  
void DS18B20_Rst(void)       
{
                              
  GPIO_InitTypeDef  GPIO_InitStructure;      
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);       
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;               //PORTA.8 推挽输出      
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                  
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;      
  GPIO_Init(GPIOA, &GPIO_InitStructure);      
  
  GPIO_ResetBits(GPIOA,GPIO_Pin_8);    //输出0       
  delay_us(750);     //拉低750us       
  GPIO_SetBits(GPIOA,GPIO_Pin_8); //输出1      
  delay_us(15);       //15us  
}  

由程序可知,PA8先拉低750us,再拉高15us,为什么这样做?

答:看ds18b20的数据手册知道:
在这里插入图片描述
控制器发送400960us低+1560us高形式的脉冲后,ds18b20会再返回一个60-240us的脉冲。

函数DS18B20_Rst()作用是使控制器发送750us低+15us高形式的脉冲,来初始化DS18B20时序。

那用怎么判断ds18b20返回的脉冲是不是60-240us呢?
对DS18B20_Check go to definition

DS18B20_Check

//等待DS18B20的回应  
//返回1:未检测到DS18B20的存在  
//返回0:存在  
u8 DS18B20_Check(void)       
{
            
  u8 retry=0;      
  GPIO_InitTypeDef  GPIO_InitStructure;      
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);     
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;               //PORTA.8 上拉输入      
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;       //上拉输入        
  GPIO_Init(GPIOA, &GPIO_InitStructure);
        
  while (DS18B20_DQ_IN && retry<200)    
  {
              
    retry++;          
    delay_us(1);      
  };         
  if(retry>=200)//等待200us,还不拉低      
  {
             
    return 1;//直接返回错误      
   }      
  else retry=0;//能进到else,表示ds18b20已经有反应,电平变低      
  while (!DS18B20_DQ_IN && retry<240)      
  {
             
    retry++;          
    delay_us(1);      
  };      
  if(retry>=240)return 1;           
  return 0;  
}

DS18B20_DQ_IN && retry<200表示在ds18b20还没相应,即DS18B20_DQ_IN为1,且未相应时间<200us时,就一直等待ds18b20相应,如果到200us时ds18b20还没有相应,就直接返回错误。

!DS18B20_DQ_IN && retry<240,表示ds18b20有反应时,DS18B20_DQ_IN为0,则!DS18B20_DQ_IN为1,且响应时间不超过240us,返回相应成功,但如果相应时间超过了240us,也直接返回错误。

DS18B20_Get_Temp

//从ds18b20得到温度值  
//精度:0.1C  
//返回值:温度值 (-550~1250)   
short DS18B20_Get_Temp(void)  
{
         
  u8 temp;      
  u8 TL,TH;        
  short tem;      
  DS18B20_Start ();           // ds1820 start convert      
  DS18B20_Rst();      
  DS18B20_Check();           
  DS18B20_Write_Byte(0xcc);   // skip rom      
  DS18B20_Write_Byte(0xbe);   // convert          
  TL=DS18B20_Read_Byte();   
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DS18B20是单总线数字传感器,共有6种信号类型:复位脉冲、应答脉冲、写0、写1、读0和读1。所有这些信号,除了应答脉冲以外,都由主机发出同步信号。并且发送所有的命令和数据都是字节的低位在前。 这几个信号的时序如下: 1)复位脉冲和应答脉冲 单总线上的所有通信都是以初始化序列开始。主机输出低电平,保持低电平时间至少480us,以产生复位脉冲。接着主机释放总线,4.7K的上拉电阻将单总线拉高,延时15~60us,并进入接收模式(Rx)。接着DS18B20拉低总线60~240us,以产生低电平应答脉冲,若为低电平,再延时480us。 2)写时序 写时序包括写0时序和写1时序。所有写时序至少需要60us,且在2次独立的写时序之间至少需要1us的恢复时间,两种写时序均起始于主机拉低总线。写1时序:主机输出低电平,延时2us,然后释放总线,延时60us。写0时序:主机输出低电平,延时60us,然后释放总线,延时2us。 3)读时序 单总线器件仅在主机发出读时序时,才向主机传输数据,所以,在主机发出读数据命令后,必须马上产生读时序,以便从机能够传输数据。所有读时序至少需要60us,且在2次独立的读时序之间至少需要1us的恢复时间。每个读时序都由主机发起,至少拉低总线1us。主机在读时序期间必须释放总线,并且在时序起始后的15us之内采样总线状态。典型的读时序过程为:主机输出低电平延时2us,然后主机转入输入模式延时12us,然后读取单总线当前的电平,然后延时50us。 DS18B20的温度读取过程一般为:复位->发SKIPROM命令(0XCC)->发开始转换命令(0X44)->延时->复位->发送SKIPROM命令(0XCC)->发读存储器命令(0XBE)->连续读出两个字节数据(即温度)->结束。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值