#ifndef _VKTIMAGELOADSTOREUTIL_HPP #define _VKTIMAGELOADSTOREUTIL_HPP /*------------------------------------------------------------------------ * Vulkan Conformance Tests * ------------------------ * * Copyright (c) 2016 The Khronos Group Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * *//*! * \file * \brief Image load/store utilities *//*--------------------------------------------------------------------*/ #include "tcuDefs.hpp" #include "tcuTextureUtil.hpp" #include "vkDefs.hpp" #include "vkImageUtil.hpp" #include "vktImageTestsUtil.hpp" #include "vktImageTexture.hpp" #include "tcuVector.hpp" #include "deSharedPtr.hpp" namespace vkt { namespace image { typedef de::SharedPtr > SharedVkDescriptorSet; typedef de::SharedPtr > SharedVkImageView; template inline de::SharedPtr > makeVkSharedPtr (vk::Move vkMove) { return de::SharedPtr >(new vk::Unique(vkMove)); } inline float computeStoreColorBias (const vk::VkFormat format) { return isSnormFormat(format) ? -1.0f : 0.0f; } inline bool isIntegerFormat (const vk::VkFormat format) { return isIntFormat(format) || isUintFormat(format); } inline bool isSignedFormat (const vk::VkFormat format) { return isIntFormat(format) || isSnormFormat(format) || isSfloatFormat(format); } inline bool colorScaleAndBiasAreValid (const vk::VkFormat format, const float colorScale, const float colorBias) { // Only normalized (fixed-point) formats may have scale/bias const bool integerOrFloatFormat = isIntFormat(format) || isUintFormat(format) || isFloatFormat(format); return !integerOrFloatFormat || (colorScale == 1.0f && colorBias == 0.0f); } float computeStoreColorScale (const vk::VkFormat format, const tcu::IVec3 imageSize); ImageType getImageTypeForSingleLayer (const ImageType imageType); vk::VkImageCreateInfo makeImageCreateInfo (const Texture& texture, const vk::VkFormat format, const vk::VkImageUsageFlags usage, const vk::VkImageCreateFlags flags, const vk::VkImageTiling tiling = vk::VK_IMAGE_TILING_OPTIMAL); vk::VkDeviceSize getOptimalUniformBufferChunkSize (const vk::InstanceInterface& vki, const vk::VkPhysicalDevice physDevice, vk::VkDeviceSize minimumRequiredChunkSizeBytes); bool isRepresentableIntegerValue (const tcu::Vector value, tcu::TextureFormat format); } // image } // vkt #endif // _VKTIMAGELOADSTOREUTIL_HPP