37. 汽車電子用的單片機是8位多,還是32位?如何看待單片機在汽車電子市場中的前景?
: \9 G! G: }) T3 n/ e9 K n" t: K答:現今汽車制造也是一個進步很快的工業,特別是電子應用于汽車上,令多種新功能得以實現。
! z4 x" c6 ?8 w# c/ F0 U
7 k, G5 F1 Y- x+ G總的來說,汽車電子應用分三部份。 . z* d4 O4 f. g h3 c7 ~' u# S" |
) @, e) z0 d4 w- s 汽車發動機控制:限速控制,渦輪增壓,燃料噴注控制等。
( N6 Z5 w; F$ m1 I8 j 汽車舒適裝置:遙控防盜系統,自動空調系統,影音播放系統,衛星導航系統等。
' Z: `+ K( z- c: V: w2 I 汽車操控和制動:剎車防抱死系統(ABS),循跡系統(TCS),防滑系統(ASR),電子穩定系統(ESP)等。
8 p0 h+ ?6 r, @$ S& `
5 F# ^( i3 r( d; u9 a汽車上的各系統繁多,且日新月異,故利用何種單片機是依各系統規格,要求不一,但有一樣可肯定是該單片機要符工業規格,才能忍受汽車應用的惡劣環境,高溫,電源干擾,可靠度要求。不同檔次的汽車其功能配置相對亦有差別,故8位單片機在較低階的系統如機械控制,遙控防盜等應該還有空間,但高階的系統如影音、導航及將來的無人駕駛,就非一般單片機能實現。
* E' f- _ o# @; x) x4 X& d/ R5 L# _2 j+ p s6 d: Z
因汽車工業現階段由歐美日數個大集團所把持,相關的汽車電子配件各集團會挑選單片機大廠合作, 故汽車內置的電子系統亦由單片機大廠把持,市場只剩外置系統如遙控防盜,影音導航供小廠開發。 , l1 m( y$ V& F' N$ q5 [
0 I2 @- Z5 L2 |7 ~+ }38. 在使用三星的s3c72n4時,覺得它的time/counter不夠用。現在要同時用到3個counter,該怎么辦?
- g7 z* k7 z! ~* \+ U& p答:您是需要三個外部counter還是需要三個定時器?如果是三個定時器標志的話,可以取這三個定時最基本的時基作為timer的基礎計數,然后以這個時基來計算這三個需要的計數標志的flag,在程序中只需要查詢flag是否到,再采取動作。 1 a% A, ~0 y" Q6 B+ ^, r
. E/ ~9 D7 J0 k6 r: }" I/ p1 q
如果要3個外部脈沖計數的話,這個有一定的難度,如果外部脈沖不是很頻繁,可以考慮通過外部中斷進行,但是這個方法必須是外部脈沖的頻率與MCU執行速度有一定的數量級差,否則mcu可能無法處理其它程序,一直在處理外部中斷。
3 Z7 ]1 g( M3 \
" U L/ f: \9 a3 x4 @39. 在芯片集成技術日益進步的今天,單片機的集成技術發展也很迅速,在傳統的40引腳的基礎上,飛利浦公司推出20引腳的單片機系列,使很多的引腳可以復用,這種復用技術的使用在實際應用中會不會影響其功能的執行? * @8 O* B8 l6 v; e
答:現在有很多品牌的單片機都有引腳復用功能,不止飛利浦一家,應該說這個方式前幾年就已經有了。在實際應用中不會影響其功能的執行,但是要注意的是,有的MCU如果采用復用引腳的話,該引腳會有一些應用上的限制,這在相應的datasheet里面都會有描述,所以在系統規劃的時候都要予以注意。
3 \: j" D& w1 M" F$ Z$ k& e2 D, m# i/ {' k% |* S2 T k
40. Delta-Sigma軟件測量方式,是什么概念? 8 J7 G0 e4 v; }/ g+ ~* c! g3 n
答:Delta-Sigma原理一般應用在ADC應用中。具體來說,Delta-Sigma ADC的工作原理是由差動器、積分器和比較器構成調制器,它們一起構成一個反饋環路。調制器以大大高于模擬輸入信號帶寬的速率運行,以便提供過采樣。模擬輸入與反饋信號(誤差信號)進行差動 (delta)比較。該比較產生的差動輸出饋送到積分器(sigma)中。然后將積分器的輸出饋送到比較器中。比較器的輸出同時將反饋信號(誤差信號)傳送到差動器,而自身被饋送到數字濾波器中。這種反饋環路的目的是使反饋信號(誤差信號)趨于零。比較器輸出的結果就是1/0 流。該流如果1密度較高,則意味著模擬輸入電壓較高;反之,0密度較高,則意味著模擬輸入電壓較低。接著將1/0流饋送到數字濾波器中,該濾波器通過過采樣與抽樣,將1/0流從高速率、低精度位流轉換成低速率、高精度數字輸出。 2 S* x0 T$ r* G4 e
$ Y- Q( m( z6 j- i: Z
簡而言之,Delta就是差動,Sigma就是積分的意思。Delta-Sigma軟件測試,我的理解應該是通過軟件模擬差動積分的過程。具體來說,就是偵測外部輸入的電壓(或者電流)信號變化,然后通過軟件積分運算,得出外部信號隨時間變化的基本狀況。 - Y8 p- n U, C- D
7 B( r) @2 t+ ^! V5 c5 m3 e* O41. 通常采用什么方法來測試單片機系統的可靠性?
, | U, M, K3 ?# I, M答:單片機系統可以分為軟件和硬件兩個方面,我們要保證單片機系統可靠性就必須從這兩方面入手。
1 x, B- t9 h7 H2 E- T
) D7 Y% m* `8 E, Y' ]; R首先在設計單片機系統時,就應該充分考慮到外部的各種各樣可能干擾,盡量利用單片機提供的一切手段去割斷或者解決不良外部干擾造成的影響。我們以HOLTEK最基本的I/O單片機HT48R05A-1為例,它內部提供了看門狗定時器WDT防止單片機內部程序亂跑出錯;提供了低電壓復位系統LVR,當電壓低于某個允許值時,單片機會自動RESET防止芯片被鎖死;HOLTEK也提供了最佳的外圍電路連接方案,最大可能的避免外部干擾對芯片的影響。
9 D& b# T7 t7 B6 T2 y4 [& S5 q: |
當一個單片機系統設計完成,對于不同的單片機系統產品會有不同的測試項目和方法,但是有一些是必須測試的:
, |9 I- n, ?+ g, y* b& O) X8 Q7 b) W+ t4 d b* @% b8 d* d6 n/ `
 測試單片機軟件功能的完善性。 這是針對所有單片機系統功能的測試,測試軟件是否寫的正確完整。 , S! t) M8 H/ }8 R2 Z! E
 上電掉電測試。在使用中用戶必然會遇到上電和掉電的情況,可以進行多次開關電源,測試單片機系統的可靠性。 " I! b7 j7 c+ ~' @$ `
