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

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

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

一文讀懂DDS和AUTOSAR Adaptive的集成

jf_EksNQtU6 ? 來源:車端 ? 作者:初光 ? 2022-11-02 10:05 ? 次閱讀

對于使用AUTOSAR制造車輛的公司來說,已經(jīng)出現(xiàn)了兩個不同的平臺 - AUTOSAR Classic和AUTOSAR Adaptive 這兩個AUTOSAR平臺之間互操作性的基礎(chǔ)標準。使 AUTOSAR 自適應(yīng)應(yīng)用程序能夠與現(xiàn)有和未來的 DDS系統(tǒng)進行互操作。

什么是dds?

DDS最重要的特性是以數(shù)據(jù)為中心,這是與其他很多通信中間件不同的地方。DDS的數(shù)據(jù)共享以Topic為單元,應(yīng)用程序能夠通過Topic判斷其所包含的數(shù)據(jù)類型,而不必依賴其他的上下文信息。同時,DDS能夠按照用戶定義的方式自動地進行存儲、發(fā)布或訂閱數(shù)據(jù),使應(yīng)用程序能夠像訪問本地數(shù)據(jù)一樣去寫入或者讀取數(shù)據(jù)

DDS實現(xiàn)的數(shù)據(jù)共享可以理解成一個抽象的“全局數(shù)據(jù)空間”,任何應(yīng)用程序,不論開發(fā)語言,或者運行的操作系統(tǒng)類型,都可以通過相同的方式訪問這個“全局數(shù)據(jù)空間”,就好像訪問本地的存儲空間一樣。當然“全局數(shù)據(jù)空間”僅僅是一個抽象的概念,在實現(xiàn)時仍然是分別存儲在每個應(yīng)用程序的本地空間當中。在系統(tǒng)運行時,數(shù)據(jù)是按需傳輸或存儲的,數(shù)據(jù)的發(fā)布者僅僅發(fā)送對方需要的數(shù)據(jù),而訂閱者僅接收并存儲本地應(yīng)用程序當前需要的數(shù)據(jù)。DDS還提供了非常靈活的QoS(Quality of Service)策略,以滿足用戶對數(shù)據(jù)共享方式的不同需求,比如可靠性,故障處理等等。針對數(shù)據(jù)安全性要求比較高的系統(tǒng),DDS還提供了細顆粒度的數(shù)據(jù)安全控制,包括應(yīng)用程序身份認證,權(quán)限控制,數(shù)據(jù)加密等等。

類似于SOME/IP-SD,DDS提供了對數(shù)據(jù)發(fā)布者和訂閱者的動態(tài)發(fā)現(xiàn)機制,這意味著用戶不必去配置通信節(jié)點的地址或其他屬性信息,因為他們在運行的過程中會自動發(fā)現(xiàn)對方,并自動完成相關(guān)配置,即實現(xiàn)了“即插即用“。)

關(guān)于RTIDDS詳細的的介紹,請到最后一節(jié)查看。

什么是中間件?

中間件是位于操作系統(tǒng)和用戶應(yīng)用程序之間的軟件層,它將操作系統(tǒng)提供的資源進行抽象和封裝,為應(yīng)用程序提供各種各樣的高級的服務(wù)和功能,比如通信或數(shù)據(jù)共享。中間件的存在簡化了應(yīng)用程序開發(fā)者的工作,這使他們能夠?qū)⒆⒁饬Ψ旁趹?yīng)用程序本身上,而不必在不同應(yīng)用程序之間或不同系統(tǒng)之間的數(shù)據(jù)傳輸上花太多精力)

什么是 DDS 網(wǎng)絡(luò)綁定?

在 AUTOSAR 自適應(yīng)平臺中,通信管理功能集群提供面向服務(wù)的通信建模和基礎(chǔ)設(shè)施。應(yīng)用程序構(gòu)建在中間件之上,應(yīng)用程序級 API 與協(xié)議無關(guān),中間件在 API 和實際的底層通信技術(shù)之間進行代理。AUTOSAR 中代理或者此類映射稱為“網(wǎng)絡(luò)綁定”,下面是三個標準化的通信協(xié)議:

DDS

SOME/IP

基于信號的通信

