91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

OpenHarmony HDF HDI的IPC模式具體實現(xiàn)方法和驅(qū)動框架能力

電子發(fā)燒友開源社區(qū) ? 來源:OpenAtom OpenHarmony ? 作者:OAOH ? 2021-09-22 14:55 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

HDI接口概述

回顧之前的文章,HDF 驅(qū)動框架的一個重要功能是為系統(tǒng)提供穩(wěn)定的統(tǒng)一的硬件接口,這樣才能保證系統(tǒng)服務可以運行在不同硬件上而不需要額外的適配工作,HDI(Hardware Device Interfaces)正是為了實現(xiàn)該目的而設計。

HDI 是對硬件功能的較高層次抽象接口,各類外設完成 HDI 接口定義后便只會在 HDI 的兼容性規(guī)則下進行變更,從而保證接口的穩(wěn)定性。具體的驅(qū)動實現(xiàn)不需要再重復定義 HDI 接口,只需要按需實現(xiàn)即可接入系統(tǒng)功能。

在不同量級的 OpenHarmony 系統(tǒng)上,HDI 存在兩種部署形態(tài),IPC 模式和直通模式。

在輕量級 OpenHarmony 系統(tǒng)上,出于減小系統(tǒng)性能負載考慮,HDI 實現(xiàn)為用戶態(tài)共享庫,由系統(tǒng)服務直接加載 HDI 實現(xiàn)到自己進程中函數(shù)調(diào)用使用。HDI 實現(xiàn)封裝具體的用戶態(tài)-內(nèi)核態(tài)交互過程,當需要訪問驅(qū)動程序時使用 IO Service 請求將消息通過 system call 方式調(diào)用到內(nèi)核驅(qū)動實現(xiàn)。

在標準 OpenHarmony 系統(tǒng)上,HDI 以獨立服務進程方式部署,系統(tǒng)服務只加載 HDI 客戶端實現(xiàn)到自己進程中,實際業(yè)務運行在獨立進程中,客戶端通過 IPC 與服務端交互,便于架構解耦、權限管理。

HDI接口實現(xiàn)

直通模式為函數(shù)實現(xiàn)方式,無論調(diào)用還是實現(xiàn)都不需要其他組件支持即可實現(xiàn),這里將重點分析 IPC 模式的實現(xiàn)。

HDI發(fā)布

HDI IPC 模式基于 OpenHarmony 系統(tǒng)通信框架的通用模型,但是因為驅(qū)動很多時候涉及到底層操作和多系統(tǒng)遷移的場景而使用C語言編寫,所以驅(qū)動框架還提供了 HDI 服務的 C 語言實現(xiàn)的基礎組件,C++實現(xiàn)則主要使用系統(tǒng)通信框架組件。

HDI 服務發(fā)布基于 UHDF(用戶態(tài) HDF 驅(qū)動框架)實現(xiàn),通用的服務發(fā)布實現(xiàn)如下。

1. 實現(xiàn)驅(qū)動入口

int SampleDriverBind(struct HdfDeviceObject *deviceObject){    HDF_LOGE("SampleDriverBind enter!");    static struct IDeviceIoService testService = {        .Dispatch = SampleServiceDispatch, // 服務回調(diào)接口    };    deviceObject->service = &testService;    return HDF_SUCCESS;} int SampleDriverInit(struct HdfDeviceObject *deviceObject){    HDF_LOGE("SampleDriverInit enter");     return HDF_SUCCESS;} void SampleDriverRelease(struct HdfDeviceObject *deviceObject){    HDF_LOGE("SampleDriverRelease enter");    return;} struct HdfDriverEntry g_sampleDriverEntry = {    .moduleVersion = 1,    .moduleName = "sample_driver",    .Bind = SampleDriverBind,    .Init = SampleDriverInit,    .Release = SampleDriverRelease,};
HDF_INIT(g_sampleDriverEntry);

首先要添加一個 UHDF 驅(qū)動用于發(fā)布 IoService 服務,IoService 設備服務即為 HDI 服務實體。實現(xiàn)方式與 KHDF 驅(qū)動一致。

2. 實現(xiàn)服務響應接口

int32_t SampleServiceOnRemoteRequest(struct HdfDeviceIoClient *client, int cmdId,    struct HdfSBuf *data, struct HdfSBuf *reply){    switch (cmdId) {        case SAMPLE_SERVICE_PING:            return SampleServiceStubPing(client, data, reply);        … …        default:            HDF_LOGE("SampleServiceDispatch: not support cmd %d", cmdId);            return HDF_ERR_INVALID_PARAM;    }}static int32_t SampleServiceDispatch(struct HdfDeviceIoClient *client, int cmdId,    struct HdfSBuf *data, struct HdfSBuf *reply){    return SampleServiceOnRemoteRequest(client, cmdId, data, reply);}

當收到 HDI 調(diào)用時,服務響應接口"SampleServiceDispatch"將會被調(diào)用。

  • client 調(diào)用者對象,在用戶態(tài)驅(qū)動中暫時未支持
  • cmdId 調(diào)用命令字,用于區(qū)分調(diào)用的 API
  • data 調(diào)用入?yún)⑿蛄谢瘜ο?,?IPC 調(diào)用場景為 parcel 對象的 C 語言封裝,入?yún)⑿枰褂眯蛄谢涌趶?data 對象中獲取后再使用
  • reply 調(diào)用出參對象,需要返回給調(diào)用的信息寫入該序列化對象

