相信現(xiàn)在很多人都接觸過電路,難免會遇到很多問題,,搞電路設(shè)計(jì)不是件容易的事,,是要有豐富的實(shí)驗(yàn)經(jīng)驗(yàn)才能避開誤區(qū)走向勝利的,。在沒有成為專家級別的工程師,,踩坑是很正常不過的事情了,,下面我們盤點(diǎn)下電路設(shè)計(jì)的誤區(qū),,各位對號入座看看有你們踩過的坑嗎?
誤區(qū)一:這板子的PCB設(shè)計(jì)要求不高,,就用細(xì)一點(diǎn)的線,自動布吧,。
點(diǎn)評:自動布線必然要占用更大的PCB面積,同時(shí)產(chǎn)生比手動布線多好多倍的過孔,,在批量很大的產(chǎn)品中,,PCB廠家降價(jià)所考慮的因素除了商務(wù)因素外,就是線寬和過孔數(shù)量,,它們分別影響到PCB的成品率和鉆頭的消耗數(shù)量,,節(jié)約了供應(yīng)商的成本,也就給降價(jià)找到了理由,。
誤區(qū)二:這些總線信號都用電阻拉一下,,感覺放心些。
點(diǎn)評:信號需要上下拉的原因很多,,但也不是個(gè)個(gè)都要拉,。上下拉電阻拉一個(gè)單純的輸入信號,電流也就幾十微安以下,,但拉一個(gè)被驅(qū)動了的信號,,其電流將達(dá)毫安級,現(xiàn)在的系統(tǒng)常常是地址數(shù)據(jù)各32位,,可能還有244/245隔離后的總線及其它信號,,都上拉的話,幾瓦的功耗就耗在這些電阻上了,。
誤區(qū)三:CPU和FPGA的這些不用的I/O口怎么處理呢?先讓它空著吧,,以后再說。
點(diǎn)評:不用的I/O口如果懸空的話,,受外界的一點(diǎn)點(diǎn)干擾就可能成為反復(fù)振蕩的輸入信號了,,而MOS器件的功耗基本取決于門電路的翻轉(zhuǎn)次數(shù)。如果把它上拉的話,,每個(gè)引腳也會有微安級的電流,,所以最好的辦法是設(shè)成輸出(當(dāng)然外面不能接其它有驅(qū)動的信號)。
誤區(qū)四:這款FPGA還剩這么多門用不完,,可盡情發(fā)揮吧,。
點(diǎn)評:FGPA的功耗與被使用的觸發(fā)器數(shù)量及其翻轉(zhuǎn)次數(shù)成正比,,所以同一型號的FPGA在不同電路不同時(shí)刻的功耗可能相差100倍。盡量減少高速翻轉(zhuǎn)的觸發(fā)器數(shù)量是降低FPGA功耗的根本方法,。
誤區(qū)五:存儲器有這么多控制信號,,我這塊板子只需要用OE和WE信號就可以了,片選就接地吧,,這樣讀操作時(shí)數(shù)據(jù)出來得快多了,。
點(diǎn)評:大部分存儲器的功耗在片選有效時(shí)(不論OE和WE如何)將比片選無效時(shí)大100倍以上,所以應(yīng)盡可能使用CS來控制芯片,,并且在滿足其它要求的情況下盡可能縮短片選脈沖的寬度,。
誤區(qū)六:這些信號怎么都有過沖啊?只要匹配得好,就可消除了,。
點(diǎn)評:除了少數(shù)特定信號外(如100BASE-T,、CML),都是有過沖的,,只要不是很大,,并不一定都需要匹配,即使匹配也并非要匹配得最好,。像TTL的輸出阻抗不到50歐姆,,有的甚至20歐姆,如果也用這么大的匹配電阻的話,,那電流就非常大了,,功耗是無法接受的,另外信號幅度也將小得不能用,,再說一般信號在輸出高電平和輸出低電平時(shí)的輸出阻抗并不相同,,也沒辦法做到完全匹配。所以對TTL,、LVDS,、422等信號的匹配只要做到過沖可以接受即可。
誤區(qū)七:降低功耗都是硬件人員的事,,與軟件沒關(guān)系,。
點(diǎn)評:硬件只是搭個(gè)舞臺,唱戲的卻是軟件,,總線上幾乎每一個(gè)芯片的訪問,、每一個(gè)信號的翻轉(zhuǎn)差不多都由軟件控制的,如果軟件能減少外存的訪問次數(shù)(多使用寄存器變量,、多使用內(nèi)部CACHE等),、及時(shí)響應(yīng)中斷(中斷往往是低電平有效并帶有上拉電阻)及其它爭對具體單板的特定措施都將對降低功耗作出很大的貢獻(xiàn)。
誤區(qū)八:CPU用大一點(diǎn)的CACHE,,就應(yīng)該快了,。
點(diǎn)評:CACHE的增大,,并不一定就導(dǎo)致系統(tǒng)性能的提高,在某些情況下關(guān)閉CACHE反而比使用CACHE還快,。原因是搬到CACHE中的數(shù)據(jù)必須得到多次重復(fù)使用才會提高系統(tǒng)效率,。所以在通信系統(tǒng)中一般只打開指令CACHE,數(shù)據(jù)CACHE即使打開也只局限在部分存儲空間,,如堆棧部分,。同時(shí)也要求程序設(shè)計(jì)要兼顧C(jī)ACHE的容量及塊大小,這涉及到關(guān)鍵代碼循環(huán)體的長度及跳轉(zhuǎn)范圍,,如果一個(gè)循環(huán)剛好比CACHE大那么一點(diǎn)點(diǎn),,又在反復(fù)循環(huán)的話,那就慘了,。
誤區(qū)九:存儲器接口的時(shí)序都是廠家默認(rèn)的配置,,不用修改的。
點(diǎn)評:BSP對存儲器接口設(shè)置的默認(rèn)值都是按最保守的參數(shù)設(shè)置的,,在實(shí)際應(yīng)用中應(yīng)結(jié)合總線工作頻率和等待周期等參數(shù)進(jìn)行合理調(diào)配。有時(shí)把頻率降低反而可提高效率,,如RAM的存取周期是70ns,,總線頻率為40M時(shí),設(shè)3個(gè)周期的存取時(shí)間,,即75ns即可;若總線頻率為50M時(shí),,必須設(shè)為4個(gè)周期,實(shí)際存取時(shí)間卻放慢到了80ns,。
誤區(qū)十:這個(gè)CPU帶有DMA模塊,,用它來搬數(shù)據(jù)肯定快。
點(diǎn)評:真正的DMA是由硬件搶占總線后同時(shí)啟動兩端設(shè)備,,在一個(gè)周期內(nèi)這邊讀,,那邊寫。但很多嵌入CPU內(nèi)的DMA只是模擬而已,,啟動每一次DMA之前要做不少準(zhǔn)備工作(設(shè)起始地址和長度等),,在傳輸時(shí)往往是先讀到芯片內(nèi)暫存,然后再寫出去,,即搬一次數(shù)據(jù)需兩個(gè)時(shí)鐘周期,,比軟件來搬要快一些(不需要取指令,沒有循環(huán)跳轉(zhuǎn)等額外工作),,但如果一次只搬幾個(gè)字節(jié),,還要做一堆準(zhǔn)備工作,一般還涉及函數(shù)調(diào)用,,效率并不高,。所以這種DMA只對大數(shù)據(jù)塊才適用,。
誤區(qū)十一:100M的數(shù)據(jù)總線應(yīng)該算高頻信號,至于這個(gè)時(shí)鐘信號頻率才8K,,問題不大,。
點(diǎn)評:數(shù)據(jù)總線的值一般是由控制信號或時(shí)鐘信號的某個(gè)邊沿來采樣的,只要針對這個(gè)邊沿保持足夠的建立時(shí)間和保持時(shí)間即可,,此范圍之外有干擾也罷過沖也罷都不會有多大影響(當(dāng)然過沖最好不要超過芯片所能承受的最大電壓值),,但時(shí)鐘信號不管頻率多低(其實(shí)頻譜范圍是很寬的),它的邊沿才是關(guān)鍵的,,必須保證其單調(diào)性,,并且跳變時(shí)間需在一定范圍內(nèi)。
誤區(qū)十二:既然是數(shù)字信號,,邊沿當(dāng)然是越陡越好,。
點(diǎn)評:邊沿越陡,其頻譜范圍就越寬,,高頻部分的能量就越大;頻率越高的信號就越容易輻射(如微波電臺可做成手機(jī),,而長波電臺很多國家都做不出來),也就越容易干擾別的信號,,而自身在導(dǎo)線上的傳輸質(zhì)量卻變得越差,,因此能用低速芯片的盡量使用低速芯片。
誤區(qū)十三:信號匹配真麻煩,,如何才能匹配好呢?
點(diǎn)評:總的原則是當(dāng)信號在導(dǎo)線上的傳輸時(shí)間超過其跳變時(shí)間時(shí),,信號的反射問題才顯得重要。信號產(chǎn)生反射的原因是線路阻抗的不均勻造成的,,匹配的目的就是為了使驅(qū)動端,、負(fù)載端及傳輸線的阻抗變得接近。
但能否匹配得好,,與信號線在PCB上的拓?fù)浣Y(jié)構(gòu)也有很大關(guān)系,,傳輸線上的一條分支、一個(gè)過孔,、一個(gè)拐角,、一個(gè)接插件、不同位置與地線距離的改變等都將使阻抗產(chǎn)生變化,,而且這些因素將使反射波形變得異常復(fù)雜,,很難匹配,因此高速信號僅使用點(diǎn)到點(diǎn)的方式,,盡可能地減少過孔,、拐角等問題。以上就是電路設(shè)計(jì)中的一些常見的誤區(qū),希望能給大家一些參考,。