由于 AUTOSAR 自適應(yīng)平臺的各種設(shè)計方面,為 AUTOSAR 設(shè)計和實現(xiàn)網(wǎng)絡(luò)綁定組件通常是一項復(fù)雜的任務(wù):面向應(yīng)用程序的 API 和網(wǎng)絡(luò)綁定組件之間不存在標準化的 API 層,因此要求特定網(wǎng)絡(luò)綁定的實現(xiàn)者以各自不同的方式來集成AUTOSAR 有自己的數(shù)據(jù)類型系統(tǒng),必須通過網(wǎng)絡(luò)綁定與每個底層通信技術(shù)(即 DDS 自己的可擴展類型)的類型系統(tǒng)和功能進行協(xié)調(diào))AUTOSAR還規(guī)定了非常具體的對象生命周期和內(nèi)存管理協(xié)議,這些協(xié)議必須與網(wǎng)絡(luò)綁定封裝的底層框架相匹配。

映射 DDS 和 AUTOSAR 類型系統(tǒng)

盡管 AUTOSAR 類型相當常見并且自然映射到 DDS-XTypes(布爾值、數(shù)字、字符串、結(jié)構(gòu)、數(shù)組、序列等)——并且這種映射已經(jīng)在通信管理規(guī)范中的 DDS 網(wǎng)絡(luò)綁定材料中指定——但實際集成需要將 PSM(平臺特定模塊)組合在一起,用于 C 和C++編程語言中的兩種類型系統(tǒng)。我們將選擇AUTOSAR支持的唯一語言綁定,C++(最多C++14)和DDS的C語言PSM。從一個簡單的示例開始,下面是從 DDS-IDL 或 DDS-XML 轉(zhuǎn)換為 C 后的簡單 Point3D 類型的外觀:

struct Point3D {

     float x;

     float y;

     float z;

};

然后從AUTOSAR的ARXML轉(zhuǎn)換為C++:

struct Point3D {

     float x;

     float y;

     float z;

};

讓我們進一步改進我們的類型目錄,將 3D 點分組為點云,為了簡單起見,這些點云僅作為固定長度的數(shù)組排列。根據(jù) DDS C PSM,有如下定義:

typedef Point3D PointCloud[1024];

但是相同的類型(1024個元素的點數(shù)組)將在AUTOSAR Adaptive中生成,如下所示:

typedef ara::Array PointCloud;

它們明顯是相似但不相同的類型。事實上,ara::core::Array<>保留了一些普通固定長度數(shù)組類型的語義(例如索引訪問),但也添加了類似 STL 的語義,如 begin() 和 end() 方法,并且不會隱式轉(zhuǎn)換為 Point3D 指針。對于其他類型的,例如字符串和向量,此差距甚至更大。在RTI的ara::com中,通過AUTOSAR建模的用戶定義類型(結(jié)構(gòu)體)的實現(xiàn)類型不包含值字段,而是引用內(nèi)部管理的“后端存儲”的功能兼容包裝器。此類后端存儲可能基于 Adaptive Platform 的 PSM(標準C++數(shù)值類型和 ara::core 容器類型)或 DDS 的 PSM 自動生成類型,來自 DDS-IDL 或 DDS-XML。這種方法不僅簡化了與多種不同的通信框架的集成,而且還為共享數(shù)據(jù)時的高效內(nèi)存管理和增刪改數(shù)據(jù)樣本提供了便利。

實現(xiàn)高效的內(nèi)存管理

由于上一節(jié)中描述的數(shù)據(jù)類型結(jié)構(gòu)的靈活性,數(shù)據(jù)樣本出現(xiàn)了兩種非獨占內(nèi)存管理策略:

實現(xiàn)類型實例可以由應(yīng)用程序直接分配堆?;蚨?,這會導(dǎo)致內(nèi)部類型實現(xiàn)使用 AUTOSAR 的內(nèi)存中 PSM 類型。當傳遞給底層框架時,這些數(shù)據(jù)類型必須根據(jù)所需的目標數(shù)據(jù)格式(即,來自DDS-IDL或DDS-XML的DDS自動生成的類型)進行轉(zhuǎn)換和/或序列化。