如果 C++實現(xiàn)客戶端可以使用下面接口將 sbuf 對象轉(zhuǎn)換為 parcel 對象后操作:

int32_t SbufToParcel(struct HdfSBuf *sbuf, OHOS::MessageParcel **parcel);
3. UHDF 驅(qū)動配置
platform :: host {    hostName = "sample_host";    priority = 50;    sample_device :: device {        device0 :: deviceNode {            policy = 2;            priority = 100;            moduleName = "libsample_driver.z.so";            serviceName = "sample_driver_service";        }    }}

參數(shù)說明:

  • host 一個 host 節(jié)點即為一個獨立進程,如果需要獨立進程,新增屬于自己的 host 節(jié)點
  • policy 服務發(fā)布策略,HDI 服務設置為 2
  • moduleName 驅(qū)動實現(xiàn)庫名
  • serviceName 服務名稱,請保持全局唯一性

因為 HDI 服務 C 和 C++實現(xiàn)使用的 IPC 組件不一樣,面向?qū)ο髮崿F(xiàn)也不一致,所以在具體實現(xiàn)上存在一些差異。

HDI基礎組件UHDF 框架為了支持 HDI 實現(xiàn),提供了以下基礎組件(僅用于 C 語言 HDI 實現(xiàn)):
  • SBuf

SBuf 是同時支持 KHDF 和 UHDF 驅(qū)動 IoService 消息序列化的工具對象。在 UHDF IPC 通信場景中,SBuf 可以與系統(tǒng) IPC 框架序列化對象 MessageParcel 對象(僅支持 C++)相互轉(zhuǎn)換,從而實現(xiàn) C 和 C++實現(xiàn)的 IPC 互通。

常用 API 如下:

struct HdfSBuf;struct HdfSbufImpl;struct HdfRemoteService;
/** * @brief HdfSBuf類型定義。 * * @since 1.0 */enum HdfSbufType {    SBUF_RAW = 0,   /* 用于用戶態(tài)內(nèi)核態(tài)通信的sbuf類型 */    SBUF_IPC,       /* 用于跨進程通信的sbuf類型 */    SBUF_IPC_HW,    /* 用于擴展的預留類型 */    SBUF_TYPE_MAX,  /* sbuf類型最大值 */};

bede5c9e-0b50-11ec-8fb8-12bb97331649.png

上述接口均有對應的寫入接口,不再一一列舉,可查閱官網(wǎng)API參考文檔。

  • RemoteService

