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

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

3天內不再提示

HDI硬件設備接口介紹

OpenAtom OpenHarmony ? 來源:OpenAtom OpenHarmony ? 作者:OpenAtom OpenHarmony ? 2022-06-02 11:04 ? 次閱讀

HDF 驅動框架是 OpenAtom OpenHarmony(簡稱“OpenHarmony”)系統(tǒng)硬件生態(tài)開放的基礎,為驅動開發(fā)者提供了驅動加載、驅動服務管理和驅動消息機制等驅動框架能力,同時還為開發(fā)者提供了規(guī)范的HDI硬件設備接口,讓開發(fā)者能屏蔽南向設備差異,提供更好的硬件。本文將為大家?guī)?HDI 硬件設備接口的介紹。

327e0238-e1b8-11ec-ba43-dac502259ad0.png

圖1 HDF驅動框架

一、HDI介紹

HDI(Hardware Device Interface,硬件設備接口)是 HDF 驅動框架為開發(fā)者提供的硬件規(guī)范化描述性接口。在 OpenHarmony 分層結構中,HDI 位于 “基礎系統(tǒng)服務層”和“設備抽象層(DAL)”之間。硬件設備通過 DAL 抽象化,并基于 IDL(Interface Description Language)接口描述語言描述后,為上層應用或服務提供了規(guī)范的硬件設備接口。

32a4b0c2-e1b8-11ec-ba43-dac502259ad0.png

圖2 OpenHarmony 分層結構

HDI 支持“IPC 模式”及“直通模式”兩種調用方式。其中,IPC 模式即跨進程通信模式,基于 binder 機制實現(xiàn),調用端通過 Proxy 代理庫調用 HDI 接口,具備良好的解耦性和安全性,是標準系統(tǒng)的默認部署方式。直通模式,將 HDI 實現(xiàn)為共享庫,調用端使用 dlopen 加載 HDI 實現(xiàn)庫并直接調用 HDI 接口,是小型系統(tǒng)的默認部署方式,同時還適用于對性能有特殊需求的標準系統(tǒng)模塊。

32d2f680-e1b8-11ec-ba43-dac502259ad0.jpg

圖3 兩種調用方式

HDI 硬件設備接口的優(yōu)點用一句話總結就是:為硬件的接入提供了統(tǒng)一的實現(xiàn)通路。屏蔽了硬件接口的具體實現(xiàn),實現(xiàn)系統(tǒng)軟件與硬件的架構解耦。讓開發(fā)者專注于硬件接口的使用,從而簡化開發(fā)過程,提升開發(fā)效率。

二、HDI實現(xiàn)

通過上文的介紹,相信很多小伙伴會有疑問,HDI 接口是怎么實現(xiàn)的呢?下面我們將為你介紹 IPC 模式下基于 C/S(Client-Server 客戶端與服務端)結構的 HDI 接口實現(xiàn)。

2.1 IDL接口描述語言

為方便后文的理解,我們先簡單了解一下 IDL 接口描述語言。

IDL(Interface Description Language)是一類用來描述接口的語言,通過一種中立的方式來定義客戶端與服務端均認可的編程接口,可以實現(xiàn)在二者間的跨進程通信(IPC)。跨進程通信意味著可以在一個進程訪問另一個進程的數據,或調用另一個進程的方法。通常把應用接口提供方(供調用)稱為服務端,調用方稱為客戶端。

IDL 先把需要傳遞的對象分解成操作系統(tǒng)能夠理解的基本類型,然后根據接口聲明編譯,生成 IPC/RPC代理(Proxy)和樁(Stub)的 C/C++ 代碼,從而為調用者提供一致的接口和調用方式。

33023dd2-e1b8-11ec-ba43-dac502259ad0.png

圖4 IDL IPC模式通信模型

2.2 基于IDL語言實現(xiàn)HDI接口

