弄了三天的DSP28335與AD7606的通信終于實現(xiàn)了。最終的方案是通過DSP28335控制AD7606的采樣,采集的數(shù)據(jù)通過SPI串口發(fā)送給28335,然后28335通過串口發(fā)送給上位機(jī)顯示。
其實程序第一天就寫好了,但是一直讀不出AD7606采集到的數(shù)據(jù),所以后兩天主要是調(diào)試。
對于程序員來說,調(diào)試是最重要的能力,也還最考驗人的耐心的,因為很小的細(xì)節(jié)出錯就可能導(dǎo)致意想不到的結(jié)果,而且明明感覺是對的東西,有時確是錯誤的。
下面就說下這個調(diào)試過程。
首先程序是一部分一部分的實現(xiàn)的,這樣的話容易定位出錯的模塊,首先實現(xiàn)的是DSP與上位機(jī)的串口通信,這個在上篇的博客中有說明。
另一個模塊即是DSP控制AD7606的采樣與通信。AD7606購買的是一個模塊,外圍的電路已經(jīng)設(shè)計好,各功能引腳已經(jīng)引出,而且給出了STM32與AD7606的控制程序,但這個程序只是用于STM32,而且中間的設(shè)置及寄存器配置都是根據(jù)STM32來的,所以說要用到28335上需要大量的修改。所以還是相當(dāng)于從頭來寫,因為程序的框架可以按照給的程序來寫,所以還是節(jié)省了許多的工作。不過寫好之后發(fā)現(xiàn)上位機(jī)什么也沒有顯示。之后漫長的調(diào)試過程就來了。
既然讀不到數(shù)據(jù),首先想到的是SPI的控制是不是有問題,利用DSP28335自有的SPI回環(huán)測試功能測試了一下,又修改了下SPI的配置,但是還是沒有數(shù)據(jù)。之后想確認(rèn)下是否執(zhí)行了SPI中斷程序,發(fā)現(xiàn)SPI的中斷程序沒有執(zhí)行,但是可以進(jìn)入外部中斷程序,這個外部中斷程序是由AD7606的BUSY引腳產(chǎn)生的,當(dāng)啟動轉(zhuǎn)換的時候BUSY會變成高電平,轉(zhuǎn)換完成后又變成低電平。這個過程中間有個下降沿,利用此下降沿產(chǎn)生中斷然后開始讀取轉(zhuǎn)換后的數(shù)據(jù)。說明AD7606工作了,且完成了轉(zhuǎn)換。但是通過觀察DSP的SPI接收寄存器中一直沒有數(shù)據(jù)。
之后跟著程序,參照數(shù)據(jù)手冊走了一遍程序,確定程序邏輯上是沒有問題的。懷疑SPI的時鐘有沒有輸出,一些引腳的電平是否輸出正確,因此用示波器觀察了各引腳的電平(某一時間內(nèi)電平固定的引腳),都是期望的電平。想觀察下AD7606的數(shù)據(jù)引腳有數(shù)據(jù)輸出沒,奈何沒有邏輯分析儀,用示波器觀察不了(頻率太快,也不是一直都有輸出,示波器的干擾又大),而作罷。
上網(wǎng)查找AD7606與DSP28335的相關(guān)資料,看了一些別人的資料沒有找到需要的。其實上網(wǎng)查找的過程中還是發(fā)現(xiàn)了許多的資料,包括ADI公司完整的包括AD7606的應(yīng)用、控制程序、外圍電路的設(shè)計資料等,不要小看無意間的一句話,也許某句話也就點醒了你,所以遇到問題的時候可以多看別人遇到了什么問題、怎么解決的。這可以節(jié)省大量的時間。但是不能一味的求助別人,要自己多想。
數(shù)據(jù)手冊是一個重要的資料,關(guān)鍵點一定要明確。
控制芯片的時候要多注意這些關(guān)鍵點,因為有一個地方不對,結(jié)果就出現(xiàn)不了。(要特別注意),對照自己的程序,根據(jù)時序圖看一下,是否滿足各方面的要求,包括延時、信號的先后順序等。
在不同的時鐘頻率下,同一個延時函數(shù),延時是不一樣的,所以移植程序的時候也要注意這點。
在我的這個程序中,其實讀不出數(shù)據(jù)的最主要的一個問題還是SPI配置的問題,因為控制發(fā)送功能的寄存器中有一位是開啟增強(qiáng)功能模式,就是可以使用FIFO,而默認(rèn)情況下是不能使用FIFO的,因為想著不使用DSP的發(fā)送功能,所以直接把發(fā)送功能的配置給刪除了,而忘記了這位,所以讀取不出。而在回環(huán)測試的時候是對的,是因為回環(huán)測試的時候要開啟發(fā)送功能。
這個問題的發(fā)現(xiàn)是想著重新寫下代碼,看書核對配置的時候偶然在發(fā)送寄存器中看到有一位是控制開啟增強(qiáng)模式的。所以理不清的時候,不妨重新來過。(下策)
(也曾懷疑過硬件的問題,如果沒有解決的話,下步應(yīng)該是在STM32上跑下。不過硬件因為是買的現(xiàn)成的模塊,出問題的概率不大)
此次調(diào)試總結(jié)
首先核對硬件連接是否正確,包括供電,接地,參考電平,時鐘等,然后需要檢查寄存器配置是否正確,再逐漸調(diào)試軟件(首先跟著程序的流程走一遍,確認(rèn)是否有明顯的失誤。然后可設(shè)置斷點、標(biāo)志位、觀察某一變量的值、內(nèi)存的值等),仔細(xì)研究時序圖,這才是正確方法。另外就需要耐心與細(xì)心。