• 招生咨詢熱線:4008-569-579 
  • 手機(jī)版
    用手機(jī)掃描二維碼直達(dá)商品手機(jī)版
招生咨詢熱線
4008-569-579
機(jī)構(gòu)主頁(yè) > 培訓(xùn)資料 > 嵌入式開(kāi)發(fā):在沒(méi)有硬件的情況下開(kāi)發(fā)軟件需要注意什么?
機(jī)構(gòu)主頁(yè) > 培訓(xùn)資料>嵌入式開(kāi)發(fā):在沒(méi)有硬件的情況下開(kāi)發(fā)軟件需要注意什么?

嵌入式開(kāi)發(fā):在沒(méi)有硬件的情況下開(kāi)發(fā)軟件需要注意什么?

來(lái)源:廣州達(dá)內(nèi)教育        時(shí)間:2023-05-30        熱度:24℃        返回列表

  嵌入式開(kāi)發(fā)人員傳統(tǒng)上以硬件為中心,認(rèn)為沒(méi)有硬件他們就無(wú)法前進(jìn)(有時(shí)這是真的)。在今天的帖子中,我們將探討開(kāi)發(fā)人員在沒(méi)有硬件的情況下開(kāi)發(fā)軟件所需的思維方式轉(zhuǎn)變。


  以應(yīng)用為中心的開(kāi)發(fā)


  在當(dāng)今的現(xiàn)代開(kāi)發(fā)周期中,嵌入式開(kāi)發(fā)人員需要做出的第一個(gè)思維轉(zhuǎn)變是沒(méi)有硬件。我們不是從硬件開(kāi)始,然后一路向上,而是將注意力和開(kāi)發(fā)重點(diǎn)放在應(yīng)用程序上。開(kāi)發(fā)人員應(yīng)該關(guān)注應(yīng)用程序功能、它們之間的關(guān)系以及它們操作的數(shù)據(jù)。


  專(zhuān)注于應(yīng)用程序而不是硬件具有幾個(gè)主要優(yōu)勢(shì)。首先,它將開(kāi)發(fā)人員的注意力轉(zhuǎn)移到應(yīng)用程序功能上。其次,以應(yīng)用程序?yàn)橹攸c(diǎn),開(kāi)發(fā)人員可以識(shí)別各種功能所需的數(shù)據(jù)作為輸入和輸出,以及這些數(shù)據(jù)如何在應(yīng)用程序中流動(dòng)。這種對(duì)數(shù)據(jù)的關(guān)注具有抽象和消除硬件依賴性的額外好處!最后,以應(yīng)用程序?yàn)橹行牡拈_(kāi)發(fā)允許我們?cè)跊](méi)有硬件的情況下模擬、建模和測(cè)試我們的應(yīng)用程序代碼。這為我們提供了創(chuàng)建自動(dòng)化回歸測(cè)試、最小化目標(biāo)調(diào)試時(shí)間和在

PC 環(huán)境中測(cè)試我們的應(yīng)用程序的能力,這比在目標(biāo)環(huán)境中更容易工作。


  沒(méi)有按鈕!


  讓我們看一個(gè)簡(jiǎn)單的例子。嵌入式開(kāi)發(fā)人員經(jīng)常需要編寫(xiě)一個(gè)可以消除開(kāi)關(guān)抖動(dòng)的函數(shù)。傳統(tǒng)上,開(kāi)發(fā)人員會(huì)定期調(diào)用他們的

debounce 函數(shù),該函數(shù)將讀取 GPIO 線,然后運(yùn)行 debounce

算法。這里的問(wèn)題是去抖動(dòng)功能直接依賴于硬件!如果GPIO線發(fā)生變化,需要更新功能!將硬件更改為新的微控制器,該功能需要使用新的 GPIO

驅(qū)動(dòng)程序調(diào)用進(jìn)行更新。對(duì)功能進(jìn)行單元測(cè)試感興趣?這要困難得多,因?yàn)樵摴δ苋Q于硬件。


  顯然,這不是一個(gè)很好的解決方案,即使我們一直這樣編寫(xiě)代碼!相反,我們需要認(rèn)識(shí)到?jīng)]有按鈕!只有數(shù)據(jù)包含代表按鈕的狀態(tài)。按鈕去抖功能應(yīng)該采用代表當(dāng)前開(kāi)關(guān)狀態(tài)的參數(shù),而不是讓去抖開(kāi)關(guān)直接訪問(wèn)

GPIO

硬件。這將功能與硬件解耦,并允許在沒(méi)有硬件的情況下對(duì)功能進(jìn)行完全測(cè)試!只需傳入數(shù)據(jù)以測(cè)試開(kāi)關(guān)去抖算法是否正常工作!這也意味著我們可以構(gòu)建回歸測(cè)試!




  設(shè)計(jì)無(wú)硬件系統(tǒng)


  一般來(lái)說(shuō),嵌入式開(kāi)發(fā)人員可以遵循幾個(gè)步驟來(lái)編寫(xiě)他們的應(yīng)用程序代碼,從而打破他們的硬件依賴關(guān)系。


  首先,識(shí)別硬件生成或使用的數(shù)據(jù)。該數(shù)據(jù)將成為傳遞給應(yīng)用程序功能函數(shù)的參數(shù)。對(duì)于 debounce 示例,這只不過(guò)是

ButtonState。函數(shù)原型可能如下所示:


  bool Button_Debounce(ButtonState_t const

ButtonState);


  接下來(lái),創(chuàng)建一個(gè)可用于獲取硬件狀態(tài)的抽象。 在 PC 上運(yùn)行時(shí),此功能將僅鏈接到可以模擬硬件的數(shù)據(jù)生成器。

當(dāng)硬件存在時(shí),該函數(shù)鏈接到返回硬件狀態(tài)的 GPIO 驅(qū)動(dòng)程序。 這使開(kāi)發(fā)人員可以在有或沒(méi)有硬件的情況下進(jìn)行操作。

這將導(dǎo)致應(yīng)用程序代碼如下所示:


  bool ButtonDebounced = false;


  ButtonState_t ButtonState = Button_StateGet();


  ButtonDebounced = Button_Debounce(ButtonState);


  最后,還可以進(jìn)行抽象以將數(shù)據(jù)發(fā)布到硬件。這對(duì)于去抖動(dòng)算法來(lái)說(shuō)不是必需的,但如果應(yīng)用程序組件要控制

LED、閥門(mén)、電機(jī)等,則可能是必需的。這再次允許開(kāi)發(fā)人員在 PC 或硬件上運(yùn)行應(yīng)用程序之間切換 .


  結(jié)論


  希望提高代碼穩(wěn)健性、降低總體成本和縮短上市時(shí)間的嵌入式開(kāi)發(fā)人員可以從編寫(xiě)沒(méi)有硬件的應(yīng)用程序代碼中受益匪淺。這并不總是可行或值得的,但對(duì)于許多現(xiàn)代系統(tǒng)來(lái)說(shuō),這是一種可以顯著改進(jìn)系統(tǒng)設(shè)計(jì)的技術(shù)。它的好處是使應(yīng)用程序易于測(cè)試,并最大限度地減少了在目標(biāo)上調(diào)試所花費(fèi)的時(shí)間。

電話咨詢

電話咨詢

咨詢電話:
4008-569-579
回到頂部

回到頂部