" e+ `! _ y/ s' C
 老化測試。測試長時間工作情況下,單片機系統的可靠性。必要的話可以放置在高溫,高壓以及強電磁干擾的環境下測試。
6 E& ?2 I& H2 c R* V+ ?- ]
% q1 B7 R7 H! q& x7 O5 c ESD和EFT等測試。可以使用各種干擾模擬器來測試單片機系統的可靠性。例如使用靜電模擬器測試單片機系統的抗靜電ESD能力;使用突波雜訊模擬器進行快速脈沖抗干擾EFT測試等等。
- k2 k6 {6 v# K% d2 Q6 C/ c) y+ Y0 K
當然如果沒有此類條件,可以模擬人為使用中,可能發生的破壞情況。例如用人體或者衣服織物故意摩擦單片機系統的接觸端口,由此測試抗靜電的能力。用大功率電鉆靠近單片機系統工作,由此測試抗電磁干擾能力等。
; b9 y( C2 H% o- H5 z5 l
7 N; L1 e; F0 q. m+ f' p42. 在開發單片機的系統時,具體有那些是衡量系統的穩定性的標準? / ^8 Y$ e7 Z7 Q1 _; B( H: U9 X5 U+ k
答:從工業的角度來看,衡量系統穩定性的標準有很多,也針對不同的產品標準不同。下面我們大概介紹單片機系統最常用的標準。
a; A, |6 U+ s
+ z& Q" \2 p+ _ 電試驗(ESD)
6 B+ Y" ^' z% v8 W+ c: H參考標準: IEC 61000-4-2
' h, e; g% ^0 x6 h1 D G本試驗目的為測試試件承受直接來自操作者及相對對象所產生之靜電放電效應的程度。 - W/ a4 n5 y, R
2 g/ d2 z% w& G7 ]+ t! ?- G: `3 ^
 空間輻射耐受試驗(RS) . C, ?$ g Q6 n$ j/ b4 L3 u' k; G
參考標準:IEC 61000-4-3 5 q ^+ k8 g" T
本試驗為驗證試件對射頻產生器透過空間散射之噪聲耐受程度。 8 a+ _( S6 C; S7 }
測試頻率:80 MHz~1000 MHz # ]( t% N+ ~6 {4 K, q
! z9 W1 K' Y' X8 p. M5 N 快速脈沖抗擾測試(EFT/B) # n1 p0 L) M6 L: D2 k7 D0 h
參考標準:IEC 61000-4-4
0 w. d0 l# V( {8 E: z( B: }( F本試驗目的為驗證試件之電源線,信號線(控制線)遭受重復出現之快速瞬時叢訊時之耐受程度。 9 O. z) O e6 a# z- ^
; w. }0 h9 w( x9 P+ z8 n
 雷擊試驗(Surge) 7 o# H) a2 I4 B% m
參考標準 : IEC 61000-4-5 9 |- P: M$ W. p
本試驗為針對試件在操作狀態下,承受對于開關或雷擊瞬時之過電壓/電流產生突波之耐受程度。
0 |1 F2 q8 q1 l4 C6 R7 b, J
+ W2 {& }5 C0 { O+ T6 ]* D( z 傳導抗擾耐受性(CS) % k9 B; l, ^. {$ Z. n( w
參考標準:IEC 61000-4-6 ) E5 e. v: K n6 |
本試驗為驗證試件對射頻產生器透過電源線傳導之噪聲耐受程度。 0 s3 ?# E8 j) r
測試頻率范圍:150 kHz~80 MHz
" A. R- `. y$ y/ Q' U
8 i7 \6 W* j/ Q% w0 r' i, R Impulse
9 y+ R, f8 J9 e* w" D, X脈沖經由耦合注入電源線或控制線所作的雜抗擾性試驗。 : g% r7 H! N, I/ j% v' g. U. i
) r' {. H$ D! S3 i( |43. 在設計軟體時,大多單片機都設有看門狗,需要在軟體適當的位置去喂狗,以防止軟體復位和軟體進入死循環,如何適當的喂狗,即如何精確判定軟體的運行時間?
; Z: |1 n) b2 w' c7 y4 S- J答:大多數單片機都有看門狗定時器功能(WDT,Watch Dog Timer)以避免程序跑錯。HOLTEK有一款基本I/O型單片機--HT48R05A-1,我們就以它為例做個說明吧。
7 z/ R9 Y0 W/ N( u
7 N/ c, Z5 o- l2 }首先了解一下WDT的基本結構,它其實是一個定時器,所謂的喂狗是指將此定時器清零。喂狗分為軟件和硬件兩種方法。軟件喂狗就是用指令來清除WDT,即CLR WDT;硬件喂狗就是硬件復位RESET。當定時器溢出時,會造成WDT復位,也就是我們常說的看門狗起作用了。在程序正常執行時,我們并不希望WDT復位,所以要在看門狗溢出之前使用軟件指令喂狗,也就是要計算WDT相隔多久時間會溢出一次。HT48R05A-1的WDT溢出時間計算公式是:256*Div*Tclock。其中Div是指wdt預分頻數1~128,Tclock是指時鐘來源周期。如果使用內部RC振蕩作為WDT的時鐘來源(RC時鐘周期為65us/5V),最大的WDT溢出時間為2.1秒。 1 \9 ?# t# d8 f1 w
9 j' e1 W- g! s g0 \ f: l當我們得到了WDT溢出時間Twdt后,一般選擇在Twdt/2左右的時間進行喂狗,以保證看門狗不會溢出,同時喂狗次數不會過多。 7 b* |& {- F! P* a2 [! |
& L; q& o0 s: R' }3 g* Y
軟件運行時間是根據不同的運行路線來決定的,如果可以預見軟件運行的路線,那么可以根據T=n*T1來計算軟件的運行時間。n是指運行的機器周期數,T1是指機器周期。HOLTEK單片機是RISC結構,大部分指令由一個機器周期組成,只需要知道軟件運行了多少條指令,就可以算出運行時間了。HOLTEK的編譯軟件HT-IDE3000中,就有計算運行時間的工具。但是對于CISC結構的單片機,一條指令可以由若干個機器周期組成,那么就需要根據具體執行的指令來計算了。 % @) `* @. Y" f4 P
8 ]5 n o ^5 Z% R
44. 我們是一家開發數控系統的專業廠,利用各種單片機和CPU開發了很多產品,在軟件開發上也采用了很多通用的抗干擾技術,如:軟件陷阱、指令允余、看門狗和數字濾波等等,但實際運用中還是很不可靠,如:經常莫名其妙地死機、程序跳段、I/O數據錯誤等,并且故障的重復性很不確定,也不是周期性地重復。往往用戶使用中出現故障,但又無法重現,很讓人頭痛。反復檢查硬件也設查出原因,所以對軟件的可靠性很是懷疑。怎么辦?
7 j* N4 V, G$ w6 v答:防止干擾最有效的方法是去除干擾源、隔斷干擾路徑,但往往很難做到,所以只能看單片機抗干擾能力夠不夠強了。單片機干擾最常見的現象就是復位;至于程序跑飛,其實也可以用軟件陷阱和看門狗將程序拉回到復位狀態;所以單片機軟件抗干擾最重要的是處理好復位狀態。 3 l( T* V8 Q. U) R. P$ r6 C
# ?. o: F" }7 m' r8 _6 ~. Q6 E
一般單片機都會有一些標志寄存器,可以用來判斷復位原因;另外也可以自己在RAM中埋一些標志。在每次程序復位時,通過判斷這些標志,可以判斷出不同的復位原因;還可以根據不同的標志直接跳到相應的程序。這樣可以使程序運行有連續性,用戶在使用時也不會察覺到程序被重新復位過。 # k7 c$ A- p% |
! p8 y2 j, k( u9 M# R: l
終于貼完了, 3 z0 r S3 i7 j0 ^0 V* C' f
% T: U7 E+ B: T, n/ t% k( q; H& }
可以在定時中斷里面設置一些暫存器累加,然后加到預先設定的值(一個比較長的時間),SET標志位,這些動作都在中斷程序里面。而主程序只需要查詢標志位就好了,但是注意標志位使用后,記得清除,還有中斷里面的時基累加器使用以后也要記得清除。 |