third_party_vulkan-loader/README_OpenHarmony.md
shegangbin 4603b3a932 standardize OH extension api
Signed-off-by: shegangbin <shegangbin1@huawei.com>
Change-Id: I854a1a67f1337482279c300dcc37f6637c638f7e
2023-06-19 11:42:13 +08:00

5.1 KiB
Raw Blame History

Vulkan-Loader

本仓库包含开源软件Vulkan-Loader为OpenHarmony提供对Vulkan的支持能力。

Vulkan是一个跨平台的2D和3D绘图应用程序接口API。它的API分为核心API、窗口系统集成(WSI)扩展API以及其他扩展API。

核心API由GPU驱动实现窗口系统集成(WSI)扩展API由swapchain_layer实现swapchain_layer是OpenHarmony平台是实现的一个Vulkan Layer安装在/system/lib[64]/libvulkan_swapchain.so中。Vulkan Layer属于增强Vulkan开发环境的扩展功能被实现为动态链接库(.so文件)。

Vulkan-Loader会加载这些API的实现并对外提供这些接口给应用开发者使用。Vulkan-Loader安装在/system/lib[64]/libvulkan.so中。

Vulkan-Loader主要功能概括如下:

1、加载GPU驱动。

2、加载Vulkan Layer。

3、提供Vulkan NDK接口。

vulkan-loader_location_in_OH

加载GPU驱动

在OpenHarmony上Vulkan-Loader会扫描指定路径下的GPU驱动的json清单文件并读取该文件加载GPU驱动。

指定的扫描路径

/vendor/etc/vulkan/icd.d/
/system/etc/vulkan/icd.d/
/data/vulkan/icd.d/

建议GPU驱动的json清单文件应放在/vendor/etc/vulkan/icd.d/目录中。

Vulkan-Loader会根据GPU驱动的json清单文件中配置的library_path找到GPU驱动的动态链接库文件(.so文件)并加载。

GPU驱动的json清单文件示例

{
   "file_format_version": "1.0.1",
   "ICD": {
      "library_path": "path to driver library",
      "api_version": "1.2.205",
      "library_arch" : "64",
      "is_portability_driver": false
   }
}

详细介绍请见:Driver Manifest File Format

GPU驱动的实现

GPU驱动需要实现的Vulkan接口请参考文档LoaderDriverInterface开发者需要按照文档里的要求实现对应的接口才能够被Vulkan-Loader正确加载。

加载Vulkan Layer

Vulkan Layer属于增强Vulkan开发环境的扩展功能可以由开发人员启用或关闭。启用和关闭Vulkan Layer的方式有很多可以通过环境变量、配置文件、或者代码来开启和关闭指定的Layer。

在OpenHarmony上Vulkan-Loader通过读取指定路径下的Layer的json清单文件加载Vulkan Layer。

指定的扫描路径

/system/etc/vulkan/implicit_layer.d/
/system/etc/vulkan/explicit_layer.d/
/data/vulkan/implicit_layer.d/
/data/vulkan/explicit_layer.d/

默认加载的layer的json文件应放在xxx/implicit_layer.d/下。 需要显式加载的layer的json文件应放在xxx/explicit_layer.d/不会被Vulkan-Loader默认加载。

Vulkan Layer的json清单文件示例

下面给出swapchain_layer的json清单文件示例

{
    "file_format_version" : "1.0.0",
    "layer" : {
        "name": "VK_LAYER_OHOS_surface",
        "type": "GLOBAL",
        "library_path": "libvulkan_swapchain.so",
        "api_version": "1.3.231",
        "implementation_version": "1",
        "description": "Vulkan Swapchain",
        "disable_environment": {
            "DISABLE_OHOS_SWAPCHAIN_LAYER": "1"
        },
        "instance_extensions": [
            { "name": "VK_KHR_surface", "spec_version": "25" },
            { "name": "VK_OHOS_surface", "spec_version": "1" }
        ],
        "device_extensions": [
            { "name": "VK_KHR_swapchain", "spec_version": "70" }
        ]
    }
}

详细介绍请见:Layer Manifest File Format

Vulkan Layer的实现

Vulkan Layer需要实现的Vulkan接口请参考文档LoaderLayerInterface开发者需要按照文档里的要求实现对应的接口才能够被Vulkan-Loader正确加载。

swapchain_layer

swapchain_layer是实现Vulkan-Loader与OpenHarmony平台本地窗口(OHNativeWindow)对接的模块作为一个隐式加载的Vulkan Layer使用。

代码地址:swapchain_layer

Vulkan NDK

在OpenHarmony上Vulkan-Loader会提供Vulkan NDK接口应用层软件(如图形引擎、XComponent NAPI等)和系统层图形绘制模块(如Skia)可以调用这些NDK接口。

构建指导

适配OpenHarmony平台的编译脚本请见openharmony/BUILD.gn

由于graphic_standard模块的编译脚本中包含了Vulkan-Loader详见bundle.json所以编译graphic_standard模块可以将Vulkan-Loader同时编译出来以rk3568平台为例编译命令

./build.sh --product-name rk3568 --ccache --build-target graphic_standard

也可以单独编译Vulkan-Loader

./build.sh --product-name rk3568 --ccache --build-target vulkan_loader

编译完成后会在out/rk3568/graphic/graphic_standard目录下生成libvulkan.so

License

Apache License 2.0

LICENSE.