|
本帖最后由 whlove1314 于 2016-5-27 16:13 編輯
我的讀程序?yàn)槭裁锤粢幻腼@示一次,這一秒顯示正常,下一秒就讀到8個(gè)一(就是0x80),再下一秒就正常,然后又是8個(gè)一,搞了一早上了,現(xiàn)在都懷疑芯片壞了如果說(shuō)程序有問(wèn)題,那什么還能讀到數(shù)據(jù),若說(shuō)沒(méi)問(wèn)題,為什么隔一秒無(wú)效一次
我現(xiàn)在觀察到的現(xiàn)象是,正常顯示時(shí),數(shù)據(jù)輸出穩(wěn)定(每次讀IO口數(shù)據(jù)一致,比如說(shuō),0s-1s期間程序多次讀IO,每次數(shù)據(jù)都是0s)不正常時(shí)(8個(gè)一..)程序每讀一次IO得到的數(shù)據(jù)都會(huì)從8個(gè)一跳變到8個(gè)0,非常奇怪
后來(lái)我在主函數(shù)只寫(xiě)了一個(gè)讀取函數(shù),去掉其他干擾項(xiàng),用8個(gè)LED連接到P0口顯示讀到的BCD碼,在讀取程序后加了10ms循環(huán)延遲,發(fā)現(xiàn)不正常顯示時(shí),IO口讀到數(shù)據(jù)會(huì)在8個(gè)1和8個(gè)0之間循環(huán)跳變,讀一次變一次就是(0000 0001{此為正常顯示,值為1}然后{1111 1111,0000 0000,1111 1111,0000 0000.....}一直這樣循環(huán),循環(huán)時(shí)間為1s)到了下一秒顯示正常0000 0011(此值為3)但是中間丟失了一秒,那一秒剛才在那里亂蹦
我自己的理解是在:程序每個(gè)機(jī)器周期都會(huì)去讀取ds1302的IO口,IO口的值在1s內(nèi)應(yīng)該是不變的,雖然多次讀取,但是每次的值一樣,機(jī)器周期非常短暫,人是無(wú)法察覺(jué)到的,給人的感覺(jué)就是數(shù)據(jù)是連續(xù)輸出的(其實(shí)實(shí)在一遍一遍掃描的),每次寫(xiě)入的地址都是一樣的,讀到的值只跟ds1302有關(guān),出現(xiàn)這個(gè)問(wèn)題我實(shí)在找不到跟程序有關(guān)的地方,
所以,現(xiàn)在懵逼了......
剛才有點(diǎn)新發(fā)現(xiàn),每次在亂蹦時(shí),上一秒的數(shù)值不動(dòng),剛才延遲太短沒(méi)看清,現(xiàn)在加大延遲,就看見(jiàn)了,比如說(shuō)上秒顯示(0000 0011)這一秒就是
(0000 0011,1111 1111,0000 0011,1111 1111.......)一直這樣蹦,直到下一秒恢復(fù)正常,來(lái)位大神救命啊.....
|
|