如何成爲優秀的驅動開發工程師

 

作者:劉旭暉 Raymond 轉載請註明出處

Email [email protected]

BLOG http://blog.csdn.net/colorant/

主頁: http://sites.google.com/site/rgbbones/

 

或許這樣的標題,應該是由像Linus或Greg KH這樣的大師級的高手纔有資格寫的吧。但是作爲我來說,也許我更想把這個標題作爲一個疑問句來使用,整理一下自己的認識,用來勉勵自己,和大家一起努力實現這個目標。認識膚淺的地方,還請大家見諒。

何謂優秀的驅動開發工程師

    首先要定義,我所認爲的一個優秀的驅動開發工程師,應該具備什麼樣的能力,這裏列一下按照從易到難的順序,個人認爲應該會有幾個方面的要求吧:
 
  • 能夠獨立完成驅動的功能開發任務
  • 能夠分析和優化驅動的性能,針對特定硬件揚長避短
  • 能夠充分了解模塊相關軟硬件能力、發展方向,輔助應用工程師最大化利用硬件能力
  • 能夠輔助硬件工程師規劃硬件設計,預防問題,謀求功能模塊的最佳方案
  • 能夠協助定義系統架構,合理規劃軟硬件,謀求產品實現的最佳方案
 
    作爲一個驅動工程師,很多時候不是完全從頭開發一個完整的子系統,而是針對特定硬件和平臺移植驅動,增加功能,解決Bug等等,如果從這方面外在的表現來看:
 
解決問題的境界,大概會有這麼幾個階段:
 
  •     不知道哪裏存在BUG
  •     不知道如何解決BUG
  •     知道如何解決BUG
  •     知道如何發現BUG
  •     知道如何規劃BUG
 
    知道如何發現BUG(而不是撞上BUG)其實並不簡單,需要你對系統有足夠的瞭解,能夠察覺可能出問題的地方。 而規劃Bug更難,需要你能對問題的輕重緩急做出準確的判斷。沒有的完美的世界,只有適當的取捨,規避和預防。
 
而從解決問題過程的角度來看,我認可以分爲幾個階段:
 
  •     BUG發生 -> 大量跟蹤調試代碼 -> 終於發現並解決BUG
  •     BUG發生 -> 理論推測可能原因 -> 迅速定位並解決BUG
  •     閱讀代碼 -> 預測可能出現的BUG -> 證實並解決BUG
 
號稱能光憑瞄一遍代碼就找到問題的高手,我想我是沒希望了。

應該具備怎樣的素質

    那麼要達到上訴最佳境界,需要具備和發展哪些素質和能力呢?
 

足夠的硬件知識

    能看簡單的原理圖,能夠分析硬件異常的可能原因,能夠使用常見的硬件調試工具,我想這是做爲優秀的驅動工程師,區別與其它軟件工程師,所不可避免、必須具備的專業素質。當然取決於你具體從事的工作,對這方面的要求不盡相同。
 
    對於驅動開發者來說,不瞭解所開發驅動外設的硬件原理和相關背景知識,也許很多時候,也能夠完成一些移植,修補的工作任務,但這就好比無源之水,無根之木,我相信是很難走遠的。
 

多多益善的操作系統知識

    做驅動開發,特別是純粹的外設的驅動移植工作,剛開始的時候,也許你並不需要了解很多操作系統本身的知識(像內存管理,進程調度,鎖,各種內核子系統的原理框架等等),也能順利完成手頭的一些工作。
    但是,如果一但需要優化驅動,需要完善軟件框架,或者是遇上疑難問題需要跟蹤解決,對操作系統,內核本身的瞭解,就體現出它的價值了。
    對於Linux內核驅動開發者,尤其如此,首先,代碼是完全開源的,你有條件去了解背後的運行機制,其次,Linux內核和各個組成子系統總是在迅速的進化發展中,不進則退,你也有必要跟上時代發展的腳步。

強烈的好奇心,持續的熱情

    如果驅動開發不僅僅是你的愛好,更是你養家餬口的途徑,我想,很多時候,你大概不會有機會專注於一兩個你最有經驗的模塊的開發和維護。隨着能力的成長,勢必會要求你接觸和掌握越來越多的各式各樣的驅動模塊的開發。
    對於這件事,包括我自己,有時候大概都會有如下幾種反應:
 
    哇,原來的工作做太久了,太乏味了,很高興能做不同的工作。
    啊?又要做別的模塊啊?我手頭的工作已經太多了!
    這個模塊沒意思,我不想做。
 
    相信多數有志青年們都是第一種表現了 8 )不過,有些時候,我發覺,很多人的這種熱情其實並不持久,一個新的模塊沒做多久,就再次厭倦了,是已經爐火純青了麼,未必,或許只是修改了幾個BUG以 後不甚其煩。很多時候,我面試前來求職的工程師時,發現簡歷上這個也做過,那個也做過,但是一但問到解決了什麼問題,所做過的驅動,框架、流程、原理之類 的問題的時候,就一問三不知了。
 
    我覺得如果自己的目標是優秀,那麼最起碼的標準應該是對具體驅動模塊相關的子系統的整體工作流程,框架,具備足夠的好奇心,樂於去了解和學習,而不僅僅是爲了完成任務而工作,否則的話,很難積累下紮實的經驗和技術。

清晰的邏輯思維能力

     這一點,也許是個軟件開發人員都應該具備吧,不過,做爲驅動開發工程師來說,有時候,大多數情況下,工作的硬件環境並不是完美的,遇到問題需要分析判斷錯誤的原因是硬件問題還是驅動Bug,這時候,清晰的邏輯思維能力尤其重要。

良好的工作習慣

     大多數人都不是天才,要成爲優秀的開發工程師,一需 要持續努力,二需要時間積累經驗,而這過程中,很重要的一點,就是要有良好的工作習慣。譬如,注意設計文檔的維護,對工作中遇到的問題的記錄,過往經驗的 及時記錄,適當的軟件開發流程等等。文檔工作,可能很多人很不願意去做,它的確很花費時間。不過,唉。。。老啦,好記性不如爛筆頭啊   8 )。 當然,其實設計文檔更多的是爲你提供思考的機會,而過往經驗的總結,也可以起到和大家交流技術,共同進步的目的。
 

英語

    這個也是必須的啦,沒有辦法,郵件列表,技術文檔,社 區,精通英語肯定是很大的優勢,做開源項目尤其如此。閱讀各種Spec標準文檔之類的速度還是很重要的。閱讀無障礙是一回事,能和母語一樣一目十行,那才 爽呀,唉,人生苦短,效率啊!光讀文檔,就不知道要比老外多花多少時間。。。。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章