簡單介紹一下I2C總線原理: IIC總線是PHLIPS公司推出的一種串行總線,是具備多主機(jī)系統(tǒng)所需的包括總線裁決和高低速器件同步功能的高性能串行總線。 IIC總線只有兩根雙向信號線。一根是數(shù)據(jù)線SDA,另一根是時鐘線SCL。(記住這個就夠了,其他都是廢話!) II C總線進(jìn)行數(shù)據(jù)傳送時,時鐘信號為高電平期間,數(shù)據(jù)線上的數(shù)據(jù)必須保持穩(wěn)定,只有在時鐘線上的信號為低電平期間,數(shù)據(jù)線上的高電平或低電平狀態(tài)才允許變化。
注意到IIC總線是需要接上拉電阻的!因為連到IIC總線的器件的輸出基本為開漏輸出.
起始和終止信號 :SCL線為高電平期間,SDA線由高電平向低電平的變化表示起始信號;SCL線為高電平期間,SDA線由低電平向高電平的變化表示終止信號。下圖一目了然。
1.001.jpg (10.33 KB, 下載次數(shù): 98)
下載附件
2017-6-19 22:18 上傳
數(shù)據(jù)傳送格式(1)字節(jié)傳送與應(yīng)答 每一個字節(jié)必須保證是8位長度。數(shù)據(jù)傳送時,先傳送最高位(MSB),每一個被傳送的字節(jié)后面都必須跟隨一位應(yīng)答位(即一幀共有9位)。如果一段時間內(nèi)沒有收到從機(jī)的應(yīng)答信號,則自動認(rèn)為從機(jī)已正確接收到數(shù)據(jù)。 對數(shù)據(jù)時進(jìn)行位操作,即來一個SCL始終高電平就寫入或者讀出一位數(shù)據(jù),這個一定要清楚!
1.002.jpg (16.57 KB, 下載次數(shù): 119)
下載附件
2017-6-19 22:18 上傳
下面介紹ATMEL公司的串行E2PROM產(chǎn)品——AT24C系列 AT24C01:128字節(jié)(128×8位); AT24C02:256字節(jié)(256×8位); AT24C04:512字節(jié)(512×8位)AT24C08:1K字節(jié)(1K×8位); AT24C16:2K字節(jié)(2K×8位);
本次實(shí)驗用的是AT24C02,所以存儲器的地址有256字節(jié)(在IIC總線尋址中讀取存儲器首地址時首地址的范圍為0~256,因為AT24C02的容量為256字節(jié))
下面是AT24C02的電路圖,注意到SDA和SCL均有連接10K的上拉電阻,本實(shí)驗中SDA接89C52的P2.0口,SCL接89C52的P2.1口。
1.003.jpg (13.96 KB, 下載次數(shù): 86)
下載附件
2017-6-19 22:18 上傳
AT24C02的芯片地址如下圖,1010為固定,A0,A1,A2正好與芯片的1,2,3引角對應(yīng),為當(dāng)前電路中的地址選擇線,三根線可選擇8個芯片同時連接在電路中,當(dāng)要與哪個芯片通信時傳送相應(yīng)的地址即可與該芯片建立連接,TX-1B實(shí)驗板上三根地址線都為0。最后一位R/W為告訴從機(jī)下一字節(jié)數(shù)據(jù)是要讀還是寫,0為寫入,1為讀出。
1.004.jpg (4.84 KB, 下載次數(shù): 82)
下載附件
2017-6-19 22:18 上傳
AT24C02的芯片地址(0xa0為寫,0xa1為讀)
任意地址寫入數(shù)據(jù)和任意地址讀取數(shù)據(jù)分別如下圖所示 讀取數(shù)據(jù):
1.005.jpg (12.92 KB, 下載次數(shù): 76)
下載附件
2017-6-19 22:18 上傳
注意,讀數(shù)據(jù)的時候也要先進(jìn)行寫操作,目的是寫入器件地址以尋找合適的器件,當(dāng)器件與地址匹配時,器件會發(fā)出一個應(yīng)答信號,這樣就可以讓單片機(jī)確定該讀哪個器件,這樣就可以開始讀取數(shù)據(jù)了.
寫入數(shù)據(jù):
1.006.jpg (13.24 KB, 下載次數(shù): 103)
下載附件
2017-6-19 22:18 上傳
下面是程序:
…………限于本文篇幅 余下代碼請從51黑下載附件…………
全部資料下載地址:
IIC時序講解.docx
(92.11 KB, 下載次數(shù): 27)
2017-6-19 17:29 上傳
點(diǎn)擊文件名下載附件
iic時序 下載積分: 黑幣 -5
|