首先,使用 IDL 語法描述 HDI 接口并保存為.idl文件,然后編寫 .idl 文件的編譯腳本 BUILD.gn 文件,最后編譯 .idl 文件即可。下面我們將為大家演示電源子系統(tǒng)的 HDI 接口的實現(xiàn)過程。

(1)使用IDL語法編寫 .idl 文件

● 定義電源接口 IPowerInterface.idl


package ohos.hdi.power.v1_0;import ohos.hdi.power.v1_0.IPowerHdiCallback;import ohos.hdi.power.v1_0.PowerTypes;
interface IPowerInterface {    RegisterCallback([in] IPowerHdiCallback ipowerHdiCallback);    StartSuspend();    StopSuspend();    ForceSuspend();    SuspendBlock([in] String name);    SuspendUnblock([in] String name);    PowerDump([out] String info);}

● 如果需要從服務端回調,可以定義 callback 接口類 IPowerHdiCallback.idl


package ohos.hdi.power.v1_0;
[callback] interface IPowerHdiCallback {    OnSuspend();    OnWakeup();}

● 如果 interface 中用到了自定義數據類型,將自定義類型定義到 powerTypes.idl


package ohos.hdi.power.v1_0;
enum PowerHdfCmd {    CMD_REGISTER_CALLBCK = 0,    CMD_START_SUSPEND,    CMD_STOP_SUSPEND,    CMD_FORCE_SUSPEND,    CMD_SUSPEND_BLOCK,    CMD_SUSPEND_UNBLOCK,    CMD_DUMP,};
enum PowerHdfCallbackCmd {    CMD_ON_SUSPEND = 0,    CMD_ON_WAKEUP,};
enum PowerHdfState {    AWAKE = 0,    INACTIVE,    SLEEP,};

(2)編寫 .idl 文件的編譯腳本 BUILD.gn


import("//drivers/adapter/uhdf2/hdi.gni")if (defined(ohos_lite)) {  group("libpower_proxy_1.0") {    deps = []    public_configs = []  }} else {  hdi("power") {    module_name = "power_interface_service"
    sources = [      "IPowerHdiCallback.idl",      "IPowerInterface.idl",      "PowerTypes.idl",    ]
    language = "cpp"     subsystem_name = "hdf"     part_name = "power_device_driver"   }}

(3)編譯 .idl文件

使用編譯工具 hdi-gen 編譯 IDL 文件,IDL 文件在編譯過程中轉換為 C/C++ 語言的函數接口聲明、客戶端與服務端 IPC 相關過程代碼,開發(fā)者只需要基于生成的 power.h 函數接口實現(xiàn)具體服務功能即可。

編譯后生成代碼在 out/product/gen/drivers/interface/power 中,接口代碼如下:


