• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #ifndef _VKPIPELINEBINARYUTIL_HPP
2 #define _VKPIPELINEBINARYUTIL_HPP
3 /*------------------------------------------------------------------------
4  * Vulkan Conformance Tests
5  * ------------------------
6  *
7  * Copyright (c) 2024 The Khronos Group Inc.
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *      http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  *//*!
22  * \file
23  * \brief Utilities for pipeline binaries.
24  *//*--------------------------------------------------------------------*/
25 
26 #include "vkDefs.hpp"
27 #include "vkRef.hpp"
28 #include <vector>
29 #include <limits>
30 
31 #ifndef CTS_USES_VULKANSC
32 
33 namespace vk
34 {
35 
36 class PipelineBinaryWrapper
37 {
38 public:
39     PipelineBinaryWrapper(const DeviceInterface &vk, const VkDevice vkDevice);
40 
41     // Generate unique key for whole pipeline basing on create info. Note: pNext chain from PipelineCreateInfo must be available
42     VkPipelineBinaryKeyKHR getPipelineKey(const void *pPipelineCreateInfo) const;
43 
44     VkResult createPipelineBinariesFromPipeline(VkPipeline pipeline);
45     VkResult createPipelineBinariesFromInternalCache(const void *pPipelineCreateInfo);
46     VkResult createPipelineBinariesFromBinaryData(const std::vector<VkPipelineBinaryDataKHR> &pipelineDataInfo);
47     VkResult createPipelineBinariesFromCreateInfo(const VkPipelineBinaryCreateInfoKHR &createInfos);
48 
49     void getPipelineBinaryData(std::vector<VkPipelineBinaryDataKHR> &pipelineDataInfo,
50                                std::vector<std::vector<uint8_t>> &pipelineDataBlob);
51 
52     void deletePipelineBinariesAndKeys(void);
53     void deletePipelineBinariesKeepKeys(void);
54 
55     VkPipelineBinaryInfoKHR preparePipelineBinaryInfo(void) const;
56 
57     uint32_t getKeyCount(void) const;
58     uint32_t getBinariesCount(void) const;
59 
60     const VkPipelineBinaryKeyKHR *getBinaryKeys(void) const;
61     const VkPipelineBinaryKHR *getPipelineBinaries(void) const;
62 
63 protected:
64     const DeviceInterface &m_vk;
65     const VkDevice m_device;
66 
67     std::vector<VkPipelineBinaryKeyKHR> m_binaryKeys;
68     std::vector<Move<VkPipelineBinaryKHR>> m_binaries;
69     std::vector<VkPipelineBinaryKHR> m_binariesRaw;
70 };
71 
72 } // namespace vk
73 
74 #endif // CTS_USES_VULKANSC
75 
76 #endif // _VKPIPELINEBINARYUTIL_HPP
77