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特性。

使用建议

  1. 在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) # 添加需要链接依赖的库文件
    
  1. 在代码中加入判断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特性信息,有可能由于应用沙盒的原因导致无法读取对应的信息,注意错误处理。