Android HIDL第一个demo编写: HIDL Test——实现Framework&App层与HAL进程IPC~Binderized模式

基于上一篇文章:
Android HIDL第一个demo编写: HIDL Test——实现Framework&App层与HAL进程IPC
使用的是Passthrough模式,这里修改为使用Binderized模式:
service.cpp文件写法:

#define LOG_TAG "vendor.heisenberg.hidltest@1.0-service"

#include <android-base/logging.h>
#include <hidl/HidlTransportSupport.h>
#include <hidl/LegacySupport.h>
#include "HidlTest.h"

// libhwbinder
using android::hardware::configureRpcThreadpool;
using android::hardware::joinRpcThreadpool;

using vendor::heisenberg::hidltest::V1_0::IHidlTest;
using vendor::heisenberg::hidltest::V1_0::implementation::HidlTest;

using android::sp;
using android::OK;
using android::status_t;

int main() {
    //和dev/hwbinder进行通信,设置最大的线程个数为4
    configureRpcThreadpool(1, true);

    // register HidlTest service
    sp<IHidlTest> mHidlTestService = new HidlTest();
    status_t status = mHidlTestService->registerAsService();
    if (status != OK) {
        ALOGE("Cannot register HidlTest HAL service");
        return 1;
    }
    ALOGI("HidlTest HAL Ready.");

    //把当前线程加入到线程池
    joinRpcThreadpool();
    return 1;
}

该service对应的bp文件中要增加HidlTest.cpp:

cc_binary {
    proprietary: true,
    relative_install_path: "hw",
    defaults: ["hidl_defaults"],
    name: "vendor.heisenberg.hidltest@1.0-service",
    init_rc: ["vendor.heisenberg.hidltest@1.0-service.rc"],
    srcs: ["service.cpp", "HidlTest.cpp"],

    cflags: [
        "-Wall",
        "-Werror",
    ],

    shared_libs: [
        "liblog",
        "libdl",
        "libutils",
        "libhardware",
        "libhidlbase",
        "libhidltransport",
        "vendor.heisenberg.hidltest@1.0",
    ],

}

打印log查看结果:

Heisenberg海森堡:~$ adb logcat | grep -Ei "hello|HidlTest"
03-03 11:11:51.707  4546  4546 I vendor.heisenberg.hidltest@1.0-service: HidlTest HAL Ready.
03-03 11:12:24.921  4460  4460 I android_os_HwBinder: HwBinder: Starting thread pool for default::vendor.heisenberg.hidltest@1.0::IHidlTest
03-03 11:12:24.921  4546  4546 I HidlTest: SLOGI HidlTest::helloWorld: Hello World, Mr.White
03-03 11:12:24.922  4460  4460 E MainActivity: IHidlTestService.helloWorld:Hello World, Mr.White

版权声明:本文为Heisenberg_Li原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。