harmony 鸿蒙CPU特性
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添加导入目录
makefile add_subdirectory(cpu_features) # 添加子目录到工程 target_link_libraries(entry PUBLIC CpuFeature::cpu_features) # 添加需要链接依赖的库文件
- 解压后目录结构如下
在代码中加入判断CPU特性支持能力语句,如下以支持ARM与AARCH64两种架构举例: “` c … // 包含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) { // Run optimized code. } else { // Run standard code. } } “`
说明:cpu_features库实际上是通过/proc/cpuinfo,与getauxval接口从内核中读取对应的CPU特性信息,有可能由于应用沙盒的原因导致无法读取对应的信息,注意错误处理。
你可能感兴趣的鸿蒙文章
harmony 鸿蒙使用MindSpore Lite引擎进行模型推理
harmony 鸿蒙使用MindSpore Lite进行离线模型的转换及推理
- 所属分类: 后端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