熱門(mén): 51單片機(jī) | 24小時(shí)必答區(qū) | 單片機(jī)教程 | 單片機(jī)DIY制作 | STM32 | Cortex M3 | 模數(shù)電子 | 電子DIY制作 | 音響/功放 | 拆機(jī)樂(lè)園 | Arduino | 嵌入式OS | 程序設(shè)計(jì)
|
發(fā)布時(shí)間: 2020-12-25 09:16
正文摘要:本帖最后由 不吃魚(yú)的貓2012 于 2021-1-12 13:05 編輯 采用MAX813來(lái)代替復(fù)位電路(未單獨(dú)采用復(fù)位電路),在while(1)大循環(huán)中喂狗,設(shè)備上電、調(diào)試、現(xiàn)場(chǎng)運(yùn)行均正常,但是不定期有幾臺(tái)出現(xiàn)程序跑飛的現(xiàn)象,感覺(jué)就 ... |
不吃魚(yú)的貓2012 發(fā)表于 2021-1-12 13:04 樓主的程序?qū)懙糜悬c(diǎn)繁雜,嵌套有點(diǎn)深。全局變量滿天飛,也沒(méi)有注釋,看得眼花繚亂。感覺(jué)是兩路18B20組成的多點(diǎn)溫度監(jiān)控報(bào)警電路。按常理這點(diǎn)功能有其一半的代碼量就夠了。樓主懷疑MAX813看門(mén)狗不能復(fù)位這很容易判斷。沒(méi)有示波器用萬(wàn)用表也能根據(jù)平均電壓判斷喂狗脈沖和復(fù)位脈沖的存在。程序中也沒(méi)有看出《最近發(fā)現(xiàn)一次是在不停按按鈕時(shí)出現(xiàn)過(guò)一次類似現(xiàn)象》的按鈕在哪。操控出問(wèn)題也不一定是程序跑飛。數(shù)據(jù)類型使用不當(dāng)也是常見(jiàn)因素。振動(dòng)環(huán)境也有可能使按鈕觸點(diǎn)不穩(wěn)定。不知樓主實(shí)際電路采用哪個(gè)型號(hào)MCU。STC的芯片內(nèi)置看門(mén)狗和EEPROM,EEPROM保存運(yùn)行數(shù)據(jù),測(cè)試過(guò)程中人為引發(fā)看門(mén)狗復(fù)位,如果不是做了標(biāo)記,直觀感覺(jué)不到熱復(fù)位重啟過(guò)程。 |
| 我最近發(fā)現(xiàn)過(guò)一次:是在不停按按鈕時(shí)出現(xiàn)類似現(xiàn)象,重啟設(shè)備又正常了,請(qǐng)問(wèn)是什么原因早成的? |
|
您的意思是放在初始化函數(shù)的最后一句(中斷初始化后面)嗎?void INIT_main() { //P0=0xff; P1=0xff; //JBTZ_moto(); INIT_BJmoto(); second=second_30=count=second_300=BJ_count=count_clk=second_clk=an_count=second_1=beep=0; FBAN_flag=CLAN_flag=BJ_flag=flag_sh=flag_hw=power_flag=JR_flag=DW_flag=GW_flag=JR_GZ_flag=0; EA=1; ET0=1; ET1=1; TR0=1; TR1=0; TMOD=0x11; TH0=(65536-50000)/256; TL0=(65536-50000)%256; TH1=(65536-250)/256; TL1=(65536-250)%256; JBTZ_moto(); } 我現(xiàn)在直接把這句話刪掉了,還是會(huì)出現(xiàn)這個(gè)問(wèn)題, |
| 會(huì)不會(huì)是數(shù)碼管掃描引起混亂? |
glinfei 發(fā)表于 2020-12-28 14:26 關(guān)鍵有故障的時(shí)候才能看到,有時(shí)候幾天都沒(méi)有故障,偶爾有一個(gè)出現(xiàn)這種現(xiàn)象。100個(gè)里面過(guò)幾天偶爾有1個(gè)出現(xiàn)這種問(wèn)題,只要出過(guò)這種問(wèn)題的,重啟正常后,連續(xù)運(yùn)行10天都沒(méi)有問(wèn)題。 |
不吃魚(yú)的貓2012 發(fā)表于 2020-12-28 12:56 總之,我的意思程序跑飛跟變量的值有關(guān),雖然程序反復(fù)不能喂狗而復(fù)位,但初始化沒(méi)做好,變量的值一直處于無(wú)法執(zhí)行下去的狀態(tài),導(dǎo)致反復(fù)的復(fù)位,建議觀察一下RST,估計(jì)一直在復(fù)位。但如果冷啟動(dòng)就清了變量,進(jìn)而就正常了。如果我說(shuō)的對(duì),那PCB板還是少改吧,多麻煩啊。 |
不吃魚(yú)的貓2012 發(fā)表于 2020-12-28 12:56 就是放到初始化的最后,也不行嗎? 我建議你重點(diǎn)考慮一下,復(fù)位與冷啟動(dòng)對(duì)變量的差異。另外,1、用狗的時(shí)候,時(shí)間中斷應(yīng)該先賦值再開(kāi)中斷;2、T1時(shí)間太短吧? |
glinfei 發(fā)表于 2020-12-28 11:40 放在初始化函數(shù)的最后一句嗎? |
麥麥123 發(fā)表于 2020-12-28 12:51 麻煩標(biāo)注一下 |
| 我感覺(jué)是中斷程序出問(wèn)題了 |
本帖最后由 不吃魚(yú)的貓2012 于 2020-12-28 12:17 編輯 glinfei 發(fā)表于 2020-12-28 11:40 您的意思是放在初始化函數(shù)的最后一句(中斷初始化后面)嗎?void INIT_main() { //P0=0xff; P1=0xff; //JBTZ_moto(); INIT_BJmoto(); second=second_30=count=second_300=BJ_count=count_clk=second_clk=an_count=second_1=beep=0; FBAN_flag=CLAN_flag=BJ_flag=flag_sh=flag_hw=power_flag=JR_flag=DW_flag=GW_flag=JR_GZ_flag=0; EA=1; ET0=1; ET1=1; TR0=1; TR1=0; TMOD=0x11; TH0=(65536-50000)/256; TL0=(65536-50000)%256; TH1=(65536-250)/256; TL1=(65536-250)%256; JBTZ_moto(); } |
|
能否把JBTZ_moto() ,放到最后一句?因?yàn)槟闶菬釂?dòng),又有太多全局變量,放太靠前了,復(fù)位后變量都有值的,這應(yīng)該導(dǎo)致顯示亂碼。 void INIT_main() { P0=0xff; P1=0xff; JBTZ_moto(); INIT_BJmoto(); |
| 參與人數(shù) 1 | 黑幣 +20 | 收起 理由 |
|---|---|---|
|
| + 20 | 回帖助人的獎(jiǎng)勵(lì)! |
glinfei 發(fā)表于 2020-12-25 15:07 程序已經(jīng)上傳到附件,麻煩幫我看看呢? |
anli88 發(fā)表于 2020-12-28 10:04 程序已經(jīng)貼在附件,麻煩幫我看看呢? |
| 你的程序有沒(méi)有沒(méi)寫(xiě)錯(cuò)呢? |
|
本帖最后由 不吃魚(yú)的貓2012 于 2020-12-28 09:20 編輯 程序已經(jīng)貼出來(lái)了,麻煩看看那里有毛病,我最近發(fā)現(xiàn)我的PCB板上繼電器離晶振太近,會(huì)不會(huì)是這個(gè)原因造成的? |
2.87 KB, 下載次數(shù): 17
|
本帖最后由 不吃魚(yú)的貓2012 于 2020-12-28 09:28 編輯 會(huì)不會(huì)是因?yàn)閿?shù)碼管時(shí)間太長(zhǎng),引起中斷沖突,我吧數(shù)碼管驅(qū)動(dòng)由原來(lái)的74HC573改成MAX7219會(huì)不會(huì)好一點(diǎn)呢? |
| 會(huì)不會(huì)中斷的時(shí)候跑飛了,那就回不到喂狗那句了,要不把程序多貼一點(diǎn)? |
| 參與人數(shù) 1 | 黑幣 +20 | 收起 理由 |
|---|---|---|
|
| + 20 | 回帖助人的獎(jiǎng)勵(lì)! |
| 頂一下 |
Powered by 單片機(jī)教程網(wǎng)