在尋求零拷貝傳輸時,應(yīng)用程序還可以利用事件和字段通知程序提供的標準 Allocate() 方法。在這種情況下,網(wǎng)絡(luò)綁定將盡可能要求底層框架“借出”內(nèi)部分配的數(shù)據(jù)樣本,該樣本將在應(yīng)用程序填充和發(fā)回時“返回”。后者是一種非常強大的機制,允許在幾種情況下進行與大小無關(guān)的恒定時間傳輸:

共享內(nèi)存?zhèn)鬏?/p>

內(nèi)存映射網(wǎng)絡(luò)接口

進程內(nèi)通信

除了以高性能的方式映射類型系統(tǒng)和 API 之外,AUTOSAR 的汽車產(chǎn)品重點還帶來了另一個挑戰(zhàn):功能安全合規(guī)性。在任何ISO-26262 ASIL級別中,評估任何DDS實施,都要有SEooC,脫離(SEooC)去評估本身就是一個挑戰(zhàn),下面是一些對DDS實施和AUTOSAR的一些約束和要求:

C 是 DDS 網(wǎng)絡(luò)綁定實現(xiàn)中唯一允許的 DDS 語言 PSM,因此可以輕松適應(yīng)多種 DDS 實現(xiàn)(占用空間小、安全意識強)

多綁定支持是必須的,因為肯定需要提供多個DDS網(wǎng)絡(luò)綁定才能支持上述各種DDS實現(xiàn)。

AUTOSAR 自適應(yīng) DDS 網(wǎng)絡(luò)綁定規(guī)范中更精簡的服務(wù)發(fā)現(xiàn)和綁定功能方法,使用在大多數(shù) DDS 中間件實現(xiàn)中更容易找到的常見 DDS 功能(主題、實例)

RTI DDS 介紹

c83be808-59d6-11ed-a3b6-dac502259ad0.png

c84e9e94-59d6-11ed-a3b6-dac502259ad0.png

c9618b70-59d6-11ed-a3b6-dac502259ad0.png

c9974d0a-59d6-11ed-a3b6-dac502259ad0.png

c9ac56be-59d6-11ed-a3b6-dac502259ad0.png

c9c7f626-59d6-11ed-a3b6-dac502259ad0.png

c9da3688-59d6-11ed-a3b6-dac502259ad0.png

c9f788f0-59d6-11ed-a3b6-dac502259ad0.png

ca14f390-59d6-11ed-a3b6-dac502259ad0.png

ca23de32-59d6-11ed-a3b6-dac502259ad0.png

ca345c3a-59d6-11ed-a3b6-dac502259ad0.png

ca4fd17c-59d6-11ed-a3b6-dac502259ad0.png

ca790718-59d6-11ed-a3b6-dac502259ad0.png

ca978a3a-59d6-11ed-a3b6-dac502259ad0.png

cab0240a-59d6-11ed-a3b6-dac502259ad0.png

cac14424-59d6-11ed-a3b6-dac502259ad0.png

cae37aee-59d6-11ed-a3b6-dac502259ad0.png

cafb063c-59d6-11ed-a3b6-dac502259ad0.png

cb36d96e-59d6-11ed-a3b6-dac502259ad0.png

cb4fcf82-59d6-11ed-a3b6-dac502259ad0.png

cb6bfa36-59d6-11ed-a3b6-dac502259ad0.png

cb7e0d8e-59d6-11ed-a3b6-dac502259ad0.png

cb9b6cd0-59d6-11ed-a3b6-dac502259ad0.png

cbb0ce7c-59d6-11ed-a3b6-dac502259ad0.png

cbc181f4-59d6-11ed-a3b6-dac502259ad0.png

cbd15ea8-59d6-11ed-a3b6-dac502259ad0.png

cbe6e2d2-59d6-11ed-a3b6-dac502259ad0.png

cbfb3688-59d6-11ed-a3b6-dac502259ad0.png

cc0f594c-59d6-11ed-a3b6-dac502259ad0.png

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

    關(guān)注

    21

    文章

    634

    瀏覽量

    152665
  • AUTOSAR
    +關(guān)注

    關(guān)注

    10

    文章

    362

    瀏覽量

    21588
