『壹』 DS18B20初始化C語言程序,求解釋,越詳細越好
第一個程序是初始化DS18B20用的,是根據時序先置0後置1的過程,這個過程中延時時間內的精度很重要,需要容根據實際使用的硬體情況時行計算,置0需要保持480-960us;
第二個程序很少看到用,一般是計算時長,在過了相應的時間後直接去讀取數據,樓主程序使用循環255次的時間需要根據編譯後的匯編代碼來計算,請樓主行算一下;感覺樓主的這個程序採用不停檢測和循環的做法有些誇張。
樓主要深入了解這個程序,最好還是直接看MAXIM-IC.COM網站上DS18B20的相關資料,重點是時序圖和相關的命令流程圖,看懂了是很有幫助的。
『貳』 DS1302時鍾怎麼初始化時間
P1.2;令=0
DS_READ�SETBP1.2;令=0。
CLRP1.1;令SCLK=0。
CLRP1.2;令=1,啟動晶元。
LCALLDS_WSUB;寫8位地址。
LCALLDS_RSUB;讀出8位數據。
RET
DS_WSUB�MOVR7,#08H
WL00P�RRCA;A為地址位元組。
MOVP1.0,C
SETBP1.1;在時鍾上升沿
NOP;輸入地址位元組。
CLRP1.1
DJNZR7�WL00P
RET
DS_RSUB�SETBP1.0;為讀數據作準備。
MOVR7�#08H
RL00P:SETBP1.1
NOP
CLRP1.1;在第9個正脈沖的下
MOVC,P1.0;降沿開始輸出數據。
RRCA;A中為讀出的數據。
DJNZR7,RL00P
RET
若使用如下程序對DSl302的RAM1�其內容為5AH進行讀操作
READ:MOVA�#11000101B;RAM1單元的讀地址。
LCAllDS_READ;調用讀子程序。
則程序執行後A中的數據為2DH,顯然讀出的數據不正確。若再使用一條RLA指令調整後,則A中為5AH,結果才正確。由此說明:使用上述程序讀出的RAM1單元中的第0位數據實為第1位數據,讀出的第7位數據實為第0位數據。
經筆者仔細研究時序圖和多次試驗得知,問題的原因在於:對於讀操作時序,在SCLK出現第8個正脈沖時,上升沿輸入地址位元組的最後一位數據,而在此正脈沖的下降沿就要輸出數據位元組的第0位數據。然而筆者的程序中是在第9個正脈沖的下降沿才誤認為輸出了數據位元組的第0位數據,此位數據事實上是第二個下降沿輸出的,故實為數據位元組的第1位數據。經筆者實驗:只要RST保持為高電平,如果超過8個下降沿,它們將重新從第0位輸出數據位,因程序中輸出的最後一位數據位,是9個下降沿輸出的數據位,故實為數據位元組的第0位數據位。
由此可見,單位元組讀操作的時序圖如改為圖2所示時序圖,則讀者較容易理解可避免發生上述編程錯誤。
只要將上述的DS_RSUB子程序改為如下的子程序即可解決上述問題:
DS_RSUBl:SETBP1.0;為讀數據作準備
MOVR7,#08H
RL00P:CLRP1.1;SCLK第8個正脈沖的
MOVC,P1.0;下降沿開始輸出數據。
RAC
SETBP1.1
DJNZR7,RL00P
RET