在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

嵌入式思想與PC思想結(jié)合

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

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

學(xué)會(huì)用嵌入式編程思想,那是第二步;

用PC的思想和嵌入式的思想結(jié)合在一起,應(yīng)用于實(shí)際的項(xiàng)目,那是第三步。

很多朋友都是從PC編程轉(zhuǎn)向嵌入式編程的。

在中國,嵌入式編程的朋友很少是正兒八經(jīng)從計(jì)算機(jī)專業(yè)畢業(yè)的,都是從自動(dòng)控制啊,電子相關(guān)的專業(yè)畢業(yè)的。

這些童鞋們,實(shí)踐經(jīng)驗(yàn)雄厚,但是理論知識(shí)缺乏;計(jì)算機(jī)專業(yè)畢業(yè)的童鞋很大一部分去弄網(wǎng)游、網(wǎng)頁這些獨(dú)立于操作系統(tǒng)的更高層的應(yīng)用了。

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

雖然沒有做過產(chǎn)業(yè)調(diào)查,但從我所見和所招聘人員,從事嵌入式行業(yè)的工程師,要么缺乏理論知識(shí),要么缺乏實(shí)踐經(jīng)驗(yàn)。

很少兩者兼?zhèn)涞摹>科湓颍€是中國的大學(xué)教育的問題。這里不探討這個(gè)問題,避免口水戰(zhàn)。我想列出我實(shí)踐中的幾個(gè)例子。引起大家在嵌入式中做項(xiàng)目時(shí)對(duì)一些問題的關(guān)注。

第一個(gè)例子:

同事在uC/OS-II下開發(fā)一個(gè)串口的驅(qū)動(dòng)程序,驅(qū)動(dòng)和接口在測(cè)試中均為發(fā)現(xiàn)問題。應(yīng)用中開發(fā)了個(gè)通訊程序,串口驅(qū)動(dòng)提供了一個(gè)查詢驅(qū)動(dòng)緩沖區(qū)字符的函數(shù):GetRxBuffCharNum()。

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

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

這段代碼判斷當(dāng)前緩沖區(qū)中超過30個(gè)字符,就將緩沖區(qū)中全部字符讀到緩沖區(qū)中,直到讀取成功為止。

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

來請(qǐng)我解決問題,當(dāng)時(shí)我看到代碼,就問了他,GetRxBuffCharNum()是怎么實(shí)現(xiàn)的?打開一看:

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

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

但是,由于在外層的do { } while() 循環(huán)中,CPU頻繁的關(guān)閉中斷,打開中斷,這個(gè)時(shí)間非常的短。

實(shí)際上CPU可能不能正常的響應(yīng)UART的中斷。當(dāng)然這和uart的波特率、硬件緩沖區(qū)的大小還有CPU的速度都有關(guān)系。我們使用的波特率非常高,大約有3Mbps。

uart起始信號(hào)和停止信號(hào)占一個(gè)比特位。一個(gè)字節(jié)需要消耗10個(gè)周期。3Mbps的波特率大約需要3.3us傳輸一個(gè)字節(jié)。

3.3us能執(zhí)行多少個(gè)CPU指令呢?

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

接收uart中斷的代碼實(shí)際上是不止20條指令的。所以,這樣下來,就有可能出現(xiàn)丟失通信數(shù)據(jù)的Bug,體現(xiàn)在系統(tǒng)層面上,就是通信不穩(wěn)定。

修改這段代碼其實(shí)很簡(jiǎn)單,最簡(jiǎn)單的辦法是從高層修改。即:

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

這樣,讓CPU有時(shí)間去執(zhí)行中斷的代碼,從而避免了頻繁關(guān)閉中斷造成的中斷代碼執(zhí)行不及時(shí),產(chǎn)生的信息丟失。

嵌入式系統(tǒng)里,大部分的RTOS應(yīng)用都是不帶串口驅(qū)動(dòng)。 自己設(shè)計(jì)代碼時(shí),沒有充分考慮代碼與內(nèi)核的結(jié)合。 造成代碼深層次的問題。

RTOS之所以稱為RTOS,就是因?yàn)閷?duì)事件的快速響應(yīng); 事件快速的響應(yīng)依賴于CPU對(duì)中斷的響應(yīng)速度。

驅(qū)動(dòng)在Linux這種系統(tǒng)中都是與內(nèi)核高度整合,一起運(yùn)行在內(nèi)核態(tài)。 RTOS雖然不能抄襲linux這種結(jié)構(gòu),但有一定的借鑒意義。