namespace OHOS {namespace HDI {namespace Power {namespace V1_0 {using namespace OHOS; enum {    CMD_POWER_INTERFACE_REGISTER_CALLBACK,    CMD_POWER_INTERFACE_START_SUSPEND,    CMD_POWER_INTERFACE_STOP_SUSPEND,    CMD_POWER_INTERFACE_FORCE_SUSPEND,    CMD_POWER_INTERFACE_SUSPEND_BLOCK,    CMD_POWER_INTERFACE_SUSPEND_UNBLOCK,    CMD_POWER_INTERFACE_POWER_DUMP,    CMD_POWER_INTERFACE_GET_VERSION,}; class IPowerInterface : public IRemoteBroker {public:    DECLARE_INTERFACE_DESCRIPTOR(u"ohos.hdi.power.v1_0.IPowerInterface");    virtual ~IPowerInterface() = default;    static sptr Get();    static sptr GetInstance(const std::string& serviceName);    virtual int32_t RegisterCallback(const sptr& ipowerHdiCallback) = 0;    virtual int32_t StartSuspend() = 0;    virtual int32_t StopSuspend() = 0;    virtual int32_t ForceSuspend() = 0;    virtual int32_t SuspendBlock(const std::string& name) = 0;    virtual int32_t SuspendUnblock(const std::string& name) = 0;    virtual int32_t PowerDump(std::string& info) = 0;    virtual int32_t GetVersion(uint32_t& majorVer, uint32_t& minorVer) = 0;};} // V1_0} // Power} // HDI}//OHOS

(4)實現(xiàn)HDI接口

● 實現(xiàn) UHDF Driver,用于將 HDI 實現(xiàn)加載為獨立進程,并基于 HDF 驅動框架發(fā)布設備服務。


static int32_t PowerInterfaceDriverDispatch(struct HdfDeviceIoClient *client, int cmdId, struct HdfSBuf *data,    struct HdfSBuf *reply){   ......
    return hdfPowerInterfaceHost->service->OnRemoteRequest(cmdId, *dataParcel, *replyParcel, option); // 將接口調用轉發(fā)到stub實現(xiàn)}
static int HdfPowerInterfaceDriverBind(struct HdfDeviceObject *deviceObject){    ......    hdfPowerInterfaceHost->ioservice.Dispatch = PowerInterfaceDriverDispatch;    hdfPowerInterfaceHost->ioservice.Open = NULL;    hdfPowerInterfaceHost->ioservice.Release = NULL;    hdfPowerInterfaceHost->service = new PowerInterfaceImpl();
    deviceObject->service = &hdfPowerInterfaceHost->ioservice;    return HDF_SUCCESS;}
......
struct HdfDriverEntry g_powerinterfaceDriverEntry = {    .moduleVersion = 1,    .moduleName = "power_interface_service",    .Bind = HdfPowerInterfaceDriverBind,    .Init = HdfPowerInterfaceDriverInit,    .Release = HdfPowerInterfaceDriverRelease,};

● 實現(xiàn) HDI 接口


#include "v1_0/power_interface_stub.h"
/* 繼承PowerInterfaceStub并實現(xiàn)IPowerInterface 中的接口*/class PowerInterfaceImpl : public PowerInterfaceStub {public:    virtual ~PowerInterfaceImpl() {}    int32_t RegisterCallback(const sptr& ipowerHdiCallback) override;    int32_t StartSuspend() override;    int32_t StopSuspend() override;    int32_t ForceSuspend() override;    int32_t SuspendBlock(const std::string& name) override;    int32_t SuspendUnblock(const std::string& name) override;    int32_t PowerDump(std::string& info) override;};
// 在cpp中對相關接口進行實現(xiàn),其中調用了內核相關接口,實現(xiàn)了具體功能
int32_t PowerInterfaceImpl::StopSuspend(){    suspendRetry_ = false;
    return HDF_SUCCESS;}
int32_t PowerInterfaceImpl::ForceSuspend(){    suspendRetry_ = false;
    NotifyCallback(CMD_ON_SUSPEND);    DoSuspend();    NotifyCallback(CMD_ON_WAKEUP);    return HDF_SUCCESS;}
int32_t PowerInterfaceImpl::SuspendBlock(const std::string& name){    std::lock_guard<std::mutex> lock(mutex_);    if (name.empty()) {        return HDF_ERR_INVALID_PARAM;    }    UniqueFd fd(TEMP_FAILURE_RETRY(open(LOCK_PATH, O_RDWR | O_CLOEXEC)));    bool ret = SaveStringToFd(fd, name);    if (!ret) {        return HDF_FAILURE;    }    return HDF_SUCCESS;}

三、HDI使用

通過上文的介紹,相信大家已經對 HDI 有了一定的了解,下面我們將為大家介紹 HDI 的使用,在直通模式下,對 HDI 接口調用為同一進程空間函數調用,過程較為直接,這里我們重點闡述 IPC 模式下的調用原理,然后通過 CPP 語言來展示電源子系統(tǒng) HDI 的調用。

3.1 調用原理

在 IPC 模式下,當系統(tǒng)服務調用 HDI 接口時,通過 proxy 庫將函數調用轉換為 IPC 請求,將接口調用的參數進行序列化;IPC 請求通過 IPC 框架發(fā)送到服務端,請求將被 stub 庫先處理,然后對接口調用的參數進行反序列化,再轉換成對服務實現(xiàn)的函數調用,從而實現(xiàn)接口調用過程。

332891e4-e1b8-11ec-ba43-dac502259ad0.png

圖5 HDI調用過程

3.2 基于CPP語言的使用

上文已經編譯生成了電源子系統(tǒng)的 HDI 接口,下面我們來看看如何使用 CPP 語言來調用 HDI 接口吧。

(1)客戶端在BUILD.gn中增加依賴://drivers/interface/foo/v1.0:libfoo_proxy_1.0"


ohos_executable("call_foo_hdi") {sources = ["src/call_foo_hdi.cpp",]deps = ["http://drivers/interface/foo/v1.0:libfoo_proxy_1.0",]external_deps = ["hiviewdfx_hilog_native:libhilog","ipc:ipc_core","utils_base:utils",]part_name = "bar"subsystem_name = "bar_subsystem"}

(2)在實現(xiàn)電源子系統(tǒng)的代碼中調用 HDI 接口,代碼如下:


 #include "v1_0/power_interface.h" //包含Power HDI接口頭文件 using namespace OHOS::V1_0; //使用HDI接口命名空間 namespace OHOS { namespace PowerMgr { sptr powerInterface = nullptr; SystemSuspendController::SystemSuspendController() {     sptr g_callback = new PowerHdiCallbackImpl();     powerInterface = IPowerInterface::Get(); //調用接口實例化接口獲取客戶端實例     if (powerInterface == nullptr) {         POWER_HILOGE(COMP_SVC, "The hdf interface is null");         return;     }     powerInterface->RegisterCallback(g_callback); // 調用HDI接口注冊電源事件回調}

四、結語

以上就是本文全部內容,我們在這里簡單介紹了HDI接口的實現(xiàn)思路及使用,對于廣大南向開發(fā)者,我們還在社區(qū)提供了詳細的HDI接口實現(xiàn)指導,歡迎大家在gitee社區(qū)參與更多討論。

社區(qū)鏈接:

https://gitee.com/openharmony/drivers_interface

審核編輯 :李倩


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

    關注

    33

    文章

    8447

    瀏覽量

    150724
  • HDI
    HDI
    +關注

    關注

    6

    文章

    191

    瀏覽量

    21262

原文標題:OpenHarmony 3.1 Release版本關鍵特性解析——HDI硬件設備接口介紹

文章出處:【微信號:gh_e4f28cfa3159,微信公眾號:OpenAtom OpenHarmony】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    HDI板盲孔制作常見缺陷及解決

    HDI板是一種高密度互連印刷電路板,其特點是線路密度高、孔徑小、層間連接復雜。在HDI板的制作過程中,盲孔的制作是一個關鍵步驟,同時也是常見的缺陷發(fā)生環(huán)節(jié)。以下是根據搜索結果總結的HDI板盲孔制作的常見缺陷及其解決方法。
    的頭像 發(fā)表于 11-02 10:33 ?117次閱讀

    PCB HDI產品的介紹

    。那么HDI產品和普通多層板產品有什么不同呢?我們用4層通孔 vs 4層1階1壓HDI產品為例從流程、疊構、產品特性和產品要求四個方面對PCB HDI產品的介紹。
    的頭像 發(fā)表于 10-28 09:44 ?214次閱讀
    PCB <b class='flag-5'>HDI</b>產品的<b class='flag-5'>介紹</b>

    如何判斷盲/埋孔HDI板有多少“階”?

    ● 盲/埋孔HDI板概述 盲/埋孔HDI (High Density Interconnect,高密度互連)板是一種高級的印刷電路板技術,它通過使用微小的盲孔和埋孔來 提高電路板上的布線密度
    發(fā)表于 10-23 18:38

    合宙Air700EAQ硬件設計手冊——應用接口1

    本文主要介紹合宙Air700EAQ的硬件設計中的應用接口部分。
    的頭像 發(fā)表于 08-26 17:13 ?420次閱讀
    合宙Air700EAQ<b class='flag-5'>硬件</b>設計手冊——應用<b class='flag-5'>接口</b>1

    合宙Air700ECQ硬件設計手冊——應用接口2

    ? 合宙Air700ECQ硬件設計手冊——應用接口部分。本文介紹了Air700ECQ的應用接口中的開關機,串口,USB接口,USB下載模式和
    的頭像 發(fā)表于 08-22 15:06 ?346次閱讀
    合宙Air700ECQ<b class='flag-5'>硬件</b>設計手冊——應用<b class='flag-5'>接口</b>2

    什么是HDI?PCB設計基礎與HDI PCB制造工藝

    隨著科技的發(fā)展,將更多功能集成在更小的封裝中的需求也隨之增長。使用高密度互連(HDI)技術設計的PCB通常更小,因為更多的元件被裝在更小的空間里。HDIPCB使用盲孔、埋孔和微孔、焊盤內孔以及非常細
    的頭像 發(fā)表于 07-22 18:21 ?3548次閱讀
    什么是<b class='flag-5'>HDI</b>?PCB設計基礎與<b class='flag-5'>HDI</b> PCB制造工藝

    HDI板工藝流程圖

    下面介紹的這款HDI板由芯板與積層構成,由導通孔進行層間連接。按所用積層絕緣材料不同和導通孔形成方法不同而有所區(qū)分。
    的頭像 發(fā)表于 03-26 11:21 ?1063次閱讀
    <b class='flag-5'>HDI</b>板工藝流程圖

    HDI板與普通pcb板有哪些不同

    HDI板與普通pcb板有哪些不同
    的頭像 發(fā)表于 03-01 10:51 ?1343次閱讀

    hdi板與普通pcb有什么區(qū)別

    hdi板與普通pcb有什么區(qū)別
    的頭像 發(fā)表于 12-28 10:26 ?2678次閱讀

    關于HDI板與普通PCB的區(qū)別

    當PCB的密度增加超過八層板后,以HDI來制造,其成本將較傳統(tǒng)復雜的壓合制程來得低。HDI板有利于先進構裝技術的使用,其電性能和訊號正確性比傳統(tǒng)PCB更高。此外,HDI板對于射頻干擾、電磁波干擾、靜電釋放、熱傳導等具有更佳的改善
    發(fā)表于 12-25 15:54 ?728次閱讀

    HDI 布線的挑戰(zhàn)和技巧

    HDI 布線的挑戰(zhàn)和技巧
    的頭像 發(fā)表于 12-07 14:48 ?477次閱讀

    什么是HDI板?HDI板中的一階,二階是怎么定義的?

    什么是HDI板?HDI板中的一階,二階是怎么定義的? HDI(High-Density Interconnect)是一種高密度互連技術,用于在電子設備中實現(xiàn)更多的線路和連接點。它利用微
    的頭像 發(fā)表于 12-07 09:59 ?4545次閱讀

    如何管理高密 HDI 過孔

    如何管理高密 HDI 過孔
    的頭像 發(fā)表于 12-05 16:32 ?442次閱讀
    如何管理高密 <b class='flag-5'>HDI</b> 過孔

    HDI電路板過孔類型介紹

    HDI電路板過孔類型介紹
    的頭像 發(fā)表于 12-04 13:58 ?988次閱讀
    <b class='flag-5'>HDI</b>電路板過孔類型<b class='flag-5'>介紹</b>

    pcb電路板hdi是什么?

    PCB線路板HDI是一種高密度互連技術,用于制造復雜的多層PCB電路板。HDI技術可以提供更高的布線密度、更小的尺寸和更好的性能。今天就跟大家說說PCB線路板HDI的制作流程吧。
    的頭像 發(fā)表于 11-16 11:00 ?2208次閱讀