新聞中心

EEPW首頁(yè) > EDA/PCB > 設(shè)計(jì)應(yīng)用 > 1-Wire總線與DS18B20應(yīng)用仿真

1-Wire總線與DS18B20應(yīng)用仿真

作者: 時(shí)間:2008-06-19 來源:今日電子 收藏

  總線的基本通信協(xié)議

本文引用地址:http://2s4d.com/article/84508.htm

  作為一種單主機(jī)多從機(jī)的總線系統(tǒng),在一條總線上可掛接的從器件數(shù)量幾乎不受限制。為了不引起邏輯上的沖突,所有從器件的1- Wire總線接口都是漏極開路的,因此在使用時(shí)必須對(duì)總線外加上拉電阻(一般取5kΩ左右)。主機(jī)對(duì)總線的基本操作分為復(fù)位、讀和寫三種,其中所有的讀寫操作均為低位在前高位在后。復(fù)位、讀和寫是1-Wire總線通信的基礎(chǔ),下面通過具體程序詳細(xì)介紹這3種操作的時(shí)序要求。(程序中DQ代表1 -Wire總線,定義為P1.0,uchar定義為unsigned char)

  1 1-Wire總線的復(fù)位

  復(fù)位是1-Wire總線通信中最為重要的一種操作,在每次總線通信之前主機(jī)必須首先發(fā)送復(fù)位信號(hào)。如程序1.1所示,產(chǎn)生復(fù)位信號(hào)時(shí)主機(jī)首先將總線拉低480~960μs然后釋放,由于上拉電阻的存在,此時(shí)總線變?yōu)楦唠娖健?-Wire總線器件在接收到有效跳變的15~60μs內(nèi)會(huì)將總線拉低60~240μs,在此期間主機(jī)可以通過對(duì)DQ采樣來判斷是否有從器件掛接在當(dāng)前總線上。函數(shù)Reset()的返回值為0表示有器件掛接在總線上,返回值為1表示沒有器件掛接在總線上。

  程序1.1 總線復(fù)位

  uchar Reset(void)
  {
   uchar tdq;
   DQ=0;  //主機(jī)拉低總線
   delay480μs(); //等待480μs
   DQ=1; //主機(jī)釋放總線
   delay60μs();  //等待60μs
   tdq=DQ;  //主機(jī)對(duì)總線采樣
   delay480μs();  //等待復(fù)位結(jié)束
   return tdq;  //返回采樣值
  }

  2 1-Wire總線的寫操作

  由于只有一條I/O線,主機(jī)1-Wire總線的寫操作只能逐位進(jìn)行,連續(xù)寫8次即可寫入總線一個(gè)字節(jié)。如程序1.2所示,當(dāng)MCS-51單片機(jī)的時(shí)鐘頻率為12MHz時(shí),程序中的語(yǔ)句_nop_();可以產(chǎn)生1μs的延時(shí),調(diào)用此函數(shù)時(shí)需包含頭文件“intrins.h”。向1-Wire總線寫1bit至少需要60μs,同時(shí)還要保證兩次連續(xù)的寫操作有1μs以上的間隔。若待寫位wbit為0則主機(jī)拉低總線60μs然后釋放,寫0操作完成。若待寫位wbit為1,則主機(jī)拉低總線并在1~15μs內(nèi)釋放,然后等待60μs,寫1操作完成。

  程序1.2 向總線寫1bit

  void Writebit(uchar wbit)
  {
   _nop_();
  //保證兩次寫操作間隔1μs以上
   DQ=0;
   _nop_();
  //保證主機(jī)拉低總線1μs以上
   if(wbit)
   {            
  //向總線寫1
   DQ=1;
  delay60μs();
   }
   else
   {            
  //向總線寫0
   delay60μs();
   DQ=1;
   }
  }

  3 1-Wire總線的讀操作

  與寫操作類似,主機(jī)對(duì)1-Wire總線的讀操作也只能逐位進(jìn)行,連續(xù)讀8次,即可讀入主機(jī)一個(gè)字節(jié)。從1-Wire總線讀取1bit同樣至少需要60μs,同時(shí)也要保證兩次連續(xù)的讀操作間隔1μs以上。如程序1.3所示,從總線讀數(shù)據(jù)時(shí),主機(jī)首先拉低總線1μs以上然后釋放,在釋放總線后的 1~15μs內(nèi)主機(jī)對(duì)總線的采樣值即為讀取到的數(shù)據(jù)。

  程序1.3 從總線讀1bit

  uchar Readbit()
  {
   uchar tdq;
   _nop_();
  //保證兩次連續(xù)寫操作間隔1μs以上
   DQ=0;
   _nop_(); 
  //保證拉低總線的時(shí)間不少于1μs
   DQ=1;
   _nop_();
   tdq=DQ; 
  //主機(jī)對(duì)總線采樣
   delay60μs();
  //等待讀操作結(jié)束
   return tdq;
  //返回讀取到的數(shù)據(jù)
  }

  數(shù)字溫度DS18B20


上一頁(yè) 1 2 3 下一頁(yè)

關(guān)鍵詞: 仿真 1-Wire 傳感器

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