找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 3112|回復(fù): 5
打印 上一主題 下一主題
收起左側(cè)

關(guān)于DS18B20搜索ROM問題

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:417092 發(fā)表于 2021-9-4 05:56 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
求助,DS18B20搜索ROM問題
因?yàn)椴粫?huì)畫流程圖。。。。。。
想一步,寫一步。寫到最后自己也不清楚哪里出了問題。。。。。

4個(gè)DS18B20搜索ROM分別為
28A0A0A0...........................
28B0B0B0...........................
28C0C0C0...........................
28D0D0D0...........................


搜索結(jié)果。。沒找到28B0B0B0搜出2個(gè)2828A0A0A0



  1. bit search_rom(uchar (*prom)[8])
  2. {
  3.         bit ask=0, end=0;
  4.         uchar i=0,j=0, k=0, buff[8]={0};
  5.         uchar _ROM_x=0, _00bit=0, high=0xff, low=0xff;
  6.         loop:
  7.         ask=init_18b20();
  8.         while(ask)
  9.         {
  10.                 ask=init_18b20();
  11.         }
  12.         write_18b20_byte(0xf0);
  13.         for(i=0; i<8; i++)
  14.         {
  15.                 for(j=0; j<8; j++)
  16.                 {
  17.                         k=0;
  18.                   k|=read_bit();
  19.                         k<<=1;
  20.                         k|=read_bit();
  21.                   switch(k)
  22.                   {
  23.                                 case 0: if(8*i+j<low) low=8*i+j;
  24.                                                                 if(8*i+j==high)
  25.                                                                 {
  26.                                                                         high=_00bit;
  27.                                                                         buff[i]>>=1; buff[i]|=0x80; write_bit(1);
  28.                                                                 }
  29.                                                                 else
  30.                                                                 {
  31.                                                                         _00bit=8*i+j;
  32.                                                                         buff[i]>>=1; write_bit(0);
  33.                                                                 }
  34.                                                                 break;
  35.                                 case 1:        buff[i]>>=1; write_bit(0); break;
  36.                                 case 2: buff[i]>>=1; buff[i]|=0x80; write_bit(1); break;
  37.                                 case 3: if(i==0)  return 0;
  38.                   }
  39.                 }
  40.         }
  41.         for(i=0; i<8; i++)
  42.                 prom[_ROM_x][i]=buff[i];
  43.         _ROM_x++;
  44.         if(end && high==low)
  45.                 return 1;
  46.         if(high==0)
  47.                 end = 1;
  48.         high = _00bit;
  49.         goto loop;

  50. }
復(fù)制代碼

ds18b20.rar (824 Bytes, 下載次數(shù): 13)

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:213173 發(fā)表于 2021-9-4 06:32 | 只看該作者
仿真單個(gè)ds18b20可以用默ROM,仿真多個(gè)ds18b20總線連接要編輯不同ROM。



回復(fù)

使用道具 舉報(bào)

板凳
ID:417092 發(fā)表于 2021-9-4 06:39 | 只看該作者
wulin 發(fā)表于 2021-9-4 06:32
仿真單個(gè)ds18b20可以用默ROM,仿真多個(gè)ds18b20總線連接要編輯不同ROM。

不是我要的答案
回復(fù)

使用道具 舉報(bào)

地板
ID:417092 發(fā)表于 2021-9-4 19:39 | 只看該作者


苦逼 的自己,手動(dòng)搜索了一遍。。。
雖然找到了。。。問題。但是如果修改,函數(shù)結(jié)構(gòu)大變。。。
修改還不如,重寫。。。。。
這就是不 畫流程圖的結(jié)果。。。。。。。

可是我東一 榔頭,西一棒槌自學(xué)的編程。。。不會(huì)畫流程圖呀!。。。!
如何學(xué)畫流程圖呀!!
回復(fù)

使用道具 舉報(bào)

5#
ID:417092 發(fā)表于 2021-9-5 02:32 | 只看該作者


感覺修改麻煩,想重寫。。。
寫了一會(huì)。。。發(fā)現(xiàn)思路更亂。。。。
還是修改原函數(shù)。。。。。
函數(shù)被修改的面目全非,慘不忍睹。。。。
但是功能終于實(shí)現(xiàn)了。。。。。
改天,把代碼精簡一下,寫下注釋再和大家分享。。。
回復(fù)

使用道具 舉報(bào)

6#
ID:417092 發(fā)表于 2021-9-6 23:57 | 只看該作者
  1. bit search_rom(uchar (*prom)[8])
  2. {
  3.         bit ask=0, end=0;
  4.         uchar i=0,j=0, k=0, buff[8]={0};
  5.         uchar _ROM_x=0, _00bit=0, high=0xff, low=0xff;
  6.         loop:
  7.         ask=init_18b20();
  8.         while(ask)
  9.         {
  10.                 ask=init_18b20();
  11.         }
  12.         write_18b20_byte(0xf0);
  13.         for(i=0; i<8; i++)
  14.         {
  15.                 for(j=0; j<8; j++)
  16.                 {
  17.                         k=0;
  18.                   k|=read_bit();
  19.                         k<<=1;
  20.                         k|=read_bit();
  21.                         if(k==0 && high!=8*i+j)
  22.                                 _00bit = 8*i+j;
  23.                         buff[i]>>=1;
  24.                         if(8*i+j>high || _ROM_x==0)
  25.                         {
  26.                                 switch(k)
  27.                                 {
  28.                                         case 0: if(8*i+j<low) low=8*i+j;  write_bit(0); break;
  29.                                         case 1:        write_bit(0); break;
  30.                                         case 2: buff[i]|=0x80; write_bit(1); break;
  31.                                         case 3: return 0;
  32.                                 }
  33.                         }
  34.                         else if(8*i+j == high)
  35.                         {
  36.                                 buff[i]|=0x80; write_bit(1);
  37.                                 high=_00bit;
  38.                         }
  39.                         else
  40.                         {
  41.                                         if((prom[_ROM_x-1][i])>>j&0x01)
  42.                                         {
  43.                                                 buff[i]|=0x80;
  44.                                                 write_bit(1);
  45.                                         }
  46.                                         else
  47.                                                 write_bit(0);
  48.                         }
  49.                 }
  50.         }
  51.         for(i=0; i<8; i++)
  52.                 prom[_ROM_x][i]=buff[i];
  53.         _ROM_x++;
  54.         if(end && high==low)
  55.                 return 1;
  56.         if(high==0)
  57.                 end = 1;
  58.         high = _00bit;
  59.         goto loop;
  60. }
復(fù)制代碼


苦逼的自學(xué)過程,
原函數(shù)被改得面目全非。。。。88行代碼

又用倆天時(shí)間 第一次精簡從88行變成60行。。。。
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表