Android系统hal实现 —(以应用层app操作gpio为例)

上一章我们讲了如何用JNI实现Android 应用层app操作节点:https://blog.csdn.net/weixin_41486477/article/details/110791176

上一章提到需要过CTS认证的是不能使用JNI方法的,所以本章整理如何构建一个hal实现Android 应用层app操作节点。

 

驱动和hal(testgpio.default.so)部分等同JNI实现的部分,下面重点分享如何构建自己的hal,并在framework中调用它。

 

一.构建hal

新建hardware\interfaces\testgpio\1.0\ITestgpio.hal,generates表示生成的函数类型,如例就是int32_t类型。

package [email protected];

interface Itestgpio {
  set_gpio_up(int32_t gpio_index) generates (int32_t result);
  set_gpio_down(int32_t gpio_index) generates (int32_t result);
  testgpio_open()generates (int32_t result);
};

借助hidl-gen工具生成目录文件:

1.执行make hidl-gen 先安装工具
2.依次执行
export [email protected]
export LOC=hardware/interfaces/testgpio/1.0/default/
hidl-gen -o $LOC -Lc++-impl -randroid.hardware:hardware/interfaces -randroid.hidl:system/libhidl/transport $PACKAGE
hidl-gen -o $LOC -Landroidbp-impl -randroid.hardware:hardware/interfaces -randroid.hidl:system/libhidl/transport $PACKAGE
./hardware/interfaces/update-makefiles.sh

生成的文件仅仅是一个模板,需要按照我们的需求自行修改

修改hardware\interfaces\testgpio\1.0\default\Testgpio.h

#ifndef ANDROID_HARDWARE_TESTGPIO_V1_0_TESTGPIO_H
#define ANDROID_HARDWARE_TESTGPIO_V1_0_TESTGPIO_H

#include <android/hardware/testgpio/1.0/ITestgpio.h>
#include <hidl/MQDescriptor.h>
#include <hardware/hardware.h>
#include <hidl/Status.h>
#include "hardware/testgpio.h"

namespace android {
namespace hardware {
namespace testgpio {
namespace V1_0 {
namespace implementation {

using ::android::hardware::hidl_array;
using ::android::hardware::hidl_memory;
using ::android::hardware::hidl_string;
using ::android::hardware::hidl_vec;
using ::android::hardware::Return;
using ::android::hardware::Void;
using ::android::sp;

struct Testgpio : public ITestgpio {
	Testgpio();
    ~Testgpio();
    // Methods from ::android::hardware::testgpio::V1_0::ITestgpio follow.
    Return<int32_t> set_gpio_up(int32_t gpio_index) override;
    Return<int32_t> set_gpio_down(int32_t gpio_index) override;
    Return<int32_t> testgpio_open() override;
	
    private:
    int openHal();
	testgpio_device_t *mDevice;
	int ret;
    // Methods from ::android::hidl::base::V1_0::IBase follow.

};

// FIXME: most likely delete, this is only for passthrough implementations
// extern "C" ITestgpio* HIDL_FETCH_ITestgpio(const char* name);

}  // namespace implementation
}  // namespace V1_0
}  // namespace testgpio
}  // namespace hardware
}  // namespace android

#endif  

修改hardware\interfaces\testgpio\1.0\default\Testgpio.cpp

#include "Testgpio.h"
#include <utils/Log.h>
#include <inttypes.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include "Tes
  • 3
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android Strongbox的HAL(Hardware Abstraction Layer)层是为了提供安全的密钥存储和加密功能而设计的。下面是Android Strongbox HAL层的实现逻辑概述: 1. 初始化:Strongbox HAL在设备启动时进行初始化。它首先建立与安全芯片的通信通道,并验证芯片的完整性和安全性。这个通道将用于后续的密钥生成、存储和操作。 2. 密钥生成和存储:Strongbox HAL提供API供应用程序生成和存储密钥。应用程序可以指定密钥的类型、长度和属性等参数。Strongbox HAL通过与安全芯片进行交互,在芯片内部生成和存储密钥对。这确保了密钥的安全性,因为密钥不会离开安全芯片。 3. 加密和解密:应用程序可以通过Strongbox HAL调用加密和解密API来使用Strongbox芯片执行加密和解密操作。Strongbox HAL将加密和解密请求传递给安全芯片,并将结果返回给应用程序。实际的加密和解密操作在芯片内部的安全执行环境(TEE)中进行,确保了数据的安全性。 4. 密钥保护和访问控制:Strongbox HAL负责保护存储在Strongbox芯片中的密钥,并提供访问控制机制。只有授权的应用程序才能访问Strongbox芯片中的密钥,并且只能执行特定的操作,如加密、解密或签名。这种访问控制机制确保了密钥的安全性和隐私性。 5. 密钥生命周期管理:Strongbox HAL提供API用于管理密钥的生命周期。应用程序可以调用这些API来生成、导入、删除和销毁Strongbox芯片中的密钥。这使得应用程序能够灵活地管理密钥,以适应不同的安全需求。 6. 安全芯片状态监测:Strongbox HAL负责监测安全芯片的状态。它会定期检查芯片的完整性和安全性,并通过错误处理机制提供相应的错误提示和处理。这确保了Strongbox芯片的可靠性和安全性。 总体而言,Android Strongbox HAL层通过与安全芯片进行通信和交互,提供了安全的密钥存储和加密功能。它管理密钥的生成、存储和生命周期,并提供访问控制和错误处理机制,以确保系统的安全性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值