專注差異化嵌入式產(chǎn)品解決方案 給智能產(chǎn)品定制注入靈魂給予生命
提供開(kāi)發(fā)工具、應(yīng)用測(cè)試 完善的開(kāi)發(fā)代碼案例庫(kù)分享
從全面的產(chǎn)品導(dǎo)入到強(qiáng)大技術(shù)支援服務(wù) 全程貼心伴隨服務(wù),創(chuàng)造無(wú)限潛能!
提供新的芯片及解決方案,提升客戶產(chǎn)品競(jìng)爭(zhēng)力
提供最新的單片機(jī)資訊,行業(yè)消息以及公司新聞動(dòng)態(tài)
十年專注單片機(jī)方案開(kāi)發(fā)的方案公司英銳恩,分享單片機(jī)應(yīng)用編程技巧(二)。英銳恩現(xiàn)提供服務(wù)產(chǎn)品涉及主控芯片:8位單片機(jī)、16位單片機(jī)、32位單片機(jī)及各類運(yùn)算放大器等。
15. 請(qǐng)介紹一下MCU的測(cè)試方法。
答: MCU從生產(chǎn)出來(lái)到封裝出貨的每個(gè)不同的階段會(huì)有不同的測(cè)試方法,其中主要會(huì)有兩種:中測(cè)和成測(cè)。
所謂中測(cè)即是WAFER的測(cè)試,它會(huì)包含產(chǎn)品的功能驗(yàn)證及AC、DC的測(cè)試。項(xiàng)目相當(dāng)繁多,以HOLTEK產(chǎn)品為例最主要的幾項(xiàng)如下:
l 接續(xù)性測(cè)試:檢測(cè)每一根I/OPIN內(nèi)接的保護(hù)用二極管是否功能無(wú)誤。
l 功能測(cè)試:以產(chǎn)品設(shè)計(jì)者所提供測(cè)試資料(TEST PATTERN)灌入IC,檢查其結(jié)果是否與當(dāng)時(shí)SIMULATION時(shí)狀態(tài)一樣。
l STANDBY電流測(cè)試:測(cè)量IC處于HALT模式時(shí)即每一個(gè)接點(diǎn)(PAD)在1態(tài)0態(tài)或Z態(tài)保持不變時(shí)的漏電
流是否符合最低之規(guī)格。
l 耗電測(cè)試:整顆IC的靜態(tài)耗電與動(dòng)態(tài)耗電。
l 輸入電壓測(cè)試:測(cè)量每個(gè)輸入接腳的輸入電壓反應(yīng)特性。
l 輸出電壓測(cè)試:測(cè)量每個(gè)輸出接腳的輸出電壓位準(zhǔn)。
l 相關(guān)頻率特性(AC)測(cè)試,也是通過(guò)外灌一定頻率,從I/O口來(lái)看輸出是否與之匹配。
l 為了保證IC生產(chǎn)的長(zhǎng)期且穩(wěn)定品質(zhì),還會(huì)做產(chǎn)品的可靠性測(cè)試,這些測(cè)試包括ESD測(cè)試,LATCH UP測(cè)試,溫度循環(huán)測(cè)試,高溫貯存測(cè)試,濕度貯存測(cè)試等。
成測(cè)則是產(chǎn)品封裝好后的測(cè)試,即PACKAGE測(cè)試。即是所有通過(guò)中測(cè)的產(chǎn)品封裝后的測(cè)試,方法主要是機(jī)臺(tái)自動(dòng)測(cè)試,但測(cè)試項(xiàng)目仍與WAFER TEST相同。PACKAGE TEST的目的是在確定IC在封裝過(guò)程中是否有任何損壞。
16. 能否利用單片來(lái)檢測(cè)手機(jī)電池的充放電時(shí)間及充放電時(shí)的電壓電流變化,并利用一個(gè)I/O端口使檢測(cè)結(jié)果在電腦上顯示出來(lái)?
答:目前市場(chǎng)上的各類智能充電器,大部分都采用MCU進(jìn)行充電電流和電壓的控制。至于要在電腦上顯示,好象并不實(shí)用,可能只有在一些專門的電池檢測(cè)儀器中才會(huì)用到;對(duì)于一般的手機(jī)用戶來(lái)說(shuō),誰(shuí)會(huì)在充電時(shí)還需要用一臺(tái)電腦來(lái)做顯示呢?要實(shí)現(xiàn)單片機(jī)與電腦的連接,最簡(jiǎn)單的方式就是采用串口通訊,但需要加一顆RS-232芯片。
17. 在ARM編程中又應(yīng)當(dāng)如何?
答:就以嵌入式系統(tǒng)觀念為例,一般嵌入式處理器可以分為三類:嵌入式微處理器、嵌入式微控制器、嵌入式DSP(Digital Signal Processor)。
嵌入式微處理器就是和通用計(jì)算機(jī)的微處理器對(duì)應(yīng)的CPU。在應(yīng)用中,一般是將微處理器裝配在專門設(shè)計(jì)的電路板上,在母板上只保留和嵌入式相關(guān)的功能即可,這樣可以滿足嵌入式系統(tǒng)體積小和功耗低的要求。目前的嵌入式處理器主要包括:PowerPC、Motorola 68000、ARM系列等等。
嵌入式微控制器又稱為單片機(jī),它將CPU、存儲(chǔ)器(少量的RAM、ROM或兩者都有)和其它接口I/O封裝在同一片集成電路里。常見(jiàn)的有HOLTEK MCU系列、Microchip MCU系列及8051等。
嵌入式DSP專門用來(lái)處理對(duì)離散時(shí)間信號(hào)進(jìn)行極快的處理計(jì)算,提高編譯效率和執(zhí)行速度。在數(shù)字濾波、FFT(Fast Fourier Transform)、頻譜分析、圖像處理的分析等領(lǐng)域,DSP正在大量進(jìn)入嵌入式市場(chǎng)。
18. MCU在射頻控制時(shí),MCU的時(shí)鐘(晶振)、數(shù)據(jù)線會(huì)輻射基頻或基頻的倍頻,被低噪放LNA放大后進(jìn)入混頻,出現(xiàn)帶內(nèi)的Spur,無(wú)法濾除。除了用layout、選擇低輻射MCU的方法可以減少一些以外,還有什么別的方法?
答:在設(shè)計(jì)高頻電路用電路板有許多注意事項(xiàng),尤其是GHz等級(jí)的高頻電路,更需要注意各電子組件pad與印刷pattern的長(zhǎng)度對(duì)電路特性所造成的影響。最近幾年高頻電路與數(shù)位電路共享相同電路板,構(gòu)成所謂的混載電路系統(tǒng)似乎有增加的趨勢(shì),類似如此的設(shè)計(jì)經(jīng)常會(huì)造成數(shù)位電路動(dòng)作時(shí),高頻電路卻發(fā)生動(dòng)作不穩(wěn)定等現(xiàn)象,其中原因之一是數(shù)位電路產(chǎn)生的噪訊,影響高頻電路正常動(dòng)作所致。為了避免上述問(wèn)題除了設(shè)法分割兩電路block之外,設(shè)計(jì)電路板之前充分檢討設(shè)計(jì)構(gòu)想,才是根本應(yīng)有的手法,基本上設(shè)計(jì)高頻電路用電路板必需掌握下列三大原則:
l 高質(zhì)感。
l 不可取巧。
l 不可倉(cāng)促搶時(shí)間。
以下是設(shè)計(jì)高頻電路板的一些建議:
(1)印刷pattern的長(zhǎng)度會(huì)影響電路特性。尤其是傳輸速度為GHz高速數(shù)位電路的傳輸線路,通常會(huì)使用strip line,同時(shí)藉由調(diào)整配線長(zhǎng)度補(bǔ)正傳輸延遲時(shí)間,其實(shí)這也意味著電子組件的設(shè)置位置對(duì)電路特性具有絕對(duì)性的影響。
(2)Ground作大better。銅箔面整體設(shè)置ground層,而連接via的better ground則是高頻電路板與高速數(shù)位電路板共同的特征,此外高頻電路板最忌諱使用幅寬細(xì)窄的印刷pattern描繪ground。
(2)電子組件的ground端子,以最短的長(zhǎng)度與電路板的ground連接。具體方法是在電子組件的ground端子pad附近設(shè)置via,使電子組件能以最短的長(zhǎng)度與電路板的ground連接。
(3)信號(hào)線作短配線設(shè)計(jì)。不可任意加大配線長(zhǎng)度,盡量縮短配線長(zhǎng)度。
(4)減少電路之間的結(jié)合。尤其是filter與amplifier輸出入之間作電路分割非常重要,它相當(dāng)于audio電路的cross talk對(duì)策。
(5)MCU回路Layout考量:震蕩電路僅可能接近IC震蕩腳位;震蕩電路與VDD & VSS保持足夠的距離;震蕩頻率大于1MHz時(shí)不需加 osc1 & osc2 電容;電源與地間要最短位置并盡量拉等寬與等距的線,于節(jié)點(diǎn)位置加上104/103/102等陶瓷電容。
19. Intel系列的96單片機(jī)80c196KB開(kāi)發(fā)系統(tǒng)時(shí),都有那些注意事項(xiàng)?
答:一個(gè)即時(shí)系統(tǒng)的軟體由即時(shí)操作系統(tǒng)加上應(yīng)用程序構(gòu)成。應(yīng)用程序與作業(yè)系統(tǒng)的接口通過(guò)系統(tǒng)調(diào)用來(lái)實(shí)現(xiàn)。用80C196KB作業(yè)系統(tǒng)的MCU,只能用內(nèi)部RAM作為TCB和所有系統(tǒng)記憶體(含各種控制表)以及各個(gè)任務(wù)的工作和資料單元。因此一定要注意以下幾點(diǎn):
(1)對(duì)各個(gè)任務(wù)分配各自的堆迭區(qū),該堆迭區(qū)既作為任務(wù)的工作單元,也作為任務(wù)控制塊的保護(hù)單元。
(2)系統(tǒng)的任務(wù)控制塊只存放各任務(wù)的堆迭指標(biāo),而任務(wù)的狀態(tài)均存放于任務(wù)椎棧中。在一個(gè)任務(wù)退出運(yùn)行時(shí),通過(guò)中斷把它的狀態(tài)進(jìn)棧,然后把它的堆迭指標(biāo)保存于系統(tǒng)的TCB中;再根據(jù)優(yōu)先取出優(yōu)先順序最高的已就緒任務(wù)的堆迭指標(biāo)SP映象值送入SP中;最后執(zhí)行中斷返回指令轉(zhuǎn)去執(zhí)行新任務(wù)。
(3)各任務(wù)的資料和工作單元盡量用堆迭實(shí)現(xiàn),這樣可以允許各任務(wù)使用同一個(gè)子程序。使用堆迭實(shí)現(xiàn)參數(shù)傳遞并作為工作單元,而不使用絕對(duì)地址的RAM,可實(shí)現(xiàn)可重入子程序。該子程序既可為各個(gè)任務(wù)所調(diào)用,也可實(shí)現(xiàn)遞回調(diào)用。
20. 在demo板上采樣電壓時(shí),不穩(wěn)定,采樣結(jié)果有波動(dòng),如何消除?
答:一般來(lái)說(shuō),仿真器都是工作在一個(gè)穩(wěn)壓的環(huán)境(通常為5V)。如果用仿真器的A/D時(shí),要注意其A/D參考電壓是由仿真器內(nèi)部給出,還是需要外部提供。A/D轉(zhuǎn)換需要一個(gè)連續(xù)的時(shí)鐘周期,所以在仿真時(shí)不能用單步調(diào)試的方法,否則會(huì)造成A/D采樣值不準(zhǔn)。至于A/D采樣不穩(wěn)定,可以在A/D輸入口加一電容,起到濾波作用;在軟件處理時(shí)采用中值濾波的方法。
21. 在車載DVD系統(tǒng)中,如何設(shè)計(jì)電子防震系統(tǒng)?
答:在車載DVD系統(tǒng),最好選擇高檔DVD機(jī),因?yàn)楦邫nDVD機(jī)都采用電子防震系統(tǒng)(ADVANCEDESP),當(dāng)記憶緩沖區(qū)內(nèi)的讀數(shù)降低,先進(jìn)的電子防震設(shè)計(jì)會(huì)以雙速讀數(shù)系統(tǒng),做出比正常速度快兩倍的讀數(shù)速率,以減低噪聲,即使連續(xù)震蕩仍可避免跳線情況出現(xiàn),現(xiàn)在就說(shuō)說(shuō)什幺叫電子防震。簡(jiǎn)單地說(shuō):電子防震就是一個(gè)信號(hào)的儲(chǔ)存--釋放過(guò)程,首先CD要先把信號(hào)進(jìn)行提前讀取,也就是我們見(jiàn)到機(jī)子的加速,再把信號(hào)儲(chǔ)存在RAM中,而我們?cè)陂_(kāi)防震的時(shí)候所聽(tīng)到的就是經(jīng)過(guò)RAM的聲音,這樣就是它的過(guò)程。當(dāng)沒(méi)有防震時(shí)是由于信號(hào)是1比1讀取的,所以當(dāng)受到?jīng)_擊后,就會(huì)出現(xiàn)跳音。而當(dāng)開(kāi)了防震時(shí),機(jī)子受到?jīng)_擊后,由RAM釋放出來(lái)的聲音使音樂(lè)不停地播放,而與此同時(shí),光頭迅速進(jìn)行復(fù)位檢索,當(dāng)檢索到信號(hào)后立即補(bǔ)充,所以不會(huì)出現(xiàn)跳音。大概的情況就是這樣。但是這樣還沒(méi)有滿足用家的要求,由于這種的方法帶來(lái)的時(shí)間短,通常只有3秒,所以跳音的機(jī)會(huì)還是蠻高,如果增大RAM又帶來(lái)造價(jià)的增高因?yàn)镽AM這東西價(jià)格較貴,尤其是質(zhì)量好的。
22. 在電子防震技術(shù)中,有那些IC或器件可供選擇?
答:在電子防震技術(shù)中,最重要的技術(shù)之一要數(shù)是RAM技術(shù),而一直以來(lái)都是因?yàn)樗某杀締?wèn)題,所以防震時(shí)間都一直不能增加,也就是說(shuō)RAM本身就有限制,RAM的容量越大,造價(jià)就越高。而許多廠家就如何在RAM的限制里得到最大限度的記憶時(shí)間展開(kāi)了開(kāi)發(fā)研究。
23. 如何進(jìn)行編程可以減少程序的bug?
答:在此提供一些建議,因系統(tǒng)中實(shí)際運(yùn)行的參數(shù)都是有范圍的。系統(tǒng)運(yùn)行中要考慮的超范圍管理參數(shù)有:
l 物理參數(shù)。這些參數(shù)主要是系統(tǒng)的輸入?yún)?shù),它包括激勵(lì)參數(shù)、采集處理中的運(yùn)行參數(shù)和處理結(jié)束的結(jié)果參數(shù)。合理設(shè)定這些邊界,將超出邊界的參數(shù)都視為非正常激勵(lì)或非正?;貞?yīng)進(jìn)行出錯(cuò)處理。
l 資源參數(shù)。這些參數(shù)主要是系統(tǒng)中的電路、器件、功能單元的資源,如記憶體容量、存儲(chǔ)單元長(zhǎng)度、堆迭深度。在程序設(shè)計(jì)中,對(duì)資源參數(shù)不允許超范圍使用。
應(yīng)用參數(shù)。這些應(yīng)用參數(shù)常表現(xiàn)為一些單片機(jī)、功能單元的應(yīng)用條件。如E2PROM的擦寫次數(shù)與資料存儲(chǔ)時(shí)間等應(yīng)用參數(shù)界限。
l 過(guò)程參數(shù)。指系統(tǒng)運(yùn)行中的有序變化的參數(shù)。
在上述參數(shù)群對(duì)一程序編寫者而言,須養(yǎng)成良好習(xí)慣,在程序的開(kāi)頭,有順序的用自己喜歡文字參數(shù)對(duì)應(yīng)列表來(lái)替代,然后用自己定義的文字參數(shù)來(lái)編寫程序,這樣在做程序的修改及維護(hù)時(shí)只在程序的開(kāi)頭做變動(dòng)即可,不用修改到程序段,才比較容易且不會(huì)出錯(cuò)。
24. 有人認(rèn)為單片機(jī)將被ARM等系列結(jié)構(gòu)的嵌入式系統(tǒng)所取代。單片機(jī)的生命期還有多長(zhǎng)?
答:因?yàn)?位單片機(jī)與嵌入式系統(tǒng)的ARM在功能結(jié)構(gòu)和單價(jià)的差異,故應(yīng)用層次上就有很大的不同。
ARM適用于系統(tǒng)復(fù)雜度較大的高級(jí)產(chǎn)品,如PDA、手機(jī)等應(yīng)用。
而8位單片機(jī)因架構(gòu)簡(jiǎn)單,硬件資源相對(duì)較少,適用于一般的工業(yè)控制,消費(fèi)性家電……等等。評(píng)估單片機(jī)近期是否會(huì)給ARM取代,要觀察兩個(gè)因素:
l 芯片成本
因ARM的工作頻率較高,電路較龐大,所需的芯片制造工藝要求在0。25U以上,成本較高。8位單片機(jī)工作頻率相對(duì)較低,電路較小,所需的芯片制造工藝在0。5U 即可,成本較低。
功能定位
ARM的功能較單片機(jī)強(qiáng),但兩者定位不同。就如現(xiàn)階段不會(huì)有人用ARM去作一個(gè)簡(jiǎn)單的工業(yè)定時(shí)開(kāi)關(guān)。當(dāng)然,如果兩者單價(jià)相同也無(wú)不可,但現(xiàn)實(shí)是有很大的單價(jià)差距。
至于將來(lái),因芯片制造成本會(huì)不斷下降,上述的成本差異影響愈來(lái)愈少!但我估計(jì)在往后5年單片機(jī)仍有價(jià)格優(yōu)勢(shì),仍能存活!但ARM是否會(huì)精簡(jiǎn)架構(gòu),降低成本,搶奪低階市場(chǎng)?我想可能性不大,ARM應(yīng)該會(huì)向上發(fā)展。同樣,單片機(jī)也只能向上發(fā)展,如16位,高功能……等。 原因就是因?yàn)樾酒圃旃に囘M(jìn)步太快。壓迫芯片設(shè)計(jì)往高集成發(fā)展。
25. 在單片機(jī)C編成時(shí),如何才能使生成的代碼具有和匯編一樣的效率?
答:如果是使用C語(yǔ)言編程時(shí),不太可能生成的代碼具有1:1和匯編一樣的效率。
C語(yǔ)言命令要被硬件識(shí)別并執(zhí)行,必須通過(guò)編譯器編譯。編譯器分為前端、中端、后端。前端與各種計(jì)算機(jī)語(yǔ)言寫的程序打交道,后端與處理器的基本指令集接軌。所以如果使用C編程時(shí),要達(dá)到最高的效率,最好能夠很了解所使用的C編譯器。先試驗(yàn)一下每條C語(yǔ)言編譯以后對(duì)應(yīng)的匯編語(yǔ)言的語(yǔ)句行數(shù),這樣就可以很明確的知道效率。在今后編程的時(shí)候,使用編譯效率最高的語(yǔ)句,這樣就能確保單片機(jī)C編程的時(shí)候同樣的功能不同的C程序,編譯效率最高。但是各家的C編譯器都會(huì)有一定的差異,優(yōu)秀的嵌入式系統(tǒng)C編譯器代碼長(zhǎng)度和執(zhí)行時(shí)間僅比以匯編語(yǔ)言編寫的同樣功能程度長(zhǎng)5-20%,所以不同廠家的C編譯器的編譯效率也會(huì)有所不同。
26. ARM單片機(jī)和哪種內(nèi)核的單片機(jī)比較接近?
答:嚴(yán)格的說(shuō),ARM不是單片機(jī),是一個(gè)嵌入式的實(shí)時(shí)操作系統(tǒng)。ARM(Advanced
RISC
Machines)是微處理器行業(yè)的一家知名企業(yè),設(shè)計(jì)了大量高性能、廉價(jià)、耗能低的RISC處理器、相關(guān)技術(shù)及軟件。ARM將其技術(shù)授權(quán)給世界上許多著名的半導(dǎo)體、軟件和OEM廠商,每個(gè)廠商得到的都是一套獨(dú)一無(wú)二的ARM相關(guān)技術(shù)及服務(wù)。所以市場(chǎng)上像Intel、IBM、LG半導(dǎo)體、NEC、SONY、菲利浦和國(guó)半這樣的大公司都有ARM系列,現(xiàn)在不存在什幺ARM單片機(jī)和哪種內(nèi)核的單片機(jī)比較接近的問(wèn)題。而且由于廠家購(gòu)買內(nèi)核后會(huì)根據(jù)自己芯片應(yīng)用方向的不同,自行添加不同的外掛功能模塊,所以,同樣內(nèi)核的芯片其提供的功能是不同的。
27. 從51轉(zhuǎn)到ARM會(huì)有困難嗎?
答:從51轉(zhuǎn)到ARM,其實(shí)編程之類的原理都是一樣的,但是要注意的是ARM是一個(gè)RISC的架構(gòu),在ARM的應(yīng)用開(kāi)放源代碼的程序很多,要想提高自己,就要多看別人的程序,linux,uc/os-II等等這些都是很好的源碼。
28. 我學(xué)過(guò)MCS51單片機(jī)教材,很有興趣,但缺乏實(shí)踐經(jīng)驗(yàn),手頭沒(méi)有任何道具可供演練,資金又有限,請(qǐng)問(wèn)該怎么辦?
答:在沒(méi)有任何條件進(jìn)行實(shí)踐時(shí),如果真的有興趣,可以下載一些具有軟件仿真功能仿真軟件進(jìn)行一些編程,像一些做得比較好的51仿真軟件應(yīng)該具有這種功能。HOLTEK的仿真軟件HT-IDE3000也具有相應(yīng)的功能,同時(shí)它還具有LCD軟件仿真,周邊電路的軟件仿真。同時(shí)可以到一些電子市場(chǎng)去購(gòu)買一些簡(jiǎn)單器件自己練習(xí)搭一下電路以加強(qiáng)硬件方面的知識(shí)。
29. 如果已經(jīng)有了針對(duì)某MCU的C實(shí)現(xiàn)的某個(gè)算法,保持框架不變,對(duì)核心的部分用匯編優(yōu)化,有沒(méi)有一些比較通用的原則?
答:每個(gè)人的編程都有自己的風(fēng)格與習(xí)慣,如果要利用別人的程序,在其中修修改改,如果他的程序并沒(méi)有很好的模塊化的話,建議最好不要這幺做,否則本來(lái)預(yù)期達(dá)到事倍功半,說(shuō)不定反而事半功倍了。要參考他人的程序當(dāng)然可以,但是首要是要看懂并理解他人程序的算法精髓,而不是在他的基礎(chǔ)上打補(bǔ)丁。而關(guān)于算法方面的優(yōu)化,可以購(gòu)買一些數(shù)據(jù)結(jié)構(gòu)的書籍,上面有比較詳細(xì)的說(shuō)明。
30. 如果準(zhǔn)備估計(jì)一個(gè)算法的MIPS,有什么好的途徑?
答:算法的運(yùn)行時(shí)間是指一個(gè)算法在計(jì)算機(jī)上運(yùn)算所花費(fèi)的時(shí)間。它大致等于計(jì)算機(jī)執(zhí)行簡(jiǎn)單操作(如賦值操作,比較操作等)所需要的時(shí)間與算法中進(jìn)行簡(jiǎn)單操作次數(shù)的乘積。通常把算法中包含簡(jiǎn)單操作次數(shù)的多少叫做算法的時(shí)間復(fù)雜性。它是一個(gè)算法運(yùn)行時(shí)間的相對(duì)量度,一般用數(shù)量級(jí)的形式給出。度量一個(gè)程序的執(zhí)行時(shí)間通常有兩種方法:
(文源網(wǎng)絡(luò),侵刪)