不知道你是否有這樣的經(jīng)歷,測(cè)試的機(jī)器運(yùn)行半個(gè)月、一個(gè)月的都沒(méi)啥問(wèn)題,突然就死機(jī)了,或者運(yùn)行錯(cuò)誤了,總之莫名其妙。但是此時(shí),你的調(diào)試器已經(jīng)從機(jī)器上拔下來(lái)了,無(wú)法在線調(diào)試觀察死機(jī)后的現(xiàn)場(chǎng)了,你無(wú)法觀察到你的變量、寄存器、外設(shè)、堆、棧等處于什么情況,這個(gè)時(shí)候你不得不重新接上調(diào)試器,再次運(yùn)行程序以等待問(wèn)題的出現(xiàn)。這個(gè)笨方法存在幾個(gè)問(wèn)題:第一、因?yàn)閺?fù)現(xiàn)率太低,所以你的電腦必須一直連接電腦,否則問(wèn)題出現(xiàn)了無(wú)法確認(rèn)。第二,萬(wàn)一中途因?yàn)楦鞣N原因(線拔了,KEIL 意外退出了)導(dǎo)致調(diào)試器和機(jī)器的連接出現(xiàn)了問(wèn)題,那么只能重來(lái)了。第三,可能運(yùn)行幾個(gè)月都不會(huì)再出問(wèn)題,但是你卻知道,這里隱藏了一個(gè)炸彈,指不定什么時(shí)候就爆了;更有甚者,可能連接調(diào)試器后這個(gè)問(wèn)題可能就沒(méi)有了,但是斷開(kāi)之后就又有問(wèn)題了。
針對(duì)以上問(wèn)題,我們就會(huì)想,是否存在一種方法,能夠在出現(xiàn)問(wèn)題之后,可以使用調(diào)試器抓獲現(xiàn)場(chǎng)環(huán)境呢?我們都知道,KEIL 環(huán)境下,連接調(diào)試器后,單片機(jī)進(jìn)入調(diào)試模式時(shí),KEIL 會(huì)自動(dòng)將整個(gè)單片機(jī)進(jìn)行復(fù)位(可能是內(nèi)核復(fù)位,也可能是系統(tǒng)復(fù)位,也可能是 RST 引腳復(fù)位),復(fù)位操作對(duì)于剛下載的程序而言,可以很方便的幫助開(kāi)發(fā)者更方便的進(jìn)入調(diào)試環(huán)境,但是對(duì)于機(jī)器的問(wèn)題現(xiàn)場(chǎng)而言,這是在破獲現(xiàn)場(chǎng)!但是根據(jù)以往的認(rèn)知,我們總是以為進(jìn)入調(diào)試模式時(shí),必然需要先進(jìn)行單片機(jī)復(fù)位的,所以我們對(duì)這種難復(fù)現(xiàn)的 BUG 總是感到無(wú)能為力。
今天,魚(yú)鷹教大家一個(gè)方法,如何使用 KEIL 調(diào)試器抓獲 STM32 的 BUG 現(xiàn)場(chǎng)(其他單片機(jī)可自行測(cè)試),這個(gè)方法將顛覆你的認(rèn)知,可以在單片機(jī)運(yùn)行時(shí)進(jìn)入調(diào)試模式,從而抓獲現(xiàn)場(chǎng)!這個(gè)功能其實(shí)在某一個(gè)軟件是集成了的(不記得哪一個(gè)軟件了),但在 KEIL 中我們需要幾步操作完成。
1、新建一個(gè)工程目標(biāo)(可命名為 NotRest):
這樣你可以看到你現(xiàn)在的目標(biāo):
?
接下來(lái)的所有操作都在這個(gè)目標(biāo)進(jìn)行。事實(shí)上,如果只是為了抓獲 BUG 現(xiàn)場(chǎng),是不需要新建目標(biāo)的,但是為了今后可以方便的不復(fù)位單片機(jī)也能進(jìn)入調(diào)試模式,也為了不改變以前目標(biāo)的配置,增加一個(gè)目標(biāo)還是很有必要的,這樣,你可以根據(jù)需要(是否復(fù)位芯片)切換目標(biāo)了。
2、新建一個(gè) load.ini 文件,文件內(nèi)容如下:LOAD %L INCREMENTAL 該文件用于加載 axf 文件到 KEIL 中,但是不會(huì)下載到單片機(jī)中,而 axf 文件可以方便我們進(jìn)行源碼級(jí)別的調(diào)試。
3、打開(kāi)該目標(biāo)的 option 進(jìn)行配置:
4、點(diǎn)擊仿真按鈕,記住了,別點(diǎn)下載按鈕(魚(yú)鷹非常不喜歡別人先點(diǎn)下載按鈕再點(diǎn)仿真按鈕,因?yàn)閯偩幾g后的代碼,如果你直接點(diǎn)仿真按鈕,在默認(rèn)配置下會(huì)自動(dòng)下載和進(jìn)入調(diào)試模式的,比較方便)。
注意,一定要確定該目標(biāo)可以正常使用(即不會(huì)復(fù)位單片機(jī))才能真正用于實(shí)際的 BUG 現(xiàn)場(chǎng),不要沒(méi)有做測(cè)試就直接拿它去調(diào)試實(shí)際的單片機(jī),否則可能因?yàn)闆](méi)有正確配置,而破壞了現(xiàn)場(chǎng)環(huán)境(默認(rèn)配置下,會(huì)直接復(fù)位單片機(jī))!