從上面的例子可以看清楚,嵌入式需要開發(fā)人員對(duì)代碼的各個(gè)環(huán)節(jié)需要了解清楚。

第二個(gè)例子:

同事驅(qū)動(dòng)一個(gè)14094串轉(zhuǎn)并的芯片。 串行信號(hào)是采用IO模擬的,因?yàn)闆]有專用的硬件。 同事就隨手寫了個(gè)驅(qū)動(dòng),結(jié)果調(diào)試了3、4天,仍舊是有問題。

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

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

將數(shù)據(jù)的8個(gè)bit在每個(gè)高電平從bit0到bit7依次發(fā)送出去。 應(yīng)該是正常的啊。 看不出問題在哪啊?

我仔細(xì)想了想,有看了14094的datasheet,明白了。

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

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

修改也比較簡(jiǎn)單:

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

這樣就完全正常了。 但是這個(gè)還是不能很好移植的一個(gè)代碼,因?yàn)榫幾g器一優(yōu)化,就有可能造成這兩個(gè)延時(shí)循環(huán)的丟失。

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

所以,真正的可以移植的代碼,應(yīng)該把這個(gè)循環(huán)做成一個(gè)納秒級(jí)的DelayNs(10);

像Linux一樣,上電時(shí),先測(cè)量一下,nop指令執(zhí)行需要多長時(shí)間執(zhí)行,多少個(gè)nop指令執(zhí)行10ns。

執(zhí)行一定的nop指令就可以了。利用編譯器防止優(yōu)化的編譯指令或者特殊的關(guān)鍵字,防止延時(shí)循環(huán)被編譯器優(yōu)化掉。如GCC中的

__volatile__ __asm__("nop; ");

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

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5143

    文章

    19563

    瀏覽量

    315502
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    8961

    瀏覽量

    153301
  • PC
    PC
    +關(guān)注

    關(guān)注

    9

    文章

    2144

    瀏覽量

    156121
  • 計(jì)算機(jī)
    +關(guān)注

    關(guān)注

    19

    文章

    7636

    瀏覽量

    90296
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3685

    瀏覽量

    94933

原文標(biāo)題:嵌入式思想與PC思想結(jié)合