收藏 人收藏

    評論

    相關(guān)推薦

    讀懂接口模塊的組合應(yīng)用有哪些?

    讀懂接口模塊的組合應(yīng)用有哪些?
    發(fā)表于 05-17 07:15

    讀懂如何去優(yōu)化AC耦合電容?

    讀懂如何去優(yōu)化AC耦合電容?
    發(fā)表于 06-08 07:04

    讀懂什么是NEC協(xié)議

    讀懂什么是NEC協(xié)議?
    發(fā)表于 10-15 09:22

    讀懂中斷方式和輪詢操作有什么區(qū)別嗎

    讀懂中斷方式和輪詢操作有什么區(qū)別嗎?
    發(fā)表于 12-10 06:00

    讀懂NB-IoT 的現(xiàn)狀、挑戰(zhàn)和前景

    讀懂 NB-IoT 的現(xiàn)狀、挑戰(zhàn)和前景
    的頭像 發(fā)表于 02-28 15:42 ?6386次閱讀

    讀懂MCU的特點、功能及如何編寫

    讀懂MCU的特點、功能及如何編寫
    發(fā)表于 12-05 09:51 ?24次下載
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>讀懂</b>MCU的特點、功能及如何編寫

    基于CANoe和Visual Studio實現(xiàn)Classic和Adaptive AUTOSAR應(yīng)用層調(diào)試

    而無法實現(xiàn)傳統(tǒng)調(diào)試或測試工作。在面對復(fù)雜控制器軟件系統(tǒng)時,CANoe可在虛擬環(huán)境實現(xiàn)軟件系統(tǒng)的調(diào)試和測試工作,Visual Studio(簡稱VS)或許是虛擬環(huán)境下進行Classic AUTOSARAdaptive AUTOSAR
    的頭像 發(fā)表于 03-10 15:47 ?2413次閱讀

    AUTOSAR C++和MISRA C++集成和自適應(yīng)開發(fā)

      AUTOSAR Adaptive 和 Classic 平臺之間的共性是有幫助的——這事實已經(jīng)反映在 AUTOSAR 基礎(chǔ)標準中,該標準包含適用于兩者的要求和技術(shù)規(guī)范。
    的頭像 發(fā)表于 06-17 14:55 ?2190次閱讀
    <b class='flag-5'>AUTOSAR</b> C++和MISRA C++<b class='flag-5'>集成</b>和自適應(yīng)開發(fā)

    映射DDSAUTOSAR類型系統(tǒng)實現(xiàn)

    對于使用AUTOSAR制造車輛的公司來說,已經(jīng)出現(xiàn)了兩個不同的平臺 - AUTOSAR Classic和AUTOSAR Adaptive 這兩個AU
    的頭像 發(fā)表于 11-02 10:05 ?1370次閱讀

    什么是Adaptive AUTOSAR?不使用Adaptive AUTOSAR行不行?

    Adaptive AUTOSAR種新的汽車軟件框架,旨在滿足現(xiàn)代汽車行業(yè)中不斷增長的技術(shù)需求。隨著汽車變得越來越智能,對處理器的性能要求也在不斷增長。
    發(fā)表于 09-15 10:54 ?2479次閱讀
    什么是<b class='flag-5'>Adaptive</b> <b class='flag-5'>AUTOSAR</b>?不使用<b class='flag-5'>Adaptive</b> <b class='flag-5'>AUTOSAR</b>行不行?

    讀懂,什么是BLE?

    讀懂,什么是BLE?
    的頭像 發(fā)表于 11-27 17:11 ?2297次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>讀懂</b>,什么是BLE?

    讀懂車規(guī)級AEC-Q認證

    讀懂車規(guī)級AEC-Q認證
    的頭像 發(fā)表于 12-04 16:45 ?955次閱讀

    讀懂微力扭轉(zhuǎn)試驗機的優(yōu)勢

    讀懂微力扭轉(zhuǎn)試驗機的優(yōu)勢
    的頭像 發(fā)表于 11-30 09:08 ?580次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>讀懂</b>微力扭轉(zhuǎn)試驗機的優(yōu)勢

    讀懂MSA(測量系統(tǒng)分析)

    讀懂MSA(測量系統(tǒng)分析)
    的頭像 發(fā)表于 11-01 11:08 ?910次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>讀懂</b>MSA(測量系統(tǒng)分析)

    讀懂單燈控制器工作原理

    讀懂單燈控制器工作原理
    的頭像 發(fā)表于 11-11 13:13 ?242次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>讀懂</b>單燈控制器工作原理