| Safe Haskell | Safe-Inferred | 
|---|---|
| Language | Haskell2010 | 
Vulkan.Extensions.VK_KHR_maintenance1
Description
Name
VK_KHR_maintenance1 - device extension
VK_KHR_maintenance1
- Name String
- VK_KHR_maintenance1
- Extension Type
- Device extension
- Registered Extension Number
- 70
- Revision
- 2
- Ratification Status
- Ratified
- Extension and Version Dependencies; Deprecation State
- Promoted to Vulkan 1.1
 
- Contact
Other Extension Metadata
- Last Modified Date
- 2018-03-13
- Interactions and External Dependencies
- Promoted to Vulkan 1.1 Core
 
- Contributors
- Dan Ginsburg, Valve
- Daniel Koch, NVIDIA
- Daniel Rakos, AMD
- Jan-Harald Fredriksen, ARM
- Faith Ekstrand, Intel
- Jeff Bolz, NVIDIA
- Jesse Hall, Google
- John Kessenich, Google
- Michael Worcester, Imagination Technologies
- Neil Henning, Codeplay Software Ltd.
- Piers Daniell, NVIDIA
- Slawomir Grajewski, Intel
- Tobias Hector, Imagination Technologies
- Tom Olson, ARM
 
Description
VK_KHR_maintenance1 adds a collection of minor features that were
 intentionally left out or overlooked from the original Vulkan 1.0
 release.
The new features are as follows:
- Allow 2D and 2D array image views to be created from 3D images, which can then be used as color framebuffer attachments. This allows applications to render to slices of a 3D image.
- Support cmdCopyImagebetween 2D array layers and 3D slices. This extension allows copying from layers of a 2D array image to slices of a 3D image and vice versa.
- Allow negative height to be specified in the
     Viewport::heightfield to perform y-inversion of the clip-space to framebuffer-space transform. This allows apps to avoid having to usegl_Position.y = -gl_Position.yin shaders also targeting other APIs.
- Allow implementations to express support for doing just transfers
     and clears of image formats that they otherwise support no other
     format features for. This is done by adding new format feature flags
     FORMAT_FEATURE_TRANSFER_SRC_BIT_KHRandFORMAT_FEATURE_TRANSFER_DST_BIT_KHR.
- Support cmdFillBufferon transfer-only queues. PreviouslycmdFillBufferwas defined to only work on command buffers allocated from command pools which support graphics or compute queues. It is now allowed on queues that just support transfer operations.
- Fix the inconsistency of how error conditions are returned between
     the createGraphicsPipelinesandcreateComputePipelinesfunctions and theallocateDescriptorSetsandallocateCommandBuffersfunctions.
- Add new ERROR_OUT_OF_POOL_MEMORY_KHRerror so implementations can give a more precise reason forallocateDescriptorSetsfailures.
- Add a new command trimCommandPoolKHRwhich gives the implementation an opportunity to release any unused command pool memory back to the system.
Promotion to Vulkan 1.1
All functionality in this extension is included in core Vulkan 1.1, with the KHR suffix omitted. The original type, enum and command names are still available as aliases of the core functionality.
New Commands
New Bitmasks
New Enum Constants
- KHR_MAINTENANCE1_SPEC_VERSION
- KHR_MAINTENANCE_1_EXTENSION_NAME
- KHR_MAINTENANCE_1_SPEC_VERSION
- Extending - FormatFeatureFlagBits:
- Extending - ImageCreateFlagBits:
- Extending - Result:
Issues
- Are viewports with zero height allowed? - RESOLVED: Yes, although they have low utility. 
Version History
- Revision 1, 2016-10-26 (Piers Daniell) - Internal revisions
 
- Revision 2, 2018-03-13 (Jon Leech) - Add issue for zero-height viewports
 
See Also
CommandPoolTrimFlagsKHR, trimCommandPoolKHR
Document Notes
For more information, see the Vulkan Specification
This page is a generated document. Fixes and changes should be made to the generator scripts, not directly.
Documentation
pattern KHR_MAINTENANCE1_SPEC_VERSION :: Integral a => a Source #
pattern KHR_MAINTENANCE1_EXTENSION_NAME :: (Eq a, IsString a) => a Source #
pattern ERROR_OUT_OF_POOL_MEMORY_KHR :: Result Source #
trimCommandPoolKHR :: MonadIO io => Device -> CommandPool -> CommandPoolTrimFlags -> io () Source #
type KHR_MAINTENANCE_1_SPEC_VERSION = 2 Source #
pattern KHR_MAINTENANCE_1_SPEC_VERSION :: forall a. Integral a => a Source #
type KHR_MAINTENANCE_1_EXTENSION_NAME = "VK_KHR_maintenance1" Source #
pattern KHR_MAINTENANCE_1_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a Source #