文章出處:【微信號(hào):c-stm32,微信公眾號(hào):STM32嵌入式開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    深入了解嵌入式編程

    能從PC機(jī)器編程去看嵌入式問題,那是第一步;學(xué)會(huì)用嵌入式編程思想,那是第二步;用PC思想
    的頭像 發(fā)表于 10-18 09:56 ?3887次閱讀

    嵌入式編程項(xiàng)目需要的注意事項(xiàng)

    能從PC機(jī)器編程去看嵌入式問題,那是第一步;學(xué)會(huì)用嵌入式編程思想,那是第二步;用PC思想
    發(fā)表于 12-23 10:40 ?786次閱讀

    嵌入式軟件設(shè)計(jì)之思想與方法

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

    嵌入式軟件和PC結(jié)合

    隨著移動(dòng)互聯(lián)網(wǎng)應(yīng)用漸漸走熱,Inel 嵌入式X86芯片重返市場(chǎng),傳統(tǒng)的嵌入式系統(tǒng)平臺(tái)、軟件開發(fā)方式和操作系統(tǒng)都在發(fā)生著變化。一個(gè)方面,互聯(lián)網(wǎng)需要更多已經(jīng)在PC使用的應(yīng)用軟件,能夠在各種移動(dòng)終端
    發(fā)表于 07-16 06:44

    怎么利用分層思想進(jìn)行嵌入式項(xiàng)目設(shè)計(jì)

    利用分層思想進(jìn)行嵌入式項(xiàng)目設(shè)計(jì),你試過嗎?
    發(fā)表于 05-22 10:16

    嵌入式開發(fā)必須掌握的設(shè)計(jì)思想

    嵌入式開發(fā)重要的2個(gè)設(shè)計(jì)思想
    發(fā)表于 03-09 07:02

    中間件思想嵌入式GIS設(shè)計(jì)中有哪些應(yīng)用?

    中間件是什么?有什么作用?中間件應(yīng)用現(xiàn)狀及未來發(fā)展趨勢(shì)如何?中間件思想嵌入式GIS設(shè)計(jì)中有哪些應(yīng)用?
    發(fā)表于 04-27 07:05

    嵌入式系統(tǒng)硬件抽象層的設(shè)計(jì)思想簡(jiǎn)析

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

    中間件思想嵌入式GIS設(shè)計(jì)中的應(yīng)用

    介紹中間件的基本概念,包括中間件的定義、特點(diǎn)、應(yīng)用現(xiàn)狀及未來發(fā)展趨勢(shì)。在此基礎(chǔ)上,針對(duì)嵌入式地理信息系統(tǒng),給出如何將中間件思想應(yīng)用在該系統(tǒng)設(shè)計(jì)上,以滿足系統(tǒng)能
    發(fā)表于 04-15 11:17 ?14次下載

    中間件思想嵌入式GIS 設(shè)計(jì)中的應(yīng)用

    介紹中間件的基本概念,包括中間件的定義、特點(diǎn)、應(yīng)用現(xiàn)狀及未來發(fā)展趨勢(shì)。在此基礎(chǔ)上,針對(duì)嵌入式地理信息系統(tǒng),給出如何將中間件思想應(yīng)用在該系統(tǒng)設(shè)計(jì)上,以滿足系統(tǒng)能
    發(fā)表于 05-15 15:45 ?14次下載

    基于AVR單片機(jī)的嵌入式“瘦服務(wù)器”系統(tǒng)設(shè)計(jì)思想

    基于AVR單片機(jī)的嵌入式“瘦服務(wù)器”系統(tǒng)設(shè)計(jì)思想 根據(jù)國內(nèi)嵌入式設(shè)備的研究形勢(shì)和產(chǎn)業(yè)發(fā)展規(guī)模,提出了基于AVR單片機(jī)(ATmega103)的嵌入式 “瘦
    發(fā)表于 05-04 22:10 ?962次閱讀
    基于AVR單片機(jī)的<b class='flag-5'>嵌入式</b>“瘦服務(wù)器”系統(tǒng)設(shè)計(jì)<b class='flag-5'>思想</b>

    嵌入式開發(fā)的2個(gè)設(shè)計(jì)思想

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

    嵌入式開發(fā),這2個(gè)設(shè)計(jì)思想要掌握!

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

    嵌入式系統(tǒng)硬件抽象層(HAL & BSP)的設(shè)計(jì)思想--第一部分

    嵌入式系統(tǒng)硬件抽象層(HAL & BSP)的設(shè)計(jì)思想1 前言1.1 層次化思想1.2 模塊化思想1.3 對(duì)象化思想2 板級(jí)支持包(B
    發(fā)表于 12-08 12:06 ?13次下載
    <b class='flag-5'>嵌入式</b>系統(tǒng)硬件抽象層(HAL & BSP)的設(shè)計(jì)<b class='flag-5'>思想</b>--第一部分

    怎么從PC編程轉(zhuǎn)向嵌入式編程

    能從PC機(jī)器編程去看嵌入式問題,那是第一步; 學(xué)會(huì)用嵌入式編程思想,那是第二步; 用PC思想
    的頭像 發(fā)表于 06-22 10:36 ?1068次閱讀
    主站蜘蛛池模板: 九九免费久久这里有精品23 | 亚洲毛片网 | 免费播放黄色 | 亚洲网站免费 | 欧美成人性动漫在线观看 | 国产亚洲精品久久久久久牛牛 | bt种子磁力天堂torrent | 欧美日韩一区二区三区毛片 | 国产免费高清视频在线观看不卡 | 精品手机在线视频 | 色四月婷婷 | 五月婷婷丁香在线 | 狠狠操天天操夜夜操 | 黄页网站视频免费 视频 | 日本xxx69hd | 中文字幕在线乱码免费毛片 | 日本国产在线观看 | 久久亚洲aⅴ精品网站婷婷 久久亚洲成人 | 国模鲍鱼| 黑人干亚洲 | 日本精品一在线观看视频 | 国产香蕉免费精品视频 | 国产精品免费观看网站 | 中文字幕亚洲一区婷婷 | 亚洲 欧洲 日韩 | 黄视频免费在线观看 | 婷婷激情狠狠综合五月 | 海棠高h粗暴调教双性男男 韩国韩宝贝2020vip福利视频 | 色依依视频视频在线观看 | 天天做天天添婷婷我也去 | 婷婷视频网 | 伊人久久亚洲综合天堂 | 日本精品卡一卡2卡3卡四卡三卡 | 午夜日本一区二区三区 | 日韩三级免费观看 | 淫婷婷 | 中文字幕在线观看一区二区三区 | 四虎国产视频 | 夜夜夜夜操 | 色多多拼多多网站 | 在线观看亚洲免费视频 |