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

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

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

HDI硬件設(shè)備接口介紹

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

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

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

圖1 HDF驅(qū)動(dòng)框架

一、HDI介紹

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

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

圖2 OpenHarmony 分層結(jié)構(gòu)

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

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

圖3 兩種調(diào)用方式

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

二、HDI實(shí)現(xiàn)

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

2.1 IDL接口描述語言

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

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

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

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

圖4 IDL IPC模式通信模型

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

首先,使用 IDL 語法描述 HDI 接口并保存為.idl文件,然后編寫 .idl 文件的編譯腳本 BUILD.gn 文件,最后編譯 .idl 文件即可。下面我們將為大家演示電源子系統(tǒng)的 HDI 接口的實(shí)現(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);}

● 如果需要從服務(wù)端回調(diào),可以定義 callback 接口類 IPowerHdiCallback.idl


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

● 如果 interface 中用到了自定義數(shù)據(jù)類型,將自定義類型定義到 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 文件在編譯過程中轉(zhuǎn)換為 C/C++ 語言的函數(shù)接口聲明、客戶端與服務(wù)端 IPC 相關(guān)過程代碼,開發(fā)者只需要基于生成的 power.h 函數(shù)接口實(shí)現(xiàn)具體服務(wù)功能即可。

編譯后生成代碼在 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)實(shí)現(xiàn)HDI接口

● 實(shí)現(xiàn) UHDF Driver,用于將 HDI 實(shí)現(xiàn)加載為獨(dú)立進(jìn)程,并基于 HDF 驅(qū)動(dòng)框架發(fā)布設(shè)備服務(wù)。


