<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

嵌入式思想與PC思想結合

STM32嵌入式開發 ? 來源:CSDN-coolbacon ? 2023-05-10 10:42 ? 次閱讀

能從PC機器編程去看嵌入式問題,那是第一步;

學會用嵌入式編程思想,那是第二步;

用PC的思想和嵌入式的思想結合在一起,應用于實際的項目,那是第三步。

很多朋友都是從PC編程轉向嵌入式編程的。

在中國,嵌入式編程的朋友很少是正兒八經從計算機專業畢業的,都是從自動控制啊,電子相關的專業畢業的。

這些童鞋們,實踐經驗雄厚,但是理論知識缺乏;計算機專業畢業的童鞋很大一部分去弄網游、網頁這些獨立于操作系統的更高層的應用了。

也不太愿意從事嵌入式行業,畢竟這條路不好走。他們理論知識雄厚,但缺乏電路等相關的知識,在嵌入式里學習需要再學習一些具體的知識,比較難走。

雖然沒有做過產業調查,但從我所見和所招聘人員,從事嵌入式行業的工程師,要么缺乏理論知識,要么缺乏實踐經驗。

很少兩者兼備的。究其原因,還是中國的大學教育的問題。這里不探討這個問題,避免口水戰。我想列出我實踐中的幾個例子。引起大家在嵌入式中做項目時對一些問題的關注。

第一個例子:

同事在uC/OS-II下開發一個串口的驅動程序,驅動和接口在測試中均為發現問題。應用中開發了個通訊程序,串口驅動提供了一個查詢驅動緩沖區字符的函數:GetRxBuffCharNum()。

高層需要接受一定數量的字符以后才能對包做解析。一個同事撰寫的代碼,用偽代碼表示如下:

00118dc6-ee49-11ed-90ce-dac502259ad0.png

這段代碼判斷當前緩沖區中超過30個字符,就將緩沖區中全部字符讀到緩沖區中,直到讀取成功為止。

邏輯清楚,思路也清楚。但這段代碼是不能正常工作。如果是在PC機上,定然是沒有任何問題,工作的異常正常。但在嵌入式里真的是不得而知了。同事很郁悶,不知道為什么。

來請我解決問題,當時我看到代碼,就問了他,GetRxBuffCharNum()是怎么實現的?打開一看:

0024346c-ee49-11ed-90ce-dac502259ad0.png

很明顯,由于在循環中,interruput_disable()和interrupt_enable()之間是個全局臨界區域,保證gRxBufCharNum的完整性。

但是,由于在外層的do { } while() 循環中,CPU頻繁的關閉中斷,打開中斷,這個時間非常的短。

實際上CPU可能不能正常的響應UART的中斷。當然這和uart的波特率、硬件緩沖區的大小還有CPU的速度都有關系。我們使用的波特率非常高,大約有3Mbps。

uart起始信號和停止信號占一個比特位。一個字節需要消耗10個周期。3Mbps的波特率大約需要3.3us傳輸一個字節。

3.3us能執行多少個CPU指令呢?

100MHz的ARM,大約能執行150條指令左右。結果關閉中斷的時間是多長呢?一般ARM關閉中斷都需要4條以上的指令,打開又有4條以上的指令。

接收uart中斷的代碼實際上是不止20條指令的。所以,這樣下來,就有可能出現丟失通信數據的Bug,體現在系統層面上,就是通信不穩定。

修改這段代碼其實很簡單,最簡單的辦法是從高層修改。即:

003e07e8-ee49-11ed-90ce-dac502259ad0.png

這樣,讓CPU有時間去執行中斷的代碼,從而避免了頻繁關閉中斷造成的中斷代碼執行不及時,產生的信息丟失。

嵌入式系統里,大部分的RTOS應用都是不帶串口驅動。 自己設計代碼時,沒有充分考慮代碼與內核的結合。 造成代碼深層次的問題。

RTOS之所以稱為RTOS,就是因為對事件的快速響應; 事件快速的響應依賴于CPU對中斷的響應速度。

驅動在Linux這種系統中都是與內核高度整合,一起運行在內核態。 RTOS雖然不能抄襲linux這種結構,但有一定的借鑒意義。

從上面的例子可以看清楚,嵌入式需要開發人員對代碼的各個環節需要了解清楚。

第二個例子:

同事驅動一個14094串轉并的芯片。 串行信號是采用IO模擬的,因為沒有專用的硬件。 同事就隨手寫了個驅動,結果調試了3、4天,仍舊是有問題。

我實在看不下去了,就去看了看,控制的并行信號有時候正常有時候不正常。 我看了看代碼,用偽代碼大概是:

005499a4-ee49-11ed-90ce-dac502259ad0.png

將數據的8個bit在每個高電平從bit0到bit7依次發送出去。 應該是正常的啊。 看不出問題在哪啊?

我仔細想了想,有看了14094的datasheet,明白了。

原來,14094要求clock的高電平持續10個ns,低電平也要持續10個ns。 這段代碼之做了高電平時間的延時,沒有做低電平的延時。 如果中斷插在低電平之間工作,那么這段代碼是可以的。

但是如果CPU沒有中斷插在低電平時執行,則是不能正常工作的。 所以就時好時壞。

修改也比較簡單:

0069f1b4-ee49-11ed-90ce-dac502259ad0.png

這樣就完全正常了。 但是這個還是不能很好移植的一個代碼,因為編譯器一優化,就有可能造成這兩個延時循環的丟失。

丟失了,就不能保證高電平低電平持續10ns的要求,也就不能正常工作了。

所以,真正的可以移植的代碼,應該把這個循環做成一個納秒級的DelayNs(10);

像Linux一樣,上電時,先測量一下,nop指令執行需要多長時間執行,多少個nop指令執行10ns。

執行一定的nop指令就可以了。利用編譯器防止優化的編譯指令或者特殊的關鍵字,防止延時循環被編譯器優化掉。如GCC中的

__volatile__ __asm__("nop; ");

從這個例子中可以清楚的看到,寫好一段好代碼,是需要很多知識支撐的。你說呢?

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5001

    文章

    18414

    瀏覽量

    291400
  • 接口
    +關注

    關注

    33

    文章

    7859

    瀏覽量

    148967
  • PC
    PC
    +關注

    關注

    9

    文章

    1976

    瀏覽量

    152991
  • 計算機
    +關注

    關注

    19

    文章

    6757

    瀏覽量

    85269
  • 編程
    +關注

    關注

    88

    文章

    3450

    瀏覽量

    92692

原文標題:嵌入式思想與PC思想結合

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    深入了解嵌入式編程

    能從PC機器編程去看嵌入式問題,那是第一步;學會用嵌入式編程思想,那是第二步;用PC思想
    的頭像 發表于 10-18 09:56 ?3421次閱讀

    嵌入式編程項目需要的注意事項

    能從PC機器編程去看嵌入式問題,那是第一步;學會用嵌入式編程思想,那是第二步;用PC思想
    發表于 12-23 10:40 ?570次閱讀

    嵌入式軟件設計之思想與方法

    本帖最后由 lee_st 于 2018-2-24 17:16 編輯 嵌入式軟件設計之思想與方法
    發表于 02-24 17:15

    嵌入式軟件和PC結合

    隨著移動互聯網應用漸漸走熱,Inel 嵌入式X86芯片重返市場,傳統的嵌入式系統平臺、軟件開發方式和操作系統都在發生著變化。一個方面,互聯網需要更多已經在PC使用的應用軟件,能夠在各種移動終端
    發表于 07-16 06:44

    怎么利用分層思想進行嵌入式項目設計

    利用分層思想進行嵌入式項目設計,你試過嗎?
    發表于 05-22 10:16

    嵌入式開發必須掌握的設計思想?

    嵌入式開發重要的2個設計思想
    發表于 03-09 07:02

    中間件思想嵌入式GIS設計中有哪些應用?

    中間件是什么?有什么作用?中間件應用現狀及未來發展趨勢如何?中間件思想嵌入式GIS設計中有哪些應用?
    發表于 04-27 07:05

    嵌入式系統相比較PC機有何優勢

    來源:ittbank首先,“嵌入式”這是個概念,準確的定義沒有,各個書上都有各自的定義。但是主要思想是一樣的,就是相比較PC機這種通用系統來說,嵌入式系統是個專用系統,結構精簡,在硬件
    發表于 11-23 08:53

    嵌入式系統硬件抽象層的設計思想簡析

    嵌入式系統硬件抽象層(HAL & BSP)的設計思想1 前言1.1 層次化思想1.2 模塊化思想1.3 對象化思想2 板級支持包(BSP)3
    發表于 02-11 07:49

    中間件思想嵌入式GIS設計中的應用

    介紹中間件的基本概念,包括中間件的定義、特點、應用現狀及未來發展趨勢。在此基礎上,針對嵌入式地理信息系統,給出如何將中間件思想應用在該系統設計上,以滿足系統能
    發表于 04-15 11:17 ?14次下載

    中間件思想嵌入式GIS 設計中的應用

    介紹中間件的基本概念,包括中間件的定義、特點、應用現狀及未來發展趨勢。在此基礎上,針對嵌入式地理信息系統,給出如何將中間件思想應用在該系統設計上,以滿足系統能
    發表于 05-15 15:45 ?14次下載

    嵌入式開發的2個設計思想

    筆者參考了市面上各種各樣的嵌入式書籍,如MCS-51、AVR、ARM等都有看過,但沒發現有哪本是介紹設計思想的,就算有也是鳳毛麟角。寫程序不難,但如何寫得好、寫得快,那是需要點經驗積累的。所以在
    的頭像 發表于 02-10 11:42 ?596次閱讀
    做<b class='flag-5'>嵌入式</b>開發的2個設計<b class='flag-5'>思想</b>

    嵌入式開發,這2個設計思想要掌握!

    筆者參考了市面上各種各樣的嵌入式書籍,如MCS-51、AVR、ARM等都有看過,但沒發現有哪本是介紹設計思想的,就算有也是鳳毛麟角。寫程序不難,但如何寫得好、寫得快,那是需要點經驗積累的。所以在
    發表于 02-26 06:01 ?11次下載
    做<b class='flag-5'>嵌入式</b>開發,這2個設計<b class='flag-5'>思想</b>要掌握!

    嵌入式開發,這2個設計思想要掌握!

    筆者參考了市面上各種各樣的嵌入式書籍,如MCS-51、AVR、ARM等都有看過,但沒發現有哪本是介紹設計思想的,就算有也是鳳毛麟角。寫程序不難,但如何寫得好、寫得快,那是需要點經驗積累的。...
    發表于 01-14 09:59 ?5次下載
    做<b class='flag-5'>嵌入式</b>開發,這2個設計<b class='flag-5'>思想</b>要掌握!

    怎么從PC編程轉向嵌入式編程

    能從PC機器編程去看嵌入式問題,那是第一步; 學會用嵌入式編程思想,那是第二步; 用PC思想
    的頭像 發表于 06-22 10:36 ?469次閱讀
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>