RemoteService 對象和系統(tǒng) IPC 框架中的 IRemoteObject 對象(僅支持 C++)對應并可以相互轉(zhuǎn)換,表示一個 IPC 對象。相關 API 說明:
// 消息分發(fā)器,用于服務端響應調(diào)用或者在客戶端發(fā)起調(diào)用struct HdfRemoteDispatcher {    int (*Dispatch)(struct HdfRemoteService *, int, struct HdfSBuf *, struct HdfSBuf *);};
// RemoteService 死亡回調(diào)對象struct HdfDeathRecipient {    void (*OnRemoteDied)(struct HdfDeathRecipient *, struct HdfRemoteService *);};
struct HdfRemoteService {    struct HdfObject object_;    struct HdfObject *target;    struct HdfRemoteDispatcher *dispatcher;    bool isHw;};// 以自定義的消息分發(fā)器實例化一個RemoteServicestruct HdfRemoteService *HdfRemoteServiceObtain(    struct HdfObject *object, struct HdfRemoteDispatcher *dispatcher);
// 回收RemoteService對象void HdfRemoteServiceRecycle(struct HdfRemoteService *service);
// 添加RemoteService的死亡通知,如果對應RemoteService的進程異常退出,HdfDeathRecipient的回調(diào)接口將被調(diào)用voidHdfRemoteServiceAddDeathRecipient(structHdfRemoteService*service,structHdfDeathRecipient*recipient);
基于 RemoteService 實現(xiàn)一個服務端的示例:
int SampleServiceStubDispatch(    struct HdfRemoteService* service, int code, struct HdfSBuf *data, struct HdfSBuf *reply){    // IPC 調(diào)用響應接口    int ret = HDF_FAILURE;    switch (code) {        case SAMPLE_IF_0: {            // do something            break;        }        default: {            ret = HDF_ERR_INVALID_PARAM;        }    }    return ret;}bool SampleStubConstruct(){    // 構造消息分發(fā)器,實現(xiàn)消息處理回調(diào)    static struct HdfRemoteDispatcher dispatcher = {        .Dispatch = SampleServiceStubDispatch};// 實例化RemoteService    inst->remote = HdfRemoteServiceObtain((struct HdfObject *)inst, &dispatcher);    if (inst->remote == NULL) {        HDF_LOGE("Device service manager failed to obtain remote service");        return false;}……

直接基于 RemoteService 實現(xiàn)服務端只適用于需要實現(xiàn)匿名 IPC 服務的情況,基于 UHDF 發(fā)布 HDI 服務只需要實現(xiàn) Driver 綁定的 IoService 即可。

RemoteService 客戶端對象只能從 SBuf HdfSBufReadRemoteService 接口獲取。

HDI實現(xiàn)

  • Driver 為 HDI 服務的驅(qū)動入口實現(xiàn)
  • IoService 為 HDI 服務的服務入口實現(xiàn),IoService 的 Dispatch 方法中調(diào)用 ServiceStub 中的真正服務響應接口(OnRemoteRequest)
  • ServiceStub 為服務端實現(xiàn)對象,主要處理與 IPC 相關的業(yè)務邏輯,在這里完成參數(shù)反序列化后調(diào)用真正的 Service 實現(xiàn)接口,即 ServiceImpl 接口
  • ServiceImpl 為 HDI 接口的真正實現(xiàn),這里不關注 IPC 過程,只實現(xiàn)函數(shù)接口。
  • 驅(qū)動框架提供了實現(xiàn)的樣例代碼,可參考 gitee driver 代碼倉。

HDI接口調(diào)用

HDI驅(qū)動框架HDI接口

HDI 服務管理功能由驅(qū)動框架 DeviceManager 實現(xiàn),所以驅(qū)動框架提供了 HDI 服務管理相關 HDI 接口。

C++實現(xiàn):

namespace OHOS {namespace HDI {namespace ServiceManager {namespace V1_0 {
struct IServiceManager : public IRemoteBroker {public:    DECLARE_INTERFACE_DESCRIPTOR(u"HDI.IServiceManager.V1_0");    // get()靜態(tài)方法用于獲取IServiceManager對象實例    static ::sptr Get();    // GetService()接口是真正提供的HDI接口,用于查詢并獲取其他HDI服務的客戶端對象    virtual ::sptr GetService(const char* serviceName) = 0;};} // namespace V1_0} // namespace ServiceManager} // namespace HDI}//namespaceOHOS

C 實現(xiàn):

#ifdef __cplusplusextern "C" {#endif /* __cplusplus */
struct HDIServiceManager {    struct HdfRemoteService *remote;
    struct HdfRemoteService *(*GetService)(struct HDIServiceManager *self, const char* serviceName);};
struct HDIServiceManager *HDIServiceManagerGet(void);void HDIServiceManagerRelease(struct HDIServiceManager *servmgr);
#ifdef __cplusplus}#endif/*__cplusplus*/

C 語言因為缺少原生的面向?qū)ο笾С?,這里我們采用 OOC 的實現(xiàn),函數(shù)方法 HDIServiceManagerGet/Release 用于 HDIServiceManager 對象的實例化和釋放,HDI 接口關聯(lián)在接口對象內(nèi)部成員中,與 C++實現(xiàn)類似。

HDI客戶端實現(xiàn)

HDI 客戶端同時支持 C 和 C++實現(xiàn),實現(xiàn)方法較為簡單,只需 realize HDI 接口類即可。提供 C++實現(xiàn)基于系統(tǒng) IPC 子系統(tǒng)的統(tǒng)一模型,C 語言基于 RemoteService 和 SBuf 組件實現(xiàn),但是有一些公共的約定:

1. 客戶端提供接口對象,接口與對象綁定且必須與 HDI 一致

2. 提供服務接口對象的實例化和釋放接口。

3. 客戶端實現(xiàn) IPC 過程,只為調(diào)用者暴露函數(shù)化接口。

HDI接口調(diào)用

HDI 客戶端接口已經(jīng)提供了服務獲取接口,調(diào)用者調(diào)用服務獲取接口后再調(diào)用服務對象方法即可完成 HDI 調(diào)用。

這里以服務管理 HDI 接口為例:

C++接口調(diào)用:

#include 
void GetTestService(){        auto servmgr = IServiceManager::Get();    if (servmgr == nullptr) {    HDF_LOGE("failed to get IServiceManager");    return;  }
    auto sampleService = servmgr->GetService(TEST_SERVICE_NAME);  if (sampleService == nullptr) {    HDF_LOGE("failed to get TEST_SERVICE");    return;  }    // do something}

C 接口調(diào)用:

#include 
void GetTestService(){        struct HDIServiceManager *servmgr = HDIServiceManagerGet();    if (servmgr == nullptr) {    HDF_LOGE("failed to get IServiceManager");    return;  }
    struct HdfRemoteService *sampleService = servmgr->GetService(servmgr, TEST_SERVICE_NAME);  if (sampleService == nullptr) {    HDF_LOGE("failed to get TEST_SERVICE");    return;  }    // do something}

總結

本文介紹了 HDI 的總體方案,重點介紹了 HDI 的 IPC 模式具體實現(xiàn)方法和驅(qū)動框架能力,相信對讀者理解和使用 HDI 有所幫助。

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

    關注

    7

    文章

    225

    瀏覽量

    22732
  • C++
    C++
    +關注

    關注

    22

    文章

    2124

    瀏覽量

    77191
  • 代碼
    +關注

    關注

    30

    文章

    4971

    瀏覽量

    74054
  • OpenHarmony
    +關注

    關注

    33

    文章

    3958

    瀏覽量

    21165

原文標題:OpenHarmony HDF HDI基礎能力分析與使用

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    Binder?驅(qū)動深度解析:Android IPC?的核心底層實現(xiàn)

    ?Binder?驅(qū)動的支撐。對于?Android?開發(fā)者而言,吃透?Binder?驅(qū)動實現(xiàn)原理,不僅能深入理解?Android?系統(tǒng)的設計邏輯,更能高效定位性能問題、規(guī)避安全漏洞,實現(xiàn)
    的頭像 發(fā)表于 03-12 08:11 ?316次閱讀
    Binder?<b class='flag-5'>驅(qū)動</b>深度解析:Android <b class='flag-5'>IPC</b>?的核心底層<b class='flag-5'>實現(xiàn)</b>

    #OpenHarmony 鏡像燒錄

    OpenHarmony
    視美泰
    發(fā)布于 :2026年01月16日 09:42:36

    #OpenHarmony 系統(tǒng)概述

    OpenHarmony
    視美泰
    發(fā)布于 :2026年01月16日 09:39:20

    嵌入式程序設計中4種常用模式

    1. 模板方法模式 模板方法模式框架中最常用的設計模式。 其根本的思路是將算法由
    發(fā)表于 12-25 07:12

    基于數(shù)據(jù)算法驅(qū)動的配方研發(fā)新模式

    、實現(xiàn)自動化優(yōu)化,顯著提升了研發(fā)效率、降低了成本,并推動了產(chǎn)品創(chuàng)新。以下是該模式的核心框架、技術路徑、應用場景及未來趨勢的詳細分析。 一、新模式的核心
    的頭像 發(fā)表于 08-06 17:25 ?1204次閱讀

    HDI盲埋孔PCB階數(shù)區(qū)分方法解析

    HDI盲埋孔PCB的階數(shù)是區(qū)分其結構復雜度的關鍵指標,主要通過增層次數(shù)、鉆孔工藝及連接層數(shù)來綜合判斷,具體區(qū)分方法如下: 一、基于增層次數(shù)的階數(shù)定義 HDI板結構通常以“a+N+a”或
    的頭像 發(fā)表于 08-05 10:34 ?3980次閱讀
    <b class='flag-5'>HDI</b>盲埋孔PCB階數(shù)區(qū)分<b class='flag-5'>方法</b>解析

    迅為RK3568開發(fā)板實操-HDF驅(qū)動配置UART

    對于不同的平臺,需要在對應的平臺目錄修改對應的 hcs 文件,接下來示例為在 rk3568下新增 uart4 uart9 uart7 的修改方法。 修改 vendor/hihope/rk3568
    的頭像 發(fā)表于 06-27 15:58 ?629次閱讀

    第三屆大會回顧第3期 | FFRT并發(fā)框架OpenHarmony中的設計與實踐

    ,特別是在多核處理器上,可以顯著提高程序的運行速度和整體性能,從而改善用戶體驗。OpenHarmony的FFRT并發(fā)編程模型為開發(fā)者提供了構建異步并發(fā)任務的能力,以更高效地開發(fā)和管理并發(fā)任務。FFRT是如何設計與實現(xiàn)的,有哪些重
    的頭像 發(fā)表于 06-21 16:53 ?1301次閱讀
    第三屆大會回顧第3期 | FFRT并發(fā)<b class='flag-5'>框架</b>在<b class='flag-5'>OpenHarmony</b>中的設計與實踐

    ArkUI-X框架LogInterface使用指南

    ArkUI-X框架支持日志攔截能力,Android側提供原生接口,用于注入LogInterface接口,框架日志及ts日志通過該接口輸出,本文的核心內(nèi)容是介紹如何在Android平臺上有效利用
    發(fā)表于 06-15 23:20

    迅為RK3568開發(fā)板實操-HDF驅(qū)動配置UART-修改HCS配置

    時表示向內(nèi)核態(tài)發(fā)布服務, 取值為 2 時表示向內(nèi)核用戶態(tài)發(fā)布服務 3 moduleName 的值要與驅(qū)動實現(xiàn)的 HdfDriverEntry 結構體中的 moduleName 相同。 4
    發(fā)表于 05-22 11:32

    APP自動化測試框架

    Server等基礎服務 實現(xiàn)多設備并行測試與動態(tài)環(huán)境切換能力 元素定位體系? 采用ID/XPath/CSS選擇器/UI控件屬性等多維度定位策略 封裝頁面對象模型(POM)實現(xiàn)元素與業(yè)務邏輯分離 用例管理機制? 數(shù)據(jù)
    的頭像 發(fā)表于 05-07 07:35 ?712次閱讀
    APP自動化測試<b class='flag-5'>框架</b>

    涂鴉打造超強AI IPC技術!深度融合視覺+聽覺感知能力,顛覆傳統(tǒng)IPC交互玩法

    隨著AI大模型能力的突破與成本的下降,IPC開始從單一的“看得見”向“看得懂”迭代,并進一步向“智能交互、主動決策”的方向升級演進。目前主流設備已標配三大能力:即智能識別與分析、多模態(tài)交互與自動化管
    的頭像 發(fā)表于 04-17 18:20 ?1198次閱讀
    涂鴉打造超強AI <b class='flag-5'>IPC</b>技術!深度融合視覺+聽覺感知<b class='flag-5'>能力</b>,顛覆傳統(tǒng)<b class='flag-5'>IPC</b>交互玩法

    RT-Thread PIN驅(qū)動添加

    Pin驅(qū)動框架以NXPMCXA153為例PIN設備驅(qū)動層單純的提供接口給應用層用,其中PIN設備驅(qū)動框架接口包含rt_pin_read等,
    的頭像 發(fā)表于 03-28 18:59 ?933次閱讀
    RT-Thread PIN<b class='flag-5'>驅(qū)動</b>添加

    【北京迅為】iTOP-RK3568開發(fā)板鴻蒙OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)實操-HDF驅(qū)動配置UART

    【北京迅為】iTOP-RK3568開發(fā)板鴻蒙OpenHarmony系統(tǒng)南向驅(qū)動開發(fā)實操-HDF驅(qū)動配置UART
    的頭像 發(fā)表于 03-25 11:02 ?1759次閱讀
    【北京迅為】iTOP-RK3568開發(fā)板鴻蒙<b class='flag-5'>OpenHarmony</b>系統(tǒng)南向<b class='flag-5'>驅(qū)動</b>開發(fā)實操-<b class='flag-5'>HDF</b><b class='flag-5'>驅(qū)動</b>配置UART

    迅為RK3568開發(fā)板篇Openharmony配置HDF控制UART-實操-HDF驅(qū)動配置UART-UART應用開發(fā)-UART驅(qū)動API接口介紹

    UART 驅(qū)動 API 接口如下所示,具體的 API 詳見 drivers/hdf_core/framework/include/platform/uart_if.h 文件。 (1
    發(fā)表于 03-24 11:19