diff --git a/README_OpenHarmony.md b/README_OpenHarmony.md new file mode 100644 index 0000000..83a7cdf --- /dev/null +++ b/README_OpenHarmony.md @@ -0,0 +1,53 @@ +# Vulkan API Headers + +仓库包含Vulkan API 和 API 注册表。Vulkan 是一个适用于高性能 3D 图形设备的低开销、跨平台 API。与 OpenGL ES (GLES) 一样,Vulkan 提供用于在应用中创建高品质实时图形的工具。与OpenGL ES相比使用 Vulkan 的优势明显,Vulkan可以大大降低 CPU 开销,另外Vulkan支持 SPIR-V 二进制Shader语言。 + +OpenHarmony引入后,在框架层新增加载程序(Vulkan-Loader),负责加GPU驱动实现、加载OpenHarmony平台的Vulkan WSI(Window System Integration, 窗口系统集成)实现,并对外开放Vulkan API。请参考[Vulkan-Loader](https://gitee.com/openharmony/third_party_vulkan-loader/blob/master/README_OpenHarmony.md) + + +## 南向开发和OpenHarmony发行版 + +设备成功运行Vulkan必需的条件: + 1. Vulkan-Loader,由OpenHarmony提供 + 2. 实现了Vulkan API 的 VulKan 驱动程序,由 SoC 提供。 + +### Vulkan Loader + +`third_party/vulkan-loader`中实现的Vulkan加载程序是Vulkan应用与Vulkan驱动之前的Wrapper层。安装在`/system/lib[64]/libvulkan.so`中。 +Vulkan Loader 会提供标准 Vulkan API 函数符号、OpenHarmony WSI扩展的函数符号,以及许多其他可选扩展。 + + +### Vulkan 驱动程序 + +Vulkan-Loader成功加载Vulkan驱动程序的必要条件 + 1.要参考[LoaderDriverInterface](https://gitee.com/openharmony/third_party_vulkan-loader/blob/master/docs/LoaderDriverInterface.md)实现对应的接口; + 2.提供驱动程序描述json文件,参考[加载GPU驱动](https://gitee.com/openharmony/third_party_vulkan-loader/blob/master/README_OpenHarmony.md#%E5%8A%A0%E8%BD%BDgpu%E9%A9%B1%E5%8A%A8); + 3.实现OpenHarmony平台的扩展包括`VK_OHOS_native_buffer`和`VK_OpenHarmony_external_memory_OHOS_native_buffer`扩展。 + + +## 北向应用开发者 + +### VK_OpenHarmony_OHOS_surface 扩展 + + 接口:vkCreateOHOSSurfaceOpenHarmony + VkResult vkCreateOHOSSurfaceOpenHarmony( + VkInstance instance, + const VkOHOSSurfaceCreateInfoOpenHarmony pCreateInfo, + const VkAllocationCallbacks pAllocator, + VkSurfaceKHR pSurface) + + 参数: + instance是要关联Surface的实例。 + pCreateInfo是一个指向结构的指针,该VkOHOSSurfaceCreateInfoOpenHarmony 结构包含影响表面对象创建的参数。 + pAllocator是用于在没有更多特定内存分配器可用时做为Surface对象分配的分配器。 + pSurface是一个指向VkSurfaceKHR句柄的指针,在该句柄中返回创建的Surface对象。 + + +## Vulkan使用文档 + +API官方文档 https://registry.khronos.org/vulkan/ + + +## License + +见 [LICENSE](LICENSE). diff --git a/README_zh.md b/README_zh.md deleted file mode 100644 index 9db46a4..0000000 --- a/README_zh.md +++ /dev/null @@ -1,49 +0,0 @@ -# Vulkan API Headers - -仓库包含Vulkan API 和 API 注册表。Vulkan 是一个适用于高性能 3D 图形设备的低开销、跨平台 API。与 OpenGL ES (GLES) 一样,Vulkan 提供用于在应用中创建高品质实时图形的工具。与OpenGL ES相比使用 Vulkan 的优势明显,Vulkan可以大大降低 CPU 开销,另外Vulkan支持 SPIR-V 二进制Shader语言。 - -OpenHarmony引入后,在框架层新增Vulkan Wrapper,负责实现Vulkan WSI(Window System Integration, 窗口系统集成) 与本地窗口(NativeWindow)对接,另外提供Vulkan加载程序。目前仅支持native层调用Vulkan。 - - -## 一、北向开发和OpenHarmony发行版 -### 1.实现 Vulkan - -设备成功运行Vulkan必需的条件: - 1. 加载程序,由OpenHarmony提供 - 2. 实现了Vulkan API 的 VulKan 驱动程序,有 SoC 提供。 - -### 2. Vulkan Wrapper - -`foundation/graphic/graphic_2d/frameworks/vulkan_wrapper`中实现的Vulkan加载程序是Vulkan应用与Vulkan驱动之前的Wrapper层。Vulkan Wrapper安装在`/system/lib[64]/libvulkan.so`中。Vulkan Wrapper 会提供标准 Vulkan API 函数符号、OpenHarmony WSI扩展的函数符号,以及许多其他可选扩展。 - - -### 3. Vulkan 驱动程序 - -Vulkan驱动程序需要对外暴露的函数符号请参考`hdi_vulkan.h`中的定义。 - -## 二、南向应用开发者 - -### VK_OpenHarmony_OHOS_surface 扩展 - - 接口:vkCreateOHOSSurfaceOpenHarmony - VkResult vkCreateOHOSSurfaceOpenHarmony( - VkInstance instance, - const VkOHOSSurfaceCreateInfoOpenHarmony pCreateInfo, - const VkAllocationCallbacks pAllocator, - VkSurfaceKHR pSurface) - - 参数: - instance是要关联Surface的实例。 - pCreateInfo是一个指向结构的指针,该VkOHOSSurfaceCreateInfoOpenHarmony 结构包含影响表面对象创建的参数。 - pAllocator是用于在没有更多特定内存分配器可用时做为Surface对象分配的分配器。 - pSurface是一个指向VkSurfaceKHR句柄的指针,在该句柄中返回创建的Surface对象。 - - -## 三、Vulkan使用文档 - -API官方文档 https://registry.khronos.org/vulkan/ - - -## 四、License - -见 [LICENSE](LICENSE). diff --git a/include/vulkan/vulkan.h b/include/vulkan/vulkan.h index 770cc89..85df4bc 100644 --- a/include/vulkan/vulkan.h +++ b/include/vulkan/vulkan.h @@ -85,6 +85,7 @@ #endif #ifdef VK_USE_PLATFORM_OHOS_OPENHARMONY +#include "buffer_handle.h" #include "vulkan_ohos.h" #endif diff --git a/include/vulkan/vulkan_ohos.h b/include/vulkan/vulkan_ohos.h index dfef926..7cec530 100644 --- a/include/vulkan/vulkan_ohos.h +++ b/include/vulkan/vulkan_ohos.h @@ -40,6 +40,80 @@ VKAPI_ATTR VkResult VKAPI_CALL vkCreateOHOSSurfaceOpenHarmony( VkSurfaceKHR* pSurface); #endif +#define VK_OHOS_native_buffer 1 + +#define VK_OHOS_NATIVE_BUFFER_SPEC_VERSION 1 +#define VK_OHOS_NATIVE_BUFFER_EXTENSION_NAME "VK_OHOS_native_buffer" + +typedef VkFlags VkSwapchainImageUsageFlagsOpenHarmony; +typedef enum VkSwapchainImageUsageFlagBitsOpenHarmony { + VK_SWAPCHAIN_IMAGE_USAGE_SHARED_BIT_OPENHARMONY = 0x00000001, + VK_SWAPCHAIN_IMAGE_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF +} VkSwapchainImageUsageFlagBitsOpenHarmony; + +typedef struct { + VkStructureType sType; + const void* pNext; + BufferHandle* handle; +} VkNativeBufferOpenHarmony; + +typedef struct { + VkStructureType sType; + const void* pNext; + VkSwapchainImageUsageFlagsOpenHarmony usage; +} VkSwapchainImageCreateInfoOpenHarmony; + +typedef struct { + VkStructureType sType; + const void* pNext; + VkBool32 sharedImage; +} VkPhysicalDevicePresentationPropertiesOpenHarmony; + +typedef VkResult (VKAPI_PTR *PFN_vkGetSwapchainGrallocUsageOpenHarmony)( + VkDevice device, + VkFormat format, + VkImageUsageFlags imageUsage, + uint64_t* grallocUsage); + +typedef VkResult (VKAPI_PTR *PFN_vkSetNativeFenceFdOpenHarmony)( + VkDevice device, + int32_t nativeFenceFd, + VkSemaphore semaphore, + VkFence fence); + +typedef VkResult (VKAPI_PTR *PFN_vkGetNativeFenceFdOpenHarmony)( + VkQueue queue, + uint32_t waitSemaphoreCount, + const VkSemaphore* pWaitSemaphores, + VkImage image, + int32_t* pNativeFenceFd); + +#ifndef VK_NO_PROTOTYPES + +VKAPI_ATTR VkResult VKAPI_CALL vkGetSwapchainGrallocUsageOpenHarmony( + VkDevice device, + VkFormat format, + VkImageUsageFlags imageUsage, + uint64_t* grallocUsage +); + +VKAPI_ATTR VkResult VKAPI_CALL vkSetNativeFenceFdOpenHarmony( + VkDevice device, + int32_t nativeFenceFd, + VkSemaphore semaphore, + VkFence fence +); + +VKAPI_ATTR VkResult VKAPI_CALL vkGetNativeFenceFdOpenHarmony( + VkQueue queue, + uint32_t waitSemaphoreCount, + const VkSemaphore* pWaitSemaphores, + VkImage image, + int32_t* pNativeFenceFd +); + +#endif + #define VK_OpenHarmony_external_memory_OHOS_native_buffer 1 struct OH_NativeBuffer; #define VK_OPENHARMONY_EXTERNAL_MEMORY_OHOS_NATIVE_BUFFER_SPEC_VERSION 1 diff --git a/registry/vk.xml b/registry/vk.xml index b9260fa..d0fc9ee 100644 --- a/registry/vk.xml +++ b/registry/vk.xml @@ -20548,8 +20548,8 @@ typedef void* MTLSharedEvent_id; - - + +