static int32_t PowerInterfaceDriverDispatch(struct HdfDeviceIoClient *client, int cmdId, struct HdfSBuf *data,    struct HdfSBuf *reply){   ......
    return hdfPowerInterfaceHost->service->OnRemoteRequest(cmdId, *dataParcel, *replyParcel, option); // 將接口調(diào)用轉(zhuǎn)發(fā)到stub實(shí)現(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,};

● 實(shí)現(xiàn) HDI 接口


#include "v1_0/power_interface_stub.h"
/* 繼承PowerInterfaceStub并實(shí)現(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中對(duì)相關(guān)接口進(jìn)行實(shí)現(xiàn),其中調(diào)用了內(nèi)核相關(guān)接口,實(shí)現(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使用

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

3.1 調(diào)用原理

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

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

圖5 HDI調(diào)用過程

3.2 基于CPP語言的使用

上文已經(jīng)編譯生成了電源子系統(tǒng)的 HDI 接口,下面我們來看看如何使用 CPP 語言來調(diào)用 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)在實(shí)現(xiàn)電源子系統(tǒng)的代碼中調(diào)用 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(); //調(diào)用接口實(shí)例化接口獲取客戶端實(shí)例     if (powerInterface == nullptr) {         POWER_HILOGE(COMP_SVC, "The hdf interface is null");         return;     }     powerInterface->RegisterCallback(g_callback); // 調(diào)用HDI接口注冊(cè)電源事件回調(diào)}

四、結(jié)語

以上就是本文全部?jī)?nèi)容,我們?cè)谶@里簡(jiǎn)單介紹了HDI接口的實(shí)現(xiàn)思路及使用,對(duì)于廣大南向開發(fā)者,我們還在社區(qū)提供了詳細(xì)的HDI接口實(shí)現(xiàn)指導(dǎo),歡迎大家在gitee社區(qū)參與更多討論。

社區(qū)鏈接:

https://gitee.com/openharmony/drivers_interface

審核編輯 :李倩


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

    關(guān)注

    33

    文章

    8611

    瀏覽量

    151247
  • HDI
    HDI
    +關(guān)注

    關(guān)注

    6

    文章

    200

    瀏覽量

    21311

原文標(biāo)題:OpenHarmony 3.1 Release版本關(guān)鍵特性解析——HDI硬件設(shè)備接口介紹

文章出處:【微信號(hào):gh_e4f28cfa3159,微信公眾號(hào):OpenAtom OpenHarmony】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    HDI盲埋孔工藝及制程能力你了解多少?

    十分樂觀。 然而,HDI技術(shù)屬于特殊工藝,成本較高,對(duì)制造商的生產(chǎn)能力要求嚴(yán)格。沒有先進(jìn)的設(shè)備和技術(shù)人員支持,難以保證高多層、多階HDI板的質(zhì)量。此外,HDI技術(shù)還面臨 材料選擇、制造
    的頭像 發(fā)表于 12-18 17:15 ?1082次閱讀
    <b class='flag-5'>HDI</b>盲埋孔工藝及制程能力你了解多少?

    HDI技術(shù)在5G通信設(shè)備中的信號(hào)完整性優(yōu)化方法

    隨著5G通信技術(shù)的快速發(fā)展,對(duì)通信設(shè)備的性能要求越來越高。信號(hào)完整性是5G通信設(shè)備性能的關(guān)鍵指標(biāo)之一,本文主要探討HDI技術(shù)在5G通信設(shè)備中的信號(hào)完整性優(yōu)化方法,包括信號(hào)路徑優(yōu)化、電路
    的頭像 發(fā)表于 12-04 10:47 ?279次閱讀

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

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

    HDI板電鍍與堆疊過程

    HDI線路板 HDI板是一種高性能的電路板材料,它具有高密度、高可靠性和高互連性的特點(diǎn)。HDI板的制造過程涉及多個(gè)關(guān)鍵步驟,其中包括電鍍和堆疊兩個(gè)重要環(huán)節(jié)。 電鍍過程 電鍍是HDI板制
    的頭像 發(fā)表于 10-28 19:32 ?163次閱讀
    <b class='flag-5'>HDI</b>板電鍍與堆疊過程

    PCB HDI產(chǎn)品的介紹

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

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

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

    合宙Air700EAQ硬件設(shè)計(jì)手冊(cè)——應(yīng)用接口1

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

    合宙Air700ECQ硬件設(shè)計(jì)手冊(cè)——應(yīng)用接口3

    合宙Air700ECQ硬件設(shè)計(jì)手冊(cè)——應(yīng)用接口部分介紹
    的頭像 發(fā)表于 08-22 18:34 ?466次閱讀
    合宙Air700ECQ<b class='flag-5'>硬件</b>設(shè)計(jì)手冊(cè)——應(yīng)用<b class='flag-5'>接口</b>3

    合宙Air700ECQ硬件設(shè)計(jì)手冊(cè)——應(yīng)用接口2

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

    什么是HDI?PCB設(shè)計(jì)基礎(chǔ)與HDI PCB制造工藝

    隨著科技的發(fā)展,將更多功能集成在更小的封裝中的需求也隨之增長。使用高密度互連(HDI)技術(shù)設(shè)計(jì)的PCB通常更小,因?yàn)楦嗟脑谎b在更小的空間里。HDIPCB使用盲孔、埋孔和微孔、焊盤內(nèi)孔以及非常細(xì)
    的頭像 發(fā)表于 07-22 18:21 ?4495次閱讀
    什么是<b class='flag-5'>HDI</b>?PCB設(shè)計(jì)基礎(chǔ)與<b class='flag-5'>HDI</b> PCB制造工藝

    HDI線路板介紹——PCB領(lǐng)域的技術(shù)領(lǐng)先者-健翔升小何分享

    一、HDI線路板的定義與應(yīng)用領(lǐng)域 HDI(High Density Interconnect)線路板,即高密度互連線路板,是一種具有高集成度、高精度、微型化的印刷線路板。它采用了先進(jìn)的制作工藝,將
    的頭像 發(fā)表于 05-27 18:13 ?2071次閱讀

    HDI板工藝流程圖

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

    hdi板怎么定義幾階 hdi板與普通pcb的區(qū)別

    HDI板通常采用多層結(jié)構(gòu),包括4層以上的層次。多層結(jié)構(gòu)提供了更多的信號(hào)層、電源層和地層,支持復(fù)雜的信號(hào)傳輸和電路連接。相比之下,普通PCB可能采用較少的層次。
    的頭像 發(fā)表于 03-25 16:00 ?5431次閱讀

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

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

    不同結(jié)構(gòu)的HDI設(shè)計(jì)會(huì)對(duì)成本帶來哪些影響??

    HDI的應(yīng)用在電子行業(yè)越來越廣泛,尤其是在當(dāng)前電子產(chǎn)品小型化的趨勢(shì)下。對(duì)于同一產(chǎn)品,選擇使用不同結(jié)構(gòu)的HDI設(shè)計(jì)會(huì)對(duì)成本產(chǎn)生很大影響。
    的頭像 發(fā)表于 01-25 16:50 ?871次閱讀
    不同結(jié)構(gòu)的<b class='flag-5'>HDI</b>設(shè)計(jì)會(huì)對(duì)成本帶來哪些影響??