blob: 4f16b0ffb5338700e18d197397c2be2076f27a7f [file] [log] [blame]
// Copyright 2023 The Khronos Group Inc.
//
// SPDX-License-Identifier: CC-BY-4.0
:imageparam: srcImage
:imagesubresource: imageSubresource
// Common Valid Usage
* If pname:{imageparam} is of type ename:VK_IMAGE_TYPE_1D, then for each element
of pname:pRegions, pname:imageOffset.y must: be `0` and pname:imageExtent.height must: be `1`
* For each element of pname:pRegions, pname:imageOffset.z and
[eq]#(pname:imageExtent.depth {plus} pname:imageOffset.z)# must: both be
greater than or equal to `0` and less than or equal to the depth of the specified pname:{imagesubresource} of pname:{imageparam}
* If pname:{imageparam} is of type ename:VK_IMAGE_TYPE_1D or ename:VK_IMAGE_TYPE_2D, then for each element of pname:pRegions, pname:imageOffset.z must: be `0` and pname:imageExtent.depth must: be `1`
* For each element of pname:pRegions, pname:bufferRowLength must: be a
multiple of the <<formats-compatibility-classes,texel block extent width>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, pname:bufferImageHeight must: be a
multiple of the <<formats-compatibility-classes,texel block extent height>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, pname:imageOffset.x must: be a
multiple of the <<formats-compatibility-classes,texel block extent width>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, pname:imageOffset.y must: be a
multiple of the <<formats-compatibility-classes,texel block extent height>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, pname:imageOffset.z must: be a
multiple of the <<formats-compatibility-classes,texel block extent depth>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, if the sum of pname:imageOffset.x
and pname:extent.width does not equal the width of the subresource specified by pname:srcSubresource, pname:extent.width must: be a multiple of the <<formats-compatibility-classes,texel block extent width>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, if the sum of pname:imageOffset.y
and pname:extent.height does not equal the height of the subresource specified by pname:srcSubresource, pname:extent.height must: be a multiple of the <<formats-compatibility-classes,texel block extent
height>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, if the sum of pname:imageOffset.z
and pname:extent.depth does not equal the depth of the subresource specified by pname:srcSubresource, pname:extent.depth must: be a
multiple of the <<formats-compatibility-classes,texel block extent
depth>> of the elink:VkFormat of pname:{imageparam}
* For each element of pname:pRegions, pname:{imagesubresource}.aspectMask must: specify aspects present in pname:{imageparam}
ifdef::VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion[]
* If pname:{imageparam} has a elink:VkFormat with <<formats-requiring-sampler-ycbcr-conversion,two planes>> then for each
element of pname:pRegions, pname:{imagesubresource}.aspectMask must: be
ename:VK_IMAGE_ASPECT_PLANE_0_BIT or ename:VK_IMAGE_ASPECT_PLANE_1_BIT
* If pname:{imageparam} has a elink:VkFormat with
<<formats-requiring-sampler-ycbcr-conversion,three planes>> then for
each element of pname:pRegions, pname:{imagesubresource}.aspectMask must: be ename:VK_IMAGE_ASPECT_PLANE_0_BIT, ename:VK_IMAGE_ASPECT_PLANE_1_BIT, or ename:VK_IMAGE_ASPECT_PLANE_2_BIT
endif::VK_VERSION_1_1,VK_KHR_sampler_ycbcr_conversion[]
* If pname:{imageparam} is of type ename:VK_IMAGE_TYPE_3D, for each element of
pname:pRegions, pname:{imagesubresource}.baseArrayLayer must: be `0` and pname:{imagesubresource}.layerCount must: be `1`
* For each element of pname:pRegions, pname:bufferRowLength divided by the <<formats-compatibility-classes,texel block extent width>> and then multiplied by the texel block size of pname:{imageparam} must: be less than or equal to [eq]#2^31^-1#
// Common Valid Usage