CPU特性
CPU特性是CPU提供的一些硬件扩展。开发者可以通过调用指令,设置特殊寄存器来使用这些CPU特性,例如ARMv7a架构上的VFP-v32d32、NEON、IDIV、AES等CPU特性。很多CPU特性是可选的,不同厂商的CPU通常有不同的特性。
在OpenHarmony原生库开发中,如何使用CPU特性?如何在代码中处理CPU特性相关的代码?本章节将提供一些方法,以便帮助开发者开发出既能保持兼容性,又能利用CPU特有能力的应用。
OpenHarmony系统当前没有提供获取CPU特性的接口,开发者可以导入现有开源社区的库函数,具体可以参考如下的例子;也可直接读取/proc/cpuinfo,或者调用libc getauxval(AT_HWCAP)接口来获取设备的CPU特性。
使用建议
- 在OpenHarmony系统C++工程中引入开源库,下载cpu_features库,解压到工程的cpp目录下。如下以IDE C++模版示例应用举例:
- 解压后目录结构如下
MyApplication
- 解压后目录结构如下
|-- entry |-- src |-- main |-- cpp |--cpu_features |--CMakeLists.txt |--hello.cpp ```
- 在CMakeLists.txt添加导入目录
add_subdirectory(cpu_features) # 添加子目录到工程 target_link_libraries(entry PUBLIC CpuFeature::cpu_features) # 添加需要链接依赖的库文件
-
在代码中加入判断CPU特性支持能力语句,如下以支持ARM与AARCH64两种架构举例:
... // 包含CPU架构目标检测头文件 #include "cpu_features_macros.h" // 在ARM架构上,这个宏在上面头文件中根据目标自动定义 #if defined (CPU_FEATURES_ARCH_ARM) #include "cpuinfo_arm.h" // 包含ARM架构的cpuinfo头文件 #elif defined (CPU_FEATURES_ARCH_AARCH64) #include "cpuinfo_aarch64.h" // 包含ARM64架构的cpuinfo头文件 #endif // C++代码, 需要添加`using namespace cpu_features;` // 根据不同架构,获取相应的CPU特性信息; #if defined (CPU_FEATURES_ARCH_ARM) static const ArmFeatures features = GetArmInfo().features; #elif defined (CPU_FEATURES_ARCH_AARCH64) static const Aarch64Features features = GetAarch64Info().features; #endif void Compute(void) { // 根据features的字段进行支持CPU features的特性判断 if (features.aes) { // ... } else { // ... } }
说明:
cpu_features库实际上是通过/proc/cpuinfo,与getauxval接口从内核中读取对应的CPU特性信息,有可能由于应用沙盒的原因导致无法读取对应的信息,注意错误处理。