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

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

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

利用AADL架構(gòu)如何實(shí)現(xiàn)嵌入式系統(tǒng)的設(shè)計(jì)

電子設(shè)計(jì) ? 來(lái)源:郭婷 ? 作者:電子設(shè)計(jì) ? 2019-08-19 08:03 ? 次閱讀

在設(shè)計(jì)關(guān)鍵任務(wù)和實(shí)時(shí)性系統(tǒng)時(shí),設(shè)計(jì)師必須滿(mǎn)足功能性要求和非功能性屬性,如性能(吞吐量和服務(wù)質(zhì)量)、保護(hù)、可靠性、時(shí)間緊迫性、安全和容錯(cuò)等,這些系統(tǒng)級(jí)特性具體取決于系統(tǒng)架構(gòu)。隨著嵌入式軟件系統(tǒng)的硬件多樣性和復(fù)雜性的不斷提高,可以采用模型驅(qū)動(dòng)的開(kāi)發(fā)方法來(lái)滿(mǎn)足開(kāi)發(fā)早期階段出現(xiàn)的系統(tǒng)集成問(wèn)題?;谀P偷脑O(shè)計(jì)方法的要點(diǎn)之一是要選擇合適的設(shè)計(jì)語(yǔ)言來(lái)描述具體平臺(tái)架構(gòu)。

為了調(diào)整系統(tǒng)架構(gòu),設(shè)計(jì)語(yǔ)言必須支持多種分析方法以便進(jìn)行跨領(lǐng)域的權(quán)衡,架構(gòu)設(shè)計(jì)語(yǔ)言還必須支持開(kāi)發(fā)過(guò)程中的增量分析以及用于系統(tǒng)評(píng)估的多級(jí)逼真度。這種增量特性允許架構(gòu)規(guī)范在整個(gè)生命周期內(nèi)都有效。

架構(gòu)分析與設(shè)計(jì)語(yǔ)言(AADL)是一種可以滿(mǎn)足這些要求的可擴(kuò)展的標(biāo)準(zhǔn)架構(gòu)描述語(yǔ)言。AADL適合具有挑戰(zhàn)性資源約束(如尺寸、重量和功率)、嚴(yán)格實(shí)時(shí)要求和/或高性能保證等級(jí)的嵌入式系統(tǒng)使用,應(yīng)用場(chǎng)合包括監(jiān)控、航天、飛行管理、引擎和傳動(dòng)系統(tǒng)控制、醫(yī)療設(shè)備、工業(yè)工藝控制設(shè)備和航空等。

AADL是在國(guó)際汽車(chē)工程師協(xié)會(huì)(SAE)的指導(dǎo)下開(kāi)發(fā)的,已經(jīng)于2004年11月被批準(zhǔn)為工業(yè)標(biāo)準(zhǔn)AS5506。為了支持性能分析,AADL定義了時(shí)序語(yǔ)義(semantics);為了支持可靠性分析,它包含了一個(gè)誤差建模附錄,它是AS5506/1標(biāo)準(zhǔn)中所含的更大附錄集的一部分,它能為每個(gè)組件提供誤差模型表述。

與SysML和UML等其他建模語(yǔ)言相比,AADL為標(biāo)準(zhǔn)的軟硬件組件分類(lèi)提供了強(qiáng)大的語(yǔ)義,這樣常用分析方法和良好定義的系統(tǒng)集成就可以根據(jù)這些規(guī)范實(shí)施。專(zhuān)門(mén)為嵌入式系統(tǒng)設(shè)計(jì)的這種語(yǔ)言可以通過(guò)用戶(hù)可定義屬性(獲得AADL編譯器驗(yàn)證的屬性子語(yǔ)言支持)和用戶(hù)定義附錄進(jìn)行擴(kuò)展。附錄擴(kuò)展經(jīng)過(guò)標(biāo)準(zhǔn)化可供業(yè)界廣泛使用。另外,在操作模式幫助下AADL還能支持系統(tǒng)動(dòng)態(tài)建模。

AADL支持基于標(biāo)準(zhǔn)XML/XMI定義的模型交換和工具鏈接。AADL具有標(biāo)準(zhǔn)元模型(meta-model)、圖形定義和文本語(yǔ)言屬性。AADL UML 2.0規(guī)范已經(jīng)開(kāi)發(fā)成功,并已經(jīng)開(kāi)始進(jìn)入投票階段。ARINC 653架構(gòu)的附錄也已開(kāi)始制訂。有許多工具支持這種語(yǔ)言,其中有許多是開(kāi)放源碼的工具。開(kāi)源AADL工具集環(huán)境(OSATE)是很重要的一個(gè)工具,它基于Eclipse框架,包含文本、XML和圖形編輯器以及眾多分析工具。這些工具都是開(kāi)源Eclipse插件,可以進(jìn)行擴(kuò)展。

1 監(jiān)控系統(tǒng)設(shè)計(jì)

在本例中讓我們先看看用戶(hù)的要求:用戶(hù)想要安裝一套監(jiān)控系統(tǒng)來(lái)監(jiān)視遠(yuǎn)離辦公室的三所房屋,在這些位置沒(méi)有現(xiàn)成的局域網(wǎng),為了有效地阻止入侵者,檢測(cè)過(guò)程必須快速,最好在2秒鐘之內(nèi)。這個(gè)延時(shí)標(biāo)準(zhǔn)是一種端到端的系統(tǒng)級(jí)性能要求。

一種解決方案是部署三個(gè)網(wǎng)絡(luò)攝像機(jī)對(duì)這些房子進(jìn)行監(jiān)視。攝像機(jī)通過(guò)無(wú)線方式將信息發(fā)送到辦公室的計(jì)算機(jī)。然而,無(wú)線通信的有限帶寬無(wú)法適應(yīng)全部視頻流數(shù)據(jù),因此我們需要在每個(gè)攝像機(jī)內(nèi)嵌入一個(gè)視頻處理器來(lái)對(duì)數(shù)據(jù)流進(jìn)行壓縮和預(yù)處理,但這樣做會(huì)影響到端到端的延時(shí)。我們必須評(píng)估不同的硬件選擇,例如視頻處理器和無(wú)線芯片。我們也想嘗試多種壓縮和入侵檢測(cè)算法,AADL能讓我們集中精力滿(mǎn)足系統(tǒng)性能要求,從而簡(jiǎn)化這一過(guò)程。

下一步是定義架構(gòu)。AADL圖形符號(hào)有助于實(shí)現(xiàn)這一過(guò)程,如圖1所示。值得注意的是,該模型不是任意設(shè)計(jì)的,而是具有明確定義的正式模型,即使是在較高抽象層次。

利用AADL架構(gòu)如何實(shí)現(xiàn)嵌入式系統(tǒng)的設(shè)計(jì)

系統(tǒng)構(gòu)造可以對(duì)整個(gè)系統(tǒng)和核心子系統(tǒng)(視頻檢測(cè)系統(tǒng))建模。AADL設(shè)備構(gòu)造可以描述物理組件,如視頻攝像機(jī)和顯示器,因?yàn)檫@些組件不需要捆綁應(yīng)用軟件。我們使用端口組和連接來(lái)模擬不同組件之間的通信。攝像機(jī)發(fā)送的數(shù)據(jù)流需要穿過(guò)視頻檢測(cè)系統(tǒng)。

利用AADL架構(gòu)如何實(shí)現(xiàn)嵌入式系統(tǒng)的設(shè)計(jì)

AADL通過(guò)利用層次化結(jié)構(gòu)可以用不同的詳細(xì)程度描述系統(tǒng)。圖2顯示了高層次的監(jiān)控應(yīng)用內(nèi)容。在架構(gòu)建立完成后,我們必須詳細(xì)地定義不同的組件。在介紹詳細(xì)設(shè)計(jì)之前,讓我們先了解一下AADL中的基本單元,軟件單元包括進(jìn)程、線程、線程組、數(shù)據(jù)和子程序。它們分別定義為:

進(jìn)程:受保護(hù)的地址空間

線程:一個(gè)并行執(zhí)行單位

線程組:用于組織線程的復(fù)合單元

數(shù)據(jù):數(shù)據(jù)類(lèi)型和靜態(tài)數(shù)據(jù)

子程序:可調(diào)用的連續(xù)可執(zhí)行代碼

在圖2中,我們使用軟件組件進(jìn)程、數(shù)據(jù)、線程和系統(tǒng)組件對(duì)視頻檢測(cè)系統(tǒng)的邏輯進(jìn)行建模。注意,這種模型只是比圖1所示的內(nèi)容向前邁出了一小步。

硬件組件(也稱(chēng)為平臺(tái)種類(lèi))包括了處理器、存儲(chǔ)器、總線和器件。在圖3中(在AADL結(jié)構(gòu)下方)你可以看到硬件組件的AADL標(biāo)準(zhǔn)圖形描述,它們描述了系統(tǒng)的物理特性。在監(jiān)控系統(tǒng)模型中,硬件平臺(tái)由CPU(處理器)、存儲(chǔ)器和總線確定。

利用AADL架構(gòu)如何實(shí)現(xiàn)嵌入式系統(tǒng)的設(shè)計(jì)

組件抽象包括特性、屬性和模式:特性定義了接口或輸出組件功能;屬性描述了特征和組件行為;模式描述了動(dòng)態(tài)組件重配置。

2 組件之間的交互作用

在定義好組件后,我們需要確定它們之間的關(guān)系,AADL本身就支持這一過(guò)程。組件交互使用端口(數(shù)據(jù)和事件輸入輸出端口)、端口組、子組件(subcomponent)訪問(wèn)、子程序調(diào)用、數(shù)據(jù)交換和共享。它們定義了功能接口和組件之間的通信。在圖2中,我們使用數(shù)據(jù)端口來(lái)描述系統(tǒng)與器件之間的交互。

AADL的一個(gè)關(guān)鍵特性是能對(duì)數(shù)據(jù)建模和流控制。流定義了通過(guò)多個(gè)組件和連接的順序數(shù)據(jù)或事件。在本例中,我們?yōu)槿_(tái)視頻攝像機(jī)規(guī)定了三種視頻流:video_flow1, video_flow2和video_flow3。這些視頻流代表了從攝像機(jī)到顯示器的端到端流動(dòng)。

我們定義這些流是因?yàn)樗鼈冊(cè)谖恢蒙戏珠_(kāi)的。流規(guī)范的目標(biāo)是支持端到端分析,例如端到端時(shí)序和延時(shí),誤碼傳播以及服務(wù)質(zhì)量資源管理等。流的屬性定義了性能特點(diǎn),例如,在監(jiān)控系統(tǒng)中,特殊流屬性一般都會(huì)有最大的延時(shí)。我們需要檢查實(shí)際實(shí)現(xiàn)情況來(lái)確定是否達(dá)到設(shè)計(jì)目標(biāo)。對(duì)于這個(gè)系統(tǒng)中的每個(gè)端到端的流來(lái)講,都有一個(gè)屬性被定義為“期望延時(shí)等于200ms”。

AADL的一個(gè)強(qiáng)大特征是能夠針對(duì)目標(biāo)系統(tǒng)同時(shí)對(duì)硬件和軟件建模,這有助于工程師規(guī)定和評(píng)估完整系統(tǒng)的交互效應(yīng)。在本例中,視頻攝像機(jī)、無(wú)線收發(fā)器和處理器的選擇將直接影響端到端的延時(shí)。

3 完整的系統(tǒng)模型

圖3給出了無(wú)線監(jiān)控系統(tǒng)軟硬件的AADL設(shè)計(jì),系統(tǒng)利用無(wú)線設(shè)備提供的無(wú)線網(wǎng)絡(luò)與攝像機(jī)通信。處理器按調(diào)度屬性執(zhí)行軟件組件,并限定存儲(chǔ)的存儲(chǔ)器。協(xié)議反應(yīng)總線的屬性,并一直反饋到分析工具??梢远x像PCI或VME等不同的總線類(lèi)型,包括這些標(biāo)準(zhǔn)的協(xié)議和性能特性。我們還可以定義定制無(wú)線鏈路,使它對(duì)CSMA/CA無(wú)線鏈路的特性建模。

因?yàn)槲覀兪褂脮r(shí)序語(yǔ)義和流程規(guī)范描述了關(guān)鍵性能特點(diǎn)之一,因此我們可以評(píng)估系統(tǒng)級(jí)性能。還可以逐漸增加其他結(jié)構(gòu)細(xì)節(jié)或?qū)傩?,以擴(kuò)充我們定義關(guān)鍵內(nèi)容時(shí)的分析形式。我們還能在所有開(kāi)發(fā)階段實(shí)施評(píng)估,包括早期結(jié)構(gòu)權(quán)衡分析,開(kāi)發(fā)階段的系統(tǒng)修改和調(diào)整,評(píng)估現(xiàn)有架構(gòu)變化帶來(lái)的影響,以及根據(jù)性能模型的自動(dòng)集成。這樣我們就能使用基于組件的結(jié)構(gòu)規(guī)范進(jìn)行評(píng)估,并對(duì)每個(gè)可能的變化進(jìn)行權(quán)衡。我們可以試驗(yàn)硬件和軟件組件、通信模型、調(diào)度、誤差建模、模式動(dòng)態(tài)特性等,并進(jìn)行結(jié)果整合。該語(yǔ)言還可擴(kuò)展以集成其他建模和分析功能。

4 工具支持

許多工具支持AADL架構(gòu)設(shè)計(jì)和分析。開(kāi)源AADL工具環(huán)境(OSATE)是在開(kāi)源Eclipse平臺(tái)之上的一套插件,它提供了一個(gè)集成的開(kāi)發(fā)環(huán)境用于AADL模型編輯、編譯和前端分析。另外,它還包括了使用TOPCASED插件的AADL符號(hào)圖形編輯器。目前已經(jīng)開(kāi)發(fā)成功多個(gè)分析插件用于執(zhí)行各種架構(gòu)的一致性檢查、流程和可靠性分析、數(shù)據(jù)質(zhì)量和安全分析以及資源調(diào)度。


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

    關(guān)注

    5087

    文章

    19155

    瀏覽量

    306433
  • 監(jiān)控
    +關(guān)注

    關(guān)注

    6

    文章

    2222

    瀏覽量

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

    關(guān)注

    19

    文章

    7524

    瀏覽量

    88316
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式系統(tǒng)的軟件架構(gòu)設(shè)計(jì)!

    的誤解2.1.1. 小型的系統(tǒng)不需要架構(gòu)有相當(dāng)多的嵌入式系統(tǒng)規(guī)模都較小,一般是為了某些特定的目的而設(shè)計(jì)的。受工程師認(rèn)識(shí),客戶(hù)規(guī)模和項(xiàng)目進(jìn)度的影響,經(jīng)常不做任何
    發(fā)表于 08-10 07:46

    如何利用Allegro實(shí)現(xiàn)嵌入式系統(tǒng)高速電路布線設(shè)計(jì)?

    如何利用強(qiáng)大的PCB設(shè)計(jì)軟件Allegro實(shí)現(xiàn)了基于EP9315嵌入式系統(tǒng)的硬件電路設(shè)計(jì)。
    發(fā)表于 04-25 07:29

    嵌入式架構(gòu)有多重要

    原有的代碼。接下來(lái)嵌入式ARM便和大家分享一下,嵌入式架構(gòu)那些事兒……01嵌入式系統(tǒng)的基本架構(gòu)
    發(fā)表于 10-27 08:15

    嵌入式Linux系統(tǒng)知識(shí)架構(gòu)

    嵌入式Linux系統(tǒng)知識(shí)架構(gòu)及層次嵌入式Linux系統(tǒng)構(gòu)成及啟動(dòng)略析嵌入式Linux三劍客之ub
    發(fā)表于 10-27 07:22

    嵌入式Linux系統(tǒng)體系架構(gòu)

    介紹了嵌入式Linux系統(tǒng)體系架構(gòu),以及每一層開(kāi)發(fā)人員的開(kāi)發(fā)流程。
    發(fā)表于 11-05 06:22

    嵌入式系統(tǒng)設(shè)計(jì)具有什么特點(diǎn)

    嵌入式系統(tǒng)開(kāi)發(fā)設(shè)計(jì)嵌入式系統(tǒng)設(shè)計(jì)的主要任務(wù)是定義系統(tǒng)的功能、決定系統(tǒng)
    發(fā)表于 11-08 06:02

    對(duì)嵌入式系統(tǒng)中的架構(gòu)設(shè)計(jì)的理解

    【閱讀這篇文章,你能了解到什么】1. 從事嵌入式開(kāi)發(fā)12年的我,對(duì)架構(gòu)設(shè)計(jì)的理解;2. 對(duì)嵌入式系統(tǒng)中的架構(gòu)設(shè)計(jì)要刻意訓(xùn)練;3.
    發(fā)表于 11-08 08:23

    決定嵌入式系統(tǒng)軟件架構(gòu)的因素和架構(gòu)的影響

    嵌入式系統(tǒng)軟件架構(gòu)設(shè)計(jì)目錄1.前言42.決定架構(gòu)的因素和架構(gòu)的影響42.1.常見(jiàn)的誤解52.1.1.小型的
    發(fā)表于 11-08 06:54

    嵌入式系統(tǒng)電源管理架構(gòu)的研究與實(shí)現(xiàn)

    嵌入式系統(tǒng)電源管理架構(gòu)的研究與實(shí)現(xiàn)
    發(fā)表于 06-14 16:02 ?16次下載

    AADL故障到動(dòng)態(tài)故障樹(shù)的轉(zhuǎn)換

    在基于模型驅(qū)動(dòng)的嵌入式軟件開(kāi)發(fā)中,需要使用工程技術(shù)和工具保證其安全性和可靠性。在設(shè)計(jì)階段確定系統(tǒng)的可靠性是非常重要的,因其可為設(shè)計(jì)決策提供重要信息,以減少系統(tǒng)的開(kāi)發(fā)成本。應(yīng)用AADL
    發(fā)表于 01-27 10:45 ?0次下載
    <b class='flag-5'>AADL</b>故障到動(dòng)態(tài)故障樹(shù)的轉(zhuǎn)換

    架構(gòu)分析與設(shè)計(jì)語(yǔ)言AADL研究綜述

    架構(gòu)分析與設(shè)計(jì)語(yǔ)言(AADL)是一種用于描述復(fù)雜嵌入式系統(tǒng)體系架構(gòu)的建模語(yǔ)言,被廣泛用于安全關(guān)鍵系統(tǒng)
    發(fā)表于 05-11 15:25 ?4次下載

    FPGA實(shí)現(xiàn)嵌入式系統(tǒng)

    FPGA實(shí)現(xiàn)嵌入式系統(tǒng)(嵌入式開(kāi)發(fā)報(bào)班哪個(gè)好)-該文檔為FPGA實(shí)現(xiàn)嵌入式
    發(fā)表于 07-30 09:13 ?12次下載
    FPGA<b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>

    嵌入式系統(tǒng)在物聯(lián)網(wǎng)中的應(yīng)用及架構(gòu)

    架構(gòu) 嵌入式系統(tǒng) 物聯(lián)網(wǎng)
    發(fā)表于 10-21 09:36 ?5次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>在物聯(lián)網(wǎng)中的應(yīng)用及<b class='flag-5'>架構(gòu)</b>

    嵌入式系統(tǒng)開(kāi)發(fā)設(shè)計(jì)

    嵌入式系統(tǒng)開(kāi)發(fā)設(shè)計(jì)嵌入式系統(tǒng)設(shè)計(jì)的主要任務(wù)是定義系統(tǒng)的功能、決定系統(tǒng)
    發(fā)表于 11-03 11:06 ?20次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>開(kāi)發(fā)設(shè)計(jì)

    系統(tǒng)架構(gòu)設(shè)計(jì)筆記(59)—— 嵌入式系統(tǒng)的組成

    軟件和支撐軟件是基礎(chǔ),應(yīng)用軟件則是最能體現(xiàn)整個(gè)嵌入式系統(tǒng)的特點(diǎn)和功能的部分。1 硬件架構(gòu)圖 1 是一個(gè)嵌入式系統(tǒng)的基本硬件
    發(fā)表于 11-04 11:06 ?13次下載
    <b class='flag-5'>系統(tǒng)</b><b class='flag-5'>架構(gòu)</b>設(shè)計(jì)筆記(59)—— <b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>的組成