色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

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

科技綠洲 ? 來源:一起學嵌入式 ? 作者:一起學嵌入式 ? 2023-06-22 10:36 ? 次閱讀

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

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

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

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

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

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

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

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

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

第一個例子:

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

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

![圖片](https://mmbiz.qpic.cn/mmbiz_png/K9mVOHgVt7xewibMy12Xyg6ahGaXF216WBnC60QicfdbvYtZu2nfxeUzyeyibW5yvCfrRGUIJ0HV0SmNS5oCjdvqg/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1)

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

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

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

![圖片](https://mmbiz.qpic.cn/mmbiz_png/K9mVOHgVt7xewibMy12Xyg6ahGaXF216WDOcJiao8ibNdDFYvpZ4zzvC5x03IoFOFV81mjLTUDBuDFzFznPTGiacFQ/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1)

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

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

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

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

通過分析波形,透徹理解 UART 通信

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

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

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

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

![圖片](https://mmbiz.qpic.cn/mmbiz_png/K9mVOHgVt7xewibMy12Xyg6ahGaXF216Wvvn6bP7CGoPX9bwaSkA4gfcJCnhLAKiaIVvg63icGlliaUIsbYMmGzsMA/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1)

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

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

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

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

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

第二個例子:

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

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

![圖片](https://mmbiz.qpic.cn/mmbiz_png/K9mVOHgVt7xewibMy12Xyg6ahGaXF216Wf7ZeC3OdVhMeXweiaLZDfVicgrMxmF4L8yiaB1Av1eEbz7cTFibJ8A7u0w/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1)

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

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

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

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

修改也比較簡單:

![圖片](https://mmbiz.qpic.cn/mmbiz_png/K9mVOHgVt7xewibMy12Xyg6ahGaXF216WcA5Y7oOoAPbTxWCnhNZUjMP3kGgtD9SKfPnVBlCOfExwVpRvCJYfBA/640?wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1)

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

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

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

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

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

volatile asm ("nop;\\n");

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

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

    關注

    9

    文章

    2123

    瀏覽量

    155143
  • 編程
    +關注

    關注

    88

    文章

    3649

    瀏覽量

    94344
  • 嵌入式編程
    +關注

    關注

    0

    文章

    27

    瀏覽量

    10435
收藏 人收藏

    評論

    相關推薦

    深入了解嵌入式編程

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

    嵌入式編程PC編程,不同點有多少?

    嵌入式編程的朋友很少是正兒八經計算機專業畢業的,都是自動控制啊,電子相關的專業畢業的。這些童鞋們,實踐經驗雄厚,但是理論知識缺乏
    的頭像 發表于 12-27 06:06 ?6250次閱讀

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

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

    閑談嵌入式編程的復雜性

    能從PC機器編程去看嵌入式問題,那是第一步;學會用嵌入式編程思想,那是第二步;用PC的思想和
    發表于 04-05 14:26

    【我是電子發燒友】嵌入式編程PC編程有何區別?

    能從PC機器編程去看嵌入式問題,那是第一步;學會用嵌入式編程思想,那是第二步;用PC的思想和
    發表于 04-27 10:50

    [轉]閑談嵌入式編程的復雜性

    `緒論:能從PC機器編程去看嵌入式問題,那是第一步;學會用嵌入式編程思想,那是第二步;用PC的思
    發表于 08-13 10:25

    嵌入式學習由淺入深的必經之路

    的復雜性能從PC機器編程去看嵌入式問題,那是第一步;學會用嵌入式編程思想,那是第二步;用PC的思
    發表于 08-21 14:55

    項目出發,分析嵌入式編程PC機器編程的不同

    第一步;學會用嵌入式編程思想,那是第二步;用PC的思想和嵌入式的思想結合在一起,應用于實際的項目,那是第三步。很多朋友都是
    發表于 12-11 17:36

    嵌入式編程PC編程的區別在哪

    在中國,嵌入式編程的朋友很少是正兒八經計算機專業畢業的,都是自動控制啊,電子相關的專業畢業的。這些童鞋們,實踐經驗雄厚,但是理論知識缺乏;計算機專業畢業的童鞋很大一部分去弄網游、網
    發表于 10-28 09:30

    什么是嵌入式編程

    《C嵌入式編程設計模式》第一章 什么是嵌入式編程嵌入式系統的基本知識面向對象編程與結構化
    發表于 11-08 06:15

    嵌入式C編程

    嵌入式C編程,非常有用的資料,介紹嵌入式C語言編程
    發表于 12-29 17:29 ?0次下載

    什么是嵌入式編程

    什么是嵌入式編程?對于嵌入式系統,許多人很容易將它與單片機編程混淆。其實,嵌入式編程指的是在我們
    發表于 06-29 11:05 ?1.1w次閱讀
    什么是<b class='flag-5'>嵌入式</b><b class='flag-5'>編程</b>

    嵌入式編程PC編程究竟有何區別?

    在中國,嵌入式編程的朋友很少是正兒八經計算機專業畢業的,都是自動控制啊,電子相關的專業畢業的。這些童鞋們,實踐經驗雄厚,但是理論知識缺乏;計算機專業畢業的童鞋很大一部分去弄網游、網
    發表于 10-21 12:36 ?1次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>編程</b>和<b class='flag-5'>PC</b><b class='flag-5'>編程</b>究竟有何區別?

    嵌入式C++編程

    特點展示如何使用 C ++ 來構建利用可用硬件資源的強大并發系統。嵌入式編程入門和 C ++ 17 的最新特性開始,帶您了解優秀編程的各個方面您將學習如何使用 C ++ 的并發性、內
    發表于 11-04 10:36 ?10次下載
    <b class='flag-5'>嵌入式</b>C++<b class='flag-5'>編程</b>

    淺談嵌入式系統裸機編程的內存管理

     malloc和free在PC編程中是很好用的一種內存分配手段。但是,其在嵌入式中,就未必好用了。由于嵌入式裸機編程中,無MMU,即內存管理
    發表于 09-15 10:38 ?1589次閱讀
    主站蜘蛛池模板: 国精产品一区二区三区有限公司 | bt成人种子 | 手机在线观看你懂的 | 亚洲伊人国产 | 鲁大师影院在线视频在线观看 | 戳女人屁股流水羞羞漫画 | 男生扒开美女尿口戳戳 | 麻豆免费观看高清完整视频 | 国产 亚洲 中文在线 字幕 | 国产午夜在线视频 | 夜夜精品视频一区二区 | 伊人久久精品线影院 | 日本美女bb| 麻豆精品人妻一区二区三区蜜桃 | 精品 在线 视频 亚洲 | 99re精品视频在线播放视频 | 真人做受120分钟免费看 | 1313久久国产午夜精品理论片 | 狠狠人妻久久久久久综合九色 | 94vvv男人的天堂 | 亚洲 日韩经典 中文字幕 | 在线观看视频中文字幕 | 亚洲AV国产国产久青草 | 亚洲第一综合天堂另类专 | 亚洲第一免费播放区 | 国产精品亚洲第一区二区三区 | 色色色五的天 | 蜜桃TV成人网站免费打开 | 色狠狠xx| 欧美手机在线 | 九九热在线观看视频 | 国产成人精品一区二区三区视频 | 国产精品久久久久久久久LI无码 | 成年人视频在线免费观看 | 女教师二十三岁 | 亚洲免费网站观看视频 | 草草久久久无码国产专区全集观看 | 一天不停的插BB十几次 | 哒哒哒影院在线观看免费高清 | 伊人久综合 | 首页_亚洲AV色老汉影院 |