| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
Vulkan.Extensions.VK_AMD_display_native_hdr
Description
Name
VK_AMD_display_native_hdr - device extension
VK_AMD_display_native_hdr
- Name String
- VK_AMD_display_native_hdr
- Extension Type
- Device extension
- Registered Extension Number
- 214
- Revision
- 1
- Extension and Version Dependencies
- Requires Vulkan 1.0
- Requires VK_KHR_get_physical_device_properties2
- Requires VK_KHR_get_surface_capabilities2
- Requires VK_KHR_swapchain
 
- Contact
Other Extension Metadata
- Last Modified Date
- 2018-12-18
- IP Status
- No known IP claims.
- Contributors
- Matthaeus G. Chajdas, AMD
- Aaron Hagan, AMD
- Aric Cyr, AMD
- Timothy Lottes, AMD
- Derrick Owens, AMD
- Daniel Rakos, AMD
 
Description
This extension introduces the following display native HDR features to Vulkan:
- A new ColorSpaceKHRenum for setting the native display colorspace. For example, this color space would be set by the swapchain to use the native color space in Freesync2 displays.
- Local dimming control
New Commands
New Structures
New Enum Constants
- AMD_DISPLAY_NATIVE_HDR_SPEC_VERSION
- Extending - ColorSpaceKHR:
- Extending - StructureType:
Issues
None.
Examples
None.
Version History
- Revision 1, 2018-12-18 (Daniel Rakos) - Initial revision
 
See Also
DisplayNativeHdrSurfaceCapabilitiesAMD,
 SwapchainDisplayNativeHdrCreateInfoAMD, setLocalDimmingAMD
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.
Synopsis
- setLocalDimmingAMD :: forall io. MonadIO io => Device -> SwapchainKHR -> ("localDimmingEnable" ::: Bool) -> io ()
- data DisplayNativeHdrSurfaceCapabilitiesAMD = DisplayNativeHdrSurfaceCapabilitiesAMD {}
- data SwapchainDisplayNativeHdrCreateInfoAMD = SwapchainDisplayNativeHdrCreateInfoAMD {}
- type AMD_DISPLAY_NATIVE_HDR_SPEC_VERSION = 1
- pattern AMD_DISPLAY_NATIVE_HDR_SPEC_VERSION :: forall a. Integral a => a
- type AMD_DISPLAY_NATIVE_HDR_EXTENSION_NAME = "VK_AMD_display_native_hdr"
- pattern AMD_DISPLAY_NATIVE_HDR_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
- newtype SwapchainKHR = SwapchainKHR Word64
- newtype ColorSpaceKHR where- ColorSpaceKHR Int32
- pattern COLOR_SPACE_DISPLAY_P3_LINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_SRGB_NONLINEAR_KHR :: ColorSpaceKHR
- pattern COLOR_SPACE_DISPLAY_NATIVE_AMD :: ColorSpaceKHR
- pattern COLOR_SPACE_EXTENDED_SRGB_NONLINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_PASS_THROUGH_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_ADOBERGB_NONLINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_ADOBERGB_LINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_HDR10_HLG_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_DOLBYVISION_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_HDR10_ST2084_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_BT2020_LINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_BT709_NONLINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_BT709_LINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_DCI_P3_NONLINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT :: ColorSpaceKHR
- pattern COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT :: ColorSpaceKHR
 
Documentation
Arguments
| :: forall io. MonadIO io | |
| => Device | 
 | 
| -> SwapchainKHR | 
 | 
| -> ("localDimmingEnable" ::: Bool) | 
 | 
| -> io () | 
vkSetLocalDimmingAMD - Set Local Dimming
Valid Usage (Implicit)
-  devicemust be a validDevicehandle
-  swapChainmust be a validSwapchainKHRhandle
-  Both of device, andswapChainmust have been created, allocated, or retrieved from the sameInstance
Valid Usage
- 
     DisplayNativeHdrSurfaceCapabilitiesAMD::localDimmingSupportmust be supported
See Also
data DisplayNativeHdrSurfaceCapabilitiesAMD Source #
VkDisplayNativeHdrSurfaceCapabilitiesAMD - Structure describing display native HDR specific capabilities of a surface
Valid Usage (Implicit)
See Also
Constructors
| DisplayNativeHdrSurfaceCapabilitiesAMD | |
| Fields 
 | |
Instances
data SwapchainDisplayNativeHdrCreateInfoAMD Source #
VkSwapchainDisplayNativeHdrCreateInfoAMD - Structure specifying display native HDR parameters of a newly created swapchain object
Description
If the pNext chain of
 SwapchainCreateInfoKHR does not
 include this structure, the default value for localDimmingEnable is
 TRUE, meaning local dimming is
 initially enabled for the swapchain.
Valid Usage (Implicit)
Valid Usage
- 
     It is only valid to set localDimmingEnabletoTRUEifDisplayNativeHdrSurfaceCapabilitiesAMD::localDimmingSupportis supported
See Also
Constructors
| SwapchainDisplayNativeHdrCreateInfoAMD | |
| Fields 
 | |
Instances
type AMD_DISPLAY_NATIVE_HDR_SPEC_VERSION = 1 Source #
pattern AMD_DISPLAY_NATIVE_HDR_SPEC_VERSION :: forall a. Integral a => a Source #
type AMD_DISPLAY_NATIVE_HDR_EXTENSION_NAME = "VK_AMD_display_native_hdr" Source #
pattern AMD_DISPLAY_NATIVE_HDR_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a Source #
newtype SwapchainKHR Source #
VkSwapchainKHR - Opaque handle to a swapchain object
Description
A swapchain is an abstraction for an array of presentable images that
 are associated with a surface. The presentable images are represented by
 Image objects created by the platform. One image
 (which can be an array image for multiview/stereoscopic-3D surfaces)
 is displayed at a time, but multiple images can be queued for
 presentation. An application renders to the image, and then queues the
 image for presentation to the surface.
A native window cannot be associated with more than one non-retired swapchain at a time. Further, swapchains cannot be created for native windows that have a non-Vulkan graphics API surface associated with them.
Note
The presentation engine is an abstraction for the platform’s compositor or display engine.
The presentation engine may be synchronous or asynchronous with respect to the application and/or logical device.
Some implementations may use the device’s graphics queue or dedicated presentation hardware to perform presentation.
The presentable images of a swapchain are owned by the presentation
 engine. An application can acquire use of a presentable image from the
 presentation engine. Use of a presentable image must occur only after
 the image is returned by
 acquireNextImageKHR, and before it
 is released by queuePresentKHR.
 This includes transitioning the image layout and rendering commands.
An application can acquire use of a presentable image with
 acquireNextImageKHR. After
 acquiring a presentable image and before modifying it, the application
 must use a synchronization primitive to ensure that the presentation
 engine has finished reading from the image. The application can then
 transition the image’s layout, queue rendering commands to it, etc.
 Finally, the application presents the image with
 queuePresentKHR, which releases the
 acquisition of the image.
The presentation engine controls the order in which presentable images are acquired for use by the application.
Note
This allows the platform to handle situations which require out-of-order return of images after presentation. At the same time, it allows the application to generate command buffers referencing all of the images in the swapchain at initialization time, rather than in its main loop.
See Also
VK_KHR_swapchain,
 AcquireNextImageInfoKHR,
 BindImageMemorySwapchainInfoKHR,
 ImageSwapchainCreateInfoKHR,
 PresentInfoKHR,
 SwapchainCreateInfoKHR,
 acquireFullScreenExclusiveModeEXT,
 acquireNextImageKHR,
 createSharedSwapchainsKHR,
 createSwapchainKHR,
 destroySwapchainKHR,
 getPastPresentationTimingGOOGLE,
 getRefreshCycleDurationGOOGLE,
 getSwapchainCounterEXT,
 getSwapchainImagesKHR,
 getSwapchainStatusKHR,
 queuePresentKHR,
 releaseFullScreenExclusiveModeEXT,
 setHdrMetadataEXT,
 setLocalDimmingAMD,
 waitForPresentKHR
Constructors
| SwapchainKHR Word64 | 
Instances
newtype ColorSpaceKHR Source #
VkColorSpaceKHR - Supported color space of the presentation engine
Description
Note
In the initial release of the VK_KHR_surface and VK_KHR_swapchain
 extensions, the token COLORSPACE_SRGB_NONLINEAR_KHR was used. Starting
 in the 2016-05-13 updates to the extension branches, matching release
 1.0.13 of the core API specification, COLOR_SPACE_SRGB_NONLINEAR_KHR
 is used instead for consistency with Vulkan naming rules. The older enum
 is still available for backwards compatibility.
Note
In older versions of this extension COLOR_SPACE_DISPLAY_P3_LINEAR_EXT
 was misnamed
 COLOR_SPACE_DCI_P3_LINEAR_EXT.
 This has been updated to indicate that it uses RGB color encoding, not
 XYZ. The old name is deprecated but is maintained for backwards
 compatibility.
The color components of non-linear color space swap chain images must
 have had the appropriate transfer function applied. The color space
 selected for the swap chain image will not affect the processing of data
 written into the image by the implementation. Vulkan requires that all
 implementations support the sRGB transfer function by use of an SRGB
 pixel format. Other transfer functions, such as SMPTE 170M or SMPTE2084,
 can be performed by the application shader. This extension defines
 enums for ColorSpaceKHR that correspond to the following color spaces:
| Name | Red Primary | Green Primary | Blue Primary | White-point | Transfer function | 
|---|---|---|---|---|---|
| DCI-P3 | 1.000, 0.000 | 0.000, 1.000 | 0.000, 0.000 | 0.3333, 0.3333 | DCI P3 | 
| Display-P3 | 0.680, 0.320 | 0.265, 0.690 | 0.150, 0.060 | 0.3127, 0.3290 (D65) | Display-P3 | 
| BT709 | 0.640, 0.330 | 0.300, 0.600 | 0.150, 0.060 | 0.3127, 0.3290 (D65) | ITU (SMPTE 170M) | 
| sRGB | 0.640, 0.330 | 0.300, 0.600 | 0.150, 0.060 | 0.3127, 0.3290 (D65) | sRGB | 
| extended sRGB | 0.640, 0.330 | 0.300, 0.600 | 0.150, 0.060 | 0.3127, 0.3290 (D65) | extended sRGB | 
| HDR10_ST2084 | 0.708, 0.292 | 0.170, 0.797 | 0.131, 0.046 | 0.3127, 0.3290 (D65) | ST2084 PQ | 
| DOLBYVISION | 0.708, 0.292 | 0.170, 0.797 | 0.131, 0.046 | 0.3127, 0.3290 (D65) | ST2084 PQ | 
| HDR10_HLG | 0.708, 0.292 | 0.170, 0.797 | 0.131, 0.046 | 0.3127, 0.3290 (D65) | HLG | 
| AdobeRGB | 0.640, 0.330 | 0.210, 0.710 | 0.150, 0.060 | 0.3127, 0.3290 (D65) | AdobeRGB | 
Color Spaces and Attributes
The transfer functions are described in the “Transfer Functions” chapter of the Khronos Data Format Specification.
Except Display-P3 OETF, which is:
[begin{aligned} E & = begin{cases} 1.055 times L^{1 over 2.4} - 0.055 & text{for} 0.0030186 leq L leq 1 -- 12.92 times L & text{for} 0 leq L < 0.0030186
Constructors
| ColorSpaceKHR Int32 | 
Bundled Patterns
| pattern COLOR_SPACE_DISPLAY_P3_LINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_SRGB_NONLINEAR_KHR :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_DISPLAY_NATIVE_AMD :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_EXTENDED_SRGB_NONLINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_PASS_THROUGH_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_ADOBERGB_NONLINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_ADOBERGB_LINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_HDR10_HLG_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_DOLBYVISION_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_HDR10_ST2084_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_BT2020_LINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_BT709_NONLINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_BT709_LINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_DCI_P3_NONLINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT :: ColorSpaceKHR | 
 | 
| pattern COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT :: ColorSpaceKHR | 
 |