mbox series

[0/6] powervr: MT8173 GPU support

Message ID 20240530083513.4135052-1-wenst@chromium.org (mailing list archive)
Headers show
Series powervr: MT8173 GPU support | expand

Message

Chen-Yu Tsai May 30, 2024, 8:34 a.m. UTC
Hi everyone,

This series enables the PowerVR GPU found in the MT8173 SoC, found in
some Chromebooks.

This version is different from the initial powervr driver submission [1]
in that it splits out the GPU glue layer support out of the powervr
driver and into a separate clock and power domain driver. The glue code
is otherwise the same, and also the same as found in the ChromeOS
kernels, with some extra comments and macro names added where possible.

Patch 1 adds a binding for the glue layer, called mfgtop. The glue layer
contains clock and power controls for the GPU.

Patch 2 adds a driver for the glue layer.

Patch 3 adds an entry for the MT8173 GPU and 6XT series to the PowerVR
binding.

Patch 4 adds an entry for the PowerVR 6XT series GPU to the driver.

Patch 5 corrects the clock for the GPU (called MFG) power domain.

Patch 6 adds device nodes for the GPU and glue layer to the MT8173 dtsi
file.

Patch 2 and 6 depend on patch 1 to build. I suppose some common
immutable tree would be needed from the MediaTek maintainers.

The kernel driver successfully probes the hardware and loads the
"rogue_4.40.2.51_v1.fw" firmware provided by Imagination Technologies [2].
Userspace was tested with Mesa 24.0.8 from Debian Trixie rebuilt with
the powervr vulkan driver enabled. `vulkaninfo` gives some information
about the GPU (attached at the end), but running the `triangle` example
from the Sascha Willems demos [3] with -DUSE_D2D_WSI=ON as recommended [4]
failed with:

    Can't find a display and a display mode!

Same program worked correctly on a BeaglePlay and displayed a color
gradient triangle. Not sure what went wrong here.

Anyway, please have a look and test.


Thanks
ChenYu

[1] https://lore.kernel.org/dri-devel/20220815165156.118212-2-sarah.walker@imgtec.com/
[2] https://gitlab.freedesktop.org/imagination/linux-firmware/-/tree/powervr
[3] https://github.com/SaschaWillems/Vulkan
[4] https://lore.kernel.org/dri-devel/f2b2671e-5acc-4dec-9c2e-3c9cd2e1f19e@imgtec.com/

Chen-Yu Tsai (6):
  dt-bindings: clock: mediatek: Add mt8173 mfgtop
  clk: mediatek: Add mt8173-mfgtop driver
  dt-bindings: gpu: powervr-rogue: Add MediaTek MT8173 GPU
  drm/imagination: Add compatible string entry for Series6XT
  arm64: dts: mediatek: mt8173: Fix MFG_ASYNC power domain clock
  arm64: dts: mediatek: mt8173: Add GPU device nodes

 .../clock/mediatek,mt8173-mfgtop.yaml         |  71 ++++++
 .../bindings/gpu/img,powervr-rogue.yaml       |  24 +-
 arch/arm64/boot/dts/mediatek/mt8173.dtsi      |  26 +-
 drivers/clk/mediatek/Kconfig                  |   9 +
 drivers/clk/mediatek/Makefile                 |   1 +
 drivers/clk/mediatek/clk-mt8173-mfgtop.c      | 240 ++++++++++++++++++
 drivers/gpu/drm/imagination/pvr_drv.c         |   1 +
 include/dt-bindings/clock/mt8173-clk.h        |   7 +
 8 files changed, 374 insertions(+), 5 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/clock/mediatek,mt8173-mfgtop.yaml
 create mode 100644 drivers/clk/mediatek/clk-mt8173-mfgtop.c


base-commit: 1613e604df0cd359cf2a7fbd9be7a0bcfacfabd0

Vulkan info output:

WARNING: [Loader Message] Code 0 : terminator_CreateInstance: Received return code -3 from call to vkCreateInstance in ICD /usr/lib/aarch64-linux-gnu/libvulkan_virtio.so. Skipping this driver.
'DISPLAY' environment variable not set... skipping surface info
ERROR: [../src/panfrost/vulkan/panvk_device.c:386] Code 0 : WARNING: panvk is not a conformant vulkan implementation, pass PAN_I_WANT_A_BROKEN_VULKAN_DRIVER=1 if you know what you're doing. (VK_ERROR_INCOMPATIBLE_DRIVER)
MESA: error: No hard coded idfwdf program. Returning empty program.
MESA: error: No hard coded passthrough rta vertex shader. Returning empty shader.
MESA: error: No hard coded passthrough vertex shader. Returning empty shader.
MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:71: FINISHME: Missing reset support for brn51764
MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:74: FINISHME: Missing reset support for brn58839
MESA: warning: ../src/imagination/vulkan/pvr_border.c:104: FINISHME: Devices without tpu_border_colour_enhanced require entries for compressed formats to be stored in the table pre-compressed.
==========
VULKANINFO
==========

Vulkan Instance Version: 1.3.280


Instance Extensions: count = 23
===============================
	VK_EXT_acquire_drm_display             : extension revision 1
	VK_EXT_acquire_xlib_display            : extension revision 1
	VK_EXT_debug_report                    : extension revision 10
	VK_EXT_debug_utils                     : extension revision 2
	VK_EXT_direct_mode_display             : extension revision 1
	VK_EXT_display_surface_counter         : extension revision 1
	VK_EXT_surface_maintenance1            : extension revision 1
	VK_EXT_swapchain_colorspace            : extension revision 4
	VK_KHR_device_group_creation           : extension revision 1
	VK_KHR_display                         : extension revision 23
	VK_KHR_external_fence_capabilities     : extension revision 1
	VK_KHR_external_memory_capabilities    : extension revision 1
	VK_KHR_external_semaphore_capabilities : extension revision 1
	VK_KHR_get_display_properties2         : extension revision 1
	VK_KHR_get_physical_device_properties2 : extension revision 2
	VK_KHR_get_surface_capabilities2       : extension revision 1
	VK_KHR_portability_enumeration         : extension revision 1
	VK_KHR_surface                         : extension revision 25
	VK_KHR_surface_protected_capabilities  : extension revision 1
	VK_KHR_wayland_surface                 : extension revision 6
	VK_KHR_xcb_surface                     : extension revision 6
	VK_KHR_xlib_surface                    : extension revision 6
	VK_LUNARG_direct_driver_loading        : extension revision 1

Layers: count = 2
=================
VK_LAYER_MESA_device_select (Linux device selection layer) Vulkan version 1.3.211, layer version 1:
	Layer Extensions: count = 0
	Devices: count = 2
		GPU id = 0 (Imagination PowerVR Rogue GX6250)
		Layer-Device Extensions: count = 0

		GPU id = 1 (llvmpipe (LLVM 17.0.6, 128 bits))
		Layer-Device Extensions: count = 0

VK_LAYER_MESA_overlay (Mesa Overlay layer) Vulkan version 1.3.211, layer version 1:
	Layer Extensions: count = 0
	Devices: count = 2
		GPU id = 0 (Imagination PowerVR Rogue GX6250)
		Layer-Device Extensions: count = 0

		GPU id = 1 (llvmpipe (LLVM 17.0.6, 128 bits))
		Layer-Device Extensions: count = 0

Device Properties and Extensions:
=================================
GPU0:
VkPhysicalDeviceProperties:
---------------------------
	apiVersion        = 1.0.274 (4194578)
	driverVersion     = 24.0.8 (100663304)
	vendorID          = 0x1010
	deviceID          = 0x6250
	deviceType        = PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU
	deviceName        = Imagination PowerVR Rogue GX6250
	pipelineCacheUUID = 6ddf30eb-d118-41f1-455f-580ae751c27b

VkPhysicalDeviceLimits:
-----------------------
	maxImageDimension1D                             = 8192
	maxImageDimension2D                             = 8192
	maxImageDimension3D                             = 2048
	maxImageDimensionCube                           = 8192
	maxImageArrayLayers                             = 2048
	maxTexelBufferElements                          = 65536
	maxUniformBufferRange                           = 134217728
	maxStorageBufferRange                           = 134217728
	maxPushConstantsSize                            = 256
	maxMemoryAllocationCount                        = 4294967295
	maxSamplerAllocationCount                       = 4294967295
	bufferImageGranularity                          = 0x00000001
	sparseAddressSpaceSize                          = 0x4000000000
	maxBoundDescriptorSets                          = 4
	maxPerStageDescriptorSamplers                   = 32
	maxPerStageDescriptorUniformBuffers             = 64
	maxPerStageDescriptorStorageBuffers             = 36
	maxPerStageDescriptorSampledImages              = 48
	maxPerStageDescriptorStorageImages              = 8
	maxPerStageDescriptorInputAttachments           = 8
	maxPerStageResources                            = 224
	maxDescriptorSetSamplers                        = 256
	maxDescriptorSetUniformBuffers                  = 256
	maxDescriptorSetUniformBuffersDynamic           = 8
	maxDescriptorSetStorageBuffers                  = 256
	maxDescriptorSetStorageBuffersDynamic           = 8
	maxDescriptorSetSampledImages                   = 256
	maxDescriptorSetStorageImages                   = 256
	maxDescriptorSetInputAttachments                = 256
	maxVertexInputAttributes                        = 16
	maxVertexInputBindings                          = 16
	maxVertexInputAttributeOffset                   = 65535
	maxVertexInputBindingStride                     = 2147483648
	maxVertexOutputComponents                       = 128
	maxTessellationGenerationLevel                  = 0
	maxTessellationPatchSize                        = 0
	maxTessellationControlPerVertexInputComponents  = 0
	maxTessellationControlPerVertexOutputComponents = 0
	maxTessellationControlPerPatchOutputComponents  = 0
	maxTessellationControlTotalOutputComponents     = 0
	maxTessellationEvaluationInputComponents        = 0
	maxTessellationEvaluationOutputComponents       = 0
	maxGeometryShaderInvocations                    = 0
	maxGeometryInputComponents                      = 0
	maxGeometryOutputComponents                     = 0
	maxGeometryOutputVertices                       = 0
	maxGeometryTotalOutputComponents                = 0
	maxFragmentInputComponents                      = 128
	maxFragmentOutputAttachments                    = 8
	maxFragmentDualSrcAttachments                   = 0
	maxFragmentCombinedOutputResources              = 52
	maxComputeSharedMemorySize                      = 16384
	maxComputeWorkGroupCount: count = 3
		65536
		65536
		65536
	maxComputeWorkGroupInvocations                  = 512
	maxComputeWorkGroupSize: count = 3
		512
		512
		64
	subPixelPrecisionBits                           = 8
	subTexelPrecisionBits                           = 8
	mipmapPrecisionBits                             = 8
	maxDrawIndexedIndexValue                        = 4294967295
	maxDrawIndirectCount                            = 2147483648
	maxSamplerLodBias                               = 16
	maxSamplerAnisotropy                            = 1
	maxViewports                                    = 1
	maxViewportDimensions: count = 2
		8192
		8192
	viewportBoundsRange: count = 2
		-16384
		16384
	viewportSubPixelBits                            = 0
	minMemoryMapAlignment                           = 64
	minTexelBufferOffsetAlignment                   = 0x00000010
	minUniformBufferOffsetAlignment                 = 0x00000004
	minStorageBufferOffsetAlignment                 = 0x00000004
	minTexelOffset                                  = -8
	maxTexelOffset                                  = 7
	minTexelGatherOffset                            = -8
	maxTexelGatherOffset                            = 7
	minInterpolationOffset                          = -0.5
	maxInterpolationOffset                          = 0.5
	subPixelInterpolationOffsetBits                 = 4
	maxFramebufferWidth                             = 8192
	maxFramebufferHeight                            = 8192
	maxFramebufferLayers                            = 2048
	framebufferColorSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	framebufferDepthSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	framebufferStencilSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	framebufferNoAttachmentsSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	maxColorAttachments                             = 8
	sampledImageColorSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	sampledImageIntegerSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	sampledImageDepthSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	sampledImageStencilSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	storageImageSampleCounts: count = 4
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_2_BIT
		SAMPLE_COUNT_4_BIT
		SAMPLE_COUNT_8_BIT
	maxSampleMaskWords                              = 1
	timestampComputeAndGraphics                     = false
	timestampPeriod                                 = 0
	maxClipDistances                                = 8
	maxCullDistances                                = 8
	maxCombinedClipAndCullDistances                 = 8
	discreteQueuePriorities                         = 2
	pointSizeRange: count = 2
		1
		511
	lineWidthRange: count = 2
		0.0625
		16
	pointSizeGranularity                            = 0.0625
	lineWidthGranularity                            = 0.0625
	strictLines                                     = false
	standardSampleLocations                         = true
	optimalBufferCopyOffsetAlignment                = 0x00000004
	optimalBufferCopyRowPitchAlignment              = 0x00000004
	nonCoherentAtomSize                             = 0x00000001

VkPhysicalDeviceSparseProperties:
---------------------------------
	residencyStandard2DBlockShape            = false
	residencyStandard2DMultisampleBlockShape = false
	residencyStandard3DBlockShape            = false
	residencyAlignedMipSize                  = false
	residencyNonResidentStrict               = false

VkPhysicalDeviceTexelBufferAlignmentPropertiesEXT:
--------------------------------------------------
	storageTexelBufferOffsetAlignmentBytes       = 0x00000010
	storageTexelBufferOffsetSingleTexelAlignment = true
	uniformTexelBufferOffsetAlignmentBytes       = 0x00000010
	uniformTexelBufferOffsetSingleTexelAlignment = false

VkPhysicalDeviceTimelineSemaphorePropertiesKHR:
-----------------------------------------------
	maxTimelineSemaphoreValueDifference = 18446744073709551615

Device Extensions: count = 20
	VK_EXT_external_memory_dma_buf        : extension revision 1
	VK_EXT_host_query_reset               : extension revision 1
	VK_EXT_private_data                   : extension revision 1
	VK_EXT_scalar_block_layout            : extension revision 1
	VK_EXT_texel_buffer_alignment         : extension revision 1
	VK_EXT_tooling_info                   : extension revision 1
	VK_KHR_bind_memory2                   : extension revision 1
	VK_KHR_copy_commands2                 : extension revision 1
	VK_KHR_external_fence                 : extension revision 1
	VK_KHR_external_fence_fd              : extension revision 1
	VK_KHR_external_memory                : extension revision 1
	VK_KHR_external_memory_fd             : extension revision 1
	VK_KHR_external_semaphore             : extension revision 1
	VK_KHR_external_semaphore_fd          : extension revision 1
	VK_KHR_format_feature_flags2          : extension revision 2
	VK_KHR_get_memory_requirements2       : extension revision 1
	VK_KHR_image_format_list              : extension revision 1
	VK_KHR_swapchain                      : extension revision 70
	VK_KHR_timeline_semaphore             : extension revision 2
	VK_KHR_uniform_buffer_standard_layout : extension revision 1

VkQueueFamilyProperties:
========================
	queueProperties[0]:
	-------------------
		minImageTransferGranularity = (1,1,1)
		queueCount                  = 2
		queueFlags                  = QUEUE_GRAPHICS_BIT | QUEUE_COMPUTE_BIT | QUEUE_TRANSFER_BIT
		timestampValidBits          = 0
		present support             = false

VkPhysicalDeviceMemoryProperties:
=================================
memoryHeaps: count = 1
	memoryHeaps[0]:
		size   = 1752969216 (0x687c3000) (1.63 GiB)
		flags: count = 1
			MEMORY_HEAP_DEVICE_LOCAL_BIT
memoryTypes: count = 1
	memoryTypes[0]:
		heapIndex     = 0
		propertyFlags = 0x0007: count = 3
			MEMORY_PROPERTY_DEVICE_LOCAL_BIT
			MEMORY_PROPERTY_HOST_VISIBLE_BIT
			MEMORY_PROPERTY_HOST_COHERENT_BIT
		usable for:
			IMAGE_TILING_OPTIMAL:
				color images
				FORMAT_D16_UNORM
				FORMAT_D32_SFLOAT
				FORMAT_S8_UINT
				FORMAT_D24_UNORM_S8_UINT
				(non-sparse)
			IMAGE_TILING_LINEAR:
				color images
				(non-sparse)

VkPhysicalDeviceFeatures:
=========================
	robustBufferAccess                      = true
	fullDrawIndexUint32                     = true
	imageCubeArray                          = true
	independentBlend                        = false
	geometryShader                          = false
	tessellationShader                      = false
	sampleRateShading                       = true
	dualSrcBlend                            = false
	logicOp                                 = false
	multiDrawIndirect                       = true
	drawIndirectFirstInstance               = true
	depthClamp                              = true
	depthBiasClamp                          = true
	fillModeNonSolid                        = false
	depthBounds                             = false
	wideLines                               = true
	largePoints                             = true
	alphaToOne                              = false
	multiViewport                           = false
	samplerAnisotropy                       = false
	textureCompressionETC2                  = true
	textureCompressionASTC_LDR              = false
	textureCompressionBC                    = false
	occlusionQueryPrecise                   = false
	pipelineStatisticsQuery                 = false
	vertexPipelineStoresAndAtomics          = true
	fragmentStoresAndAtomics                = true
	shaderTessellationAndGeometryPointSize  = false
	shaderImageGatherExtended               = false
	shaderStorageImageExtendedFormats       = true
	shaderStorageImageMultisample           = false
	shaderStorageImageReadWithoutFormat     = true
	shaderStorageImageWriteWithoutFormat    = false
	shaderUniformBufferArrayDynamicIndexing = true
	shaderSampledImageArrayDynamicIndexing  = true
	shaderStorageBufferArrayDynamicIndexing = true
	shaderStorageImageArrayDynamicIndexing  = true
	shaderClipDistance                      = false
	shaderCullDistance                      = false
	shaderFloat64                           = false
	shaderInt64                             = true
	shaderInt16                             = true
	shaderResourceResidency                 = false
	shaderResourceMinLod                    = false
	sparseBinding                           = false
	sparseResidencyBuffer                   = false
	sparseResidencyImage2D                  = false
	sparseResidencyImage3D                  = false
	sparseResidency2Samples                 = false
	sparseResidency4Samples                 = false
	sparseResidency8Samples                 = false
	sparseResidency16Samples                = false
	sparseResidencyAliased                  = false
	variableMultisampleRate                 = false
	inheritedQueries                        = false

VkPhysicalDeviceHostQueryResetFeaturesEXT:
------------------------------------------
	hostQueryReset = true

VkPhysicalDevicePrivateDataFeaturesEXT:
---------------------------------------
	privateData = true

VkPhysicalDeviceScalarBlockLayoutFeaturesEXT:
---------------------------------------------
	scalarBlockLayout = true

VkPhysicalDeviceTexelBufferAlignmentFeaturesEXT:
------------------------------------------------
	texelBufferAlignment = true

VkPhysicalDeviceTimelineSemaphoreFeaturesKHR:
---------------------------------------------
	timelineSemaphore = true

VkPhysicalDeviceUniformBufferStandardLayoutFeaturesKHR:
-------------------------------------------------------
	uniformBufferStandardLayout = true


GPU1:
VkPhysicalDeviceProperties:
---------------------------
	apiVersion        = 1.3.274 (4206866)
	driverVersion     = 0.0.1 (1)
	vendorID          = 0x10005
	deviceID          = 0x0000
	deviceType        = PHYSICAL_DEVICE_TYPE_CPU
	deviceName        = llvmpipe (LLVM 17.0.6, 128 bits)
	pipelineCacheUUID = 32342e30-2e38-2d31-2b70-316161616161

VkPhysicalDeviceLimits:
-----------------------
	maxImageDimension1D                             = 16384
	maxImageDimension2D                             = 16384
	maxImageDimension3D                             = 4096
	maxImageDimensionCube                           = 32768
	maxImageArrayLayers                             = 2048
	maxTexelBufferElements                          = 134217728
	maxUniformBufferRange                           = 65536
	maxStorageBufferRange                           = 134217728
	maxPushConstantsSize                            = 256
	maxMemoryAllocationCount                        = 4294967295
	maxSamplerAllocationCount                       = 32768
	bufferImageGranularity                          = 0x00000040
	sparseAddressSpaceSize                          = 0x00000000
	maxBoundDescriptorSets                          = 8
	maxPerStageDescriptorSamplers                   = 1000000
	maxPerStageDescriptorUniformBuffers             = 1000000
	maxPerStageDescriptorStorageBuffers             = 1000000
	maxPerStageDescriptorSampledImages              = 1000000
	maxPerStageDescriptorStorageImages              = 1000000
	maxPerStageDescriptorInputAttachments           = 1000000
	maxPerStageResources                            = 1000000
	maxDescriptorSetSamplers                        = 1000000
	maxDescriptorSetUniformBuffers                  = 1000000
	maxDescriptorSetUniformBuffersDynamic           = 1000000
	maxDescriptorSetStorageBuffers                  = 1000000
	maxDescriptorSetStorageBuffersDynamic           = 1000000
	maxDescriptorSetSampledImages                   = 1000000
	maxDescriptorSetStorageImages                   = 1000000
	maxDescriptorSetInputAttachments                = 1000000
	maxVertexInputAttributes                        = 32
	maxVertexInputBindings                          = 32
	maxVertexInputAttributeOffset                   = 2047
	maxVertexInputBindingStride                     = 2048
	maxVertexOutputComponents                       = 128
	maxTessellationGenerationLevel                  = 64
	maxTessellationPatchSize                        = 32
	maxTessellationControlPerVertexInputComponents  = 128
	maxTessellationControlPerVertexOutputComponents = 128
	maxTessellationControlPerPatchOutputComponents  = 128
	maxTessellationControlTotalOutputComponents     = 4096
	maxTessellationEvaluationInputComponents        = 128
	maxTessellationEvaluationOutputComponents       = 128
	maxGeometryShaderInvocations                    = 32
	maxGeometryInputComponents                      = 64
	maxGeometryOutputComponents                     = 128
	maxGeometryOutputVertices                       = 1024
	maxGeometryTotalOutputComponents                = 1024
	maxFragmentInputComponents                      = 128
	maxFragmentOutputAttachments                    = 8
	maxFragmentDualSrcAttachments                   = 2
	maxFragmentCombinedOutputResources              = 104
	maxComputeSharedMemorySize                      = 32768
	maxComputeWorkGroupCount: count = 3
		65535
		65535
		65535
	maxComputeWorkGroupInvocations                  = 1024
	maxComputeWorkGroupSize: count = 3
		1024
		1024
		1024
	subPixelPrecisionBits                           = 8
	subTexelPrecisionBits                           = 8
	mipmapPrecisionBits                             = 4
	maxDrawIndexedIndexValue                        = 4294967295
	maxDrawIndirectCount                            = 4294967295
	maxSamplerLodBias                               = 16
	maxSamplerAnisotropy                            = 16
	maxViewports                                    = 16
	maxViewportDimensions: count = 2
		16384
		16384
	viewportBoundsRange: count = 2
		-32768
		32768
	viewportSubPixelBits                            = 0
	minMemoryMapAlignment                           = 64
	minTexelBufferOffsetAlignment                   = 0x00000010
	minUniformBufferOffsetAlignment                 = 0x00000010
	minStorageBufferOffsetAlignment                 = 0x00000010
	minTexelOffset                                  = -32
	maxTexelOffset                                  = 31
	minTexelGatherOffset                            = -32
	maxTexelGatherOffset                            = 31
	minInterpolationOffset                          = -2
	maxInterpolationOffset                          = 2
	subPixelInterpolationOffsetBits                 = 8
	maxFramebufferWidth                             = 16384
	maxFramebufferHeight                            = 16384
	maxFramebufferLayers                            = 2048
	framebufferColorSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	framebufferDepthSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	framebufferStencilSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	framebufferNoAttachmentsSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	maxColorAttachments                             = 8
	sampledImageColorSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	sampledImageIntegerSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	sampledImageDepthSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	sampledImageStencilSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	storageImageSampleCounts: count = 2
		SAMPLE_COUNT_1_BIT
		SAMPLE_COUNT_4_BIT
	maxSampleMaskWords                              = 1
	timestampComputeAndGraphics                     = true
	timestampPeriod                                 = 1
	maxClipDistances                                = 8
	maxCullDistances                                = 8
	maxCombinedClipAndCullDistances                 = 8
	discreteQueuePriorities                         = 2
	pointSizeRange: count = 2
		0
		255
	lineWidthRange: count = 2
		1
		255
	pointSizeGranularity                            = 0.125
	lineWidthGranularity                            = 0.0078125
	strictLines                                     = true
	standardSampleLocations                         = true
	optimalBufferCopyOffsetAlignment                = 0x00000080
	optimalBufferCopyRowPitchAlignment              = 0x00000080
	nonCoherentAtomSize                             = 0x00000040

VkPhysicalDeviceSparseProperties:
---------------------------------
	residencyStandard2DBlockShape            = false
	residencyStandard2DMultisampleBlockShape = false
	residencyStandard3DBlockShape            = false
	residencyAlignedMipSize                  = false
	residencyNonResidentStrict               = false

VkPhysicalDeviceCustomBorderColorPropertiesEXT:
-----------------------------------------------
	maxCustomBorderColorSamplers = 32768

VkPhysicalDeviceDescriptorBufferDensityMapPropertiesEXT:
--------------------------------------------------------
	combinedImageSamplerDensityMapDescriptorSize = 0

VkPhysicalDeviceDescriptorBufferPropertiesEXT:
----------------------------------------------
	combinedImageSamplerDescriptorSingleArray            = true
	bufferlessPushDescriptors                            = true
	allowSamplerImageViewPostSubmitCreation              = false
	descriptorBufferOffsetAlignment                      = 0x00000004
	maxDescriptorBufferBindings                          = 8
	maxResourceDescriptorBufferBindings                  = 8
	maxSamplerDescriptorBufferBindings                   = 8
	maxEmbeddedImmutableSamplerBindings                  = 8
	maxEmbeddedImmutableSamplers                         = 2032
	bufferCaptureReplayDescriptorDataSize                = 0
	imageCaptureReplayDescriptorDataSize                 = 0
	imageViewCaptureReplayDescriptorDataSize             = 0
	samplerCaptureReplayDescriptorDataSize               = 0
	accelerationStructureCaptureReplayDescriptorDataSize = 0
	samplerDescriptorSize                                = 256
	combinedImageSamplerDescriptorSize                   = 256
	sampledImageDescriptorSize                           = 256
	storageImageDescriptorSize                           = 256
	uniformTexelBufferDescriptorSize                     = 256
	robustUniformTexelBufferDescriptorSize               = 256
	storageTexelBufferDescriptorSize                     = 256
	robustStorageTexelBufferDescriptorSize               = 256
	uniformBufferDescriptorSize                          = 256
	robustUniformBufferDescriptorSize                    = 256
	storageBufferDescriptorSize                          = 256
	robustStorageBufferDescriptorSize                    = 256
	inputAttachmentDescriptorSize                        = 256
	accelerationStructureDescriptorSize                  = 0
	maxSamplerDescriptorBufferRange                      = 0x08000000
	maxResourceDescriptorBufferRange                     = 0x10000000
	samplerDescriptorBufferAddressSpaceSize              = 0x08000000
	resourceDescriptorBufferAddressSpaceSize             = 0x08000000
	descriptorBufferAddressSpaceSize                     = 0x08000000

VkPhysicalDeviceExtendedDynamicState3PropertiesEXT:
---------------------------------------------------
	dynamicPrimitiveTopologyUnrestricted = true

VkPhysicalDeviceExternalMemoryHostPropertiesEXT:
------------------------------------------------
	minImportedHostPointerAlignment = 0x00001000

VkPhysicalDeviceGraphicsPipelineLibraryPropertiesEXT:
-----------------------------------------------------
	graphicsPipelineLibraryFastLinking                        = true
	graphicsPipelineLibraryIndependentInterpolationDecoration = true

VkPhysicalDeviceLineRasterizationPropertiesKHR:
-----------------------------------------------
	lineSubPixelPrecisionBits = 8

VkPhysicalDeviceMaintenance5PropertiesKHR:
------------------------------------------
	earlyFragmentMultisampleCoverageAfterSampleCounting = true
	earlyFragmentSampleMaskTestBeforeSampleCounting     = false
	depthStencilSwizzleOneSupport                       = false
	polygonModePointSize                                = true
	nonStrictSinglePixelWideLinesUseParallelogram       = false
	nonStrictWideLinesUseParallelogram                  = false

VkPhysicalDeviceMaintenance6PropertiesKHR:
------------------------------------------
	blockTexelViewCompatibleMultipleLayers = true
	maxCombinedImageSamplerDescriptorCount = 3
	fragmentShadingRateClampCombinerInputs = false

VkPhysicalDeviceMeshShaderPropertiesEXT:
----------------------------------------
	maxTaskWorkGroupTotalCount            = 4194304
	maxTaskWorkGroupCount: count = 3
		65536
		65536
		65536
	maxTaskWorkGroupInvocations           = 1024
	maxTaskWorkGroupSize: count = 3
		1024
		1024
		1024
	maxTaskPayloadSize                    = 16384
	maxTaskSharedMemorySize               = 32768
	maxTaskPayloadAndSharedMemorySize     = 32768
	maxMeshWorkGroupTotalCount            = 4194304
	maxMeshWorkGroupCount: count = 3
		65536
		65536
		65536
	maxMeshWorkGroupInvocations           = 1024
	maxMeshWorkGroupSize: count = 3
		1024
		1024
		1024
	maxMeshSharedMemorySize               = 28672
	maxMeshPayloadAndSharedMemorySize     = 45056
	maxMeshOutputMemorySize               = 32768
	maxMeshPayloadAndOutputMemorySize     = 49152
	maxMeshOutputComponents               = 128
	maxMeshOutputVertices                 = 256
	maxMeshOutputPrimitives               = 256
	maxMeshOutputLayers                   = 8
	maxMeshMultiviewViewCount             = 0
	meshOutputPerVertexGranularity        = 1
	meshOutputPerPrimitiveGranularity     = 1
	maxPreferredTaskWorkGroupInvocations  = 64
	maxPreferredMeshWorkGroupInvocations  = 128
	prefersLocalInvocationVertexOutput    = true
	prefersLocalInvocationPrimitiveOutput = true
	prefersCompactVertexOutput            = true
	prefersCompactPrimitiveOutput         = false

VkPhysicalDeviceMultiDrawPropertiesEXT:
---------------------------------------
	maxMultiDrawCount = 2048

VkPhysicalDeviceNestedCommandBufferPropertiesEXT:
-------------------------------------------------
	maxCommandBufferNestingLevel = 4294967295

VkPhysicalDeviceProvokingVertexPropertiesEXT:
---------------------------------------------
	provokingVertexModePerPipeline                       = true
	transformFeedbackPreservesTriangleFanProvokingVertex = true

VkPhysicalDevicePushDescriptorPropertiesKHR:
--------------------------------------------
	maxPushDescriptors = 32

VkPhysicalDeviceRobustness2PropertiesEXT:
-----------------------------------------
	robustStorageBufferAccessSizeAlignment = 0x00000001
	robustUniformBufferAccessSizeAlignment = 0x00000001

VkPhysicalDeviceShaderObjectPropertiesEXT:
------------------------------------------
	shaderBinaryUUID     = 32342e30-2e38-2d31-2b70-316161616161
	shaderBinaryVersion  = 1

VkPhysicalDeviceTransformFeedbackPropertiesEXT:
-----------------------------------------------
	maxTransformFeedbackStreams                = 4
	maxTransformFeedbackBuffers                = 4
	maxTransformFeedbackBufferSize             = 0xffffffff
	maxTransformFeedbackStreamDataSize         = 512
	maxTransformFeedbackBufferDataSize         = 512
	maxTransformFeedbackBufferDataStride       = 512
	transformFeedbackQueries                   = true
	transformFeedbackStreamsLinesTriangles     = false
	transformFeedbackRasterizationStreamSelect = false
	transformFeedbackDraw                      = true

VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT:
----------------------------------------------------
	maxVertexAttribDivisor = 4294967295

VkPhysicalDeviceVulkan11Properties:
-----------------------------------
	deviceUUID                        = 6d657361-3234-2e30-2e38-2d312b703100
	driverUUID                        = 6c6c766d-7069-7065-5555-494400000000
	deviceNodeMask                    = 0
	deviceLUIDValid                   = false
	subgroupSize                      = 4
	subgroupSupportedStages: count = 4
		SHADER_STAGE_FRAGMENT_BIT
		SHADER_STAGE_COMPUTE_BIT
		SHADER_STAGE_TASK_BIT_EXT
		SHADER_STAGE_MESH_BIT_EXT
	subgroupSupportedOperations: count = 7
		SUBGROUP_FEATURE_BASIC_BIT
		SUBGROUP_FEATURE_VOTE_BIT
		SUBGROUP_FEATURE_ARITHMETIC_BIT
		SUBGROUP_FEATURE_BALLOT_BIT
		SUBGROUP_FEATURE_SHUFFLE_BIT
		SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT
		SUBGROUP_FEATURE_QUAD_BIT
	subgroupQuadOperationsInAllStages = false
	pointClippingBehavior             = POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES
	maxMultiviewViewCount             = 6
	maxMultiviewInstanceIndex         = 2147483647
	protectedNoFault                  = false
	maxPerSetDescriptors              = 1000000
	maxMemoryAllocationSize           = 0x80000000

VkPhysicalDeviceVulkan12Properties:
-----------------------------------
	driverID                                             = DRIVER_ID_MESA_LLVMPIPE
	driverName                                           = llvmpipe
	driverInfo                                           = Mesa 24.0.8-1+p1 (LLVM 17.0.6)
	conformanceVersion:
		major    = 1
		minor    = 3
		subminor = 1
		patch    = 1
	denormBehaviorIndependence                           = SHADER_FLOAT_CONTROLS_INDEPENDENCE_ALL
	roundingModeIndependence                             = SHADER_FLOAT_CONTROLS_INDEPENDENCE_ALL
	shaderSignedZeroInfNanPreserveFloat16                = true
	shaderSignedZeroInfNanPreserveFloat32                = true
	shaderSignedZeroInfNanPreserveFloat64                = true
	shaderDenormPreserveFloat16                          = false
	shaderDenormPreserveFloat32                          = false
	shaderDenormPreserveFloat64                          = false
	shaderDenormFlushToZeroFloat16                       = false
	shaderDenormFlushToZeroFloat32                       = false
	shaderDenormFlushToZeroFloat64                       = false
	shaderRoundingModeRTEFloat16                         = true
	shaderRoundingModeRTEFloat32                         = true
	shaderRoundingModeRTEFloat64                         = true
	shaderRoundingModeRTZFloat16                         = false
	shaderRoundingModeRTZFloat32                         = false
	shaderRoundingModeRTZFloat64                         = false
	maxUpdateAfterBindDescriptorsInAllPools              = 4294967295
	shaderUniformBufferArrayNonUniformIndexingNative     = true
	shaderSampledImageArrayNonUniformIndexingNative      = true
	shaderStorageBufferArrayNonUniformIndexingNative     = true
	shaderStorageImageArrayNonUniformIndexingNative      = true
	shaderInputAttachmentArrayNonUniformIndexingNative   = true
	robustBufferAccessUpdateAfterBind                    = true
	quadDivergentImplicitLod                             = true
	maxPerStageDescriptorUpdateAfterBindSamplers         = 1000000
	maxPerStageDescriptorUpdateAfterBindUniformBuffers   = 1000000
	maxPerStageDescriptorUpdateAfterBindStorageBuffers   = 1000000
	maxPerStageDescriptorUpdateAfterBindSampledImages    = 1000000
	maxPerStageDescriptorUpdateAfterBindStorageImages    = 1000000
	maxPerStageDescriptorUpdateAfterBindInputAttachments = 1000000
	maxPerStageUpdateAfterBindResources                  = 1000000
	maxDescriptorSetUpdateAfterBindSamplers              = 1000000
	maxDescriptorSetUpdateAfterBindUniformBuffers        = 1000000
	maxDescriptorSetUpdateAfterBindUniformBuffersDynamic = 1000000
	maxDescriptorSetUpdateAfterBindStorageBuffers        = 1000000
	maxDescriptorSetUpdateAfterBindStorageBuffersDynamic = 1000000
	maxDescriptorSetUpdateAfterBindSampledImages         = 1000000
	maxDescriptorSetUpdateAfterBindStorageImages         = 1000000
	maxDescriptorSetUpdateAfterBindInputAttachments      = 1000000
	supportedDepthResolveModes: count = 2
		RESOLVE_MODE_SAMPLE_ZERO_BIT
		RESOLVE_MODE_AVERAGE_BIT
	supportedStencilResolveModes: count = 1
		RESOLVE_MODE_SAMPLE_ZERO_BIT
	independentResolveNone                               = false
	independentResolve                                   = false
	filterMinmaxSingleComponentFormats                   = true
	filterMinmaxImageComponentMapping                    = true
	maxTimelineSemaphoreValueDifference                  = 18446744073709551615
	framebufferIntegerColorSampleCounts: count = 1
		SAMPLE_COUNT_1_BIT

VkPhysicalDeviceVulkan13Properties:
-----------------------------------
	minSubgroupSize                                                               = 4
	maxSubgroupSize                                                               = 4
	maxComputeWorkgroupSubgroups                                                  = 32
	requiredSubgroupSizeStages: count = 2
		SHADER_STAGE_FRAGMENT_BIT
		SHADER_STAGE_COMPUTE_BIT
	maxInlineUniformBlockSize                                                     = 4096
	maxPerStageDescriptorInlineUniformBlocks                                      = 8
	maxPerStageDescriptorUpdateAfterBindInlineUniformBlocks                       = 8
	maxDescriptorSetInlineUniformBlocks                                           = 8
	maxDescriptorSetUpdateAfterBindInlineUniformBlocks                            = 8
	maxInlineUniformTotalSize                                                     = 262144
	integerDotProduct8BitUnsignedAccelerated                                      = false
	integerDotProduct8BitSignedAccelerated                                        = false
	integerDotProduct8BitMixedSignednessAccelerated                               = false
	integerDotProduct4x8BitPackedUnsignedAccelerated                              = false
	integerDotProduct4x8BitPackedSignedAccelerated                                = false
	integerDotProduct4x8BitPackedMixedSignednessAccelerated                       = false
	integerDotProduct16BitUnsignedAccelerated                                     = false
	integerDotProduct16BitSignedAccelerated                                       = false
	integerDotProduct16BitMixedSignednessAccelerated                              = false
	integerDotProduct32BitUnsignedAccelerated                                     = false
	integerDotProduct32BitSignedAccelerated                                       = false
	integerDotProduct32BitMixedSignednessAccelerated                              = false
	integerDotProduct64BitUnsignedAccelerated                                     = false
	integerDotProduct64BitSignedAccelerated                                       = false
	integerDotProduct64BitMixedSignednessAccelerated                              = false
	integerDotProductAccumulatingSaturating8BitUnsignedAccelerated                = false
	integerDotProductAccumulatingSaturating8BitSignedAccelerated                  = false
	integerDotProductAccumulatingSaturating8BitMixedSignednessAccelerated         = false
	integerDotProductAccumulatingSaturating4x8BitPackedUnsignedAccelerated        = false
	integerDotProductAccumulatingSaturating4x8BitPackedSignedAccelerated          = false
	integerDotProductAccumulatingSaturating4x8BitPackedMixedSignednessAccelerated = false
	integerDotProductAccumulatingSaturating16BitUnsignedAccelerated               = false
	integerDotProductAccumulatingSaturating16BitSignedAccelerated                 = false
	integerDotProductAccumulatingSaturating16BitMixedSignednessAccelerated        = false
	integerDotProductAccumulatingSaturating32BitUnsignedAccelerated               = false
	integerDotProductAccumulatingSaturating32BitSignedAccelerated                 = false
	integerDotProductAccumulatingSaturating32BitMixedSignednessAccelerated        = false
	integerDotProductAccumulatingSaturating64BitUnsignedAccelerated               = false
	integerDotProductAccumulatingSaturating64BitSignedAccelerated                 = false
	integerDotProductAccumulatingSaturating64BitMixedSignednessAccelerated        = false
	storageTexelBufferOffsetAlignmentBytes                                        = 0x00000010
	storageTexelBufferOffsetSingleTexelAlignment                                  = true
	uniformTexelBufferOffsetAlignmentBytes                                        = 0x00000010
	uniformTexelBufferOffsetSingleTexelAlignment                                  = true
	maxBufferSize                                                                 = 0xffffffff

VkPhysicalDeviceHostImageCopyPropertiesEXT:
-------------------------------------------
	copySrcLayoutCount                  = 23
	pCopySrcLayouts: count = 23
		IMAGE_LAYOUT_GENERAL
		IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL
		IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL
		IMAGE_LAYOUT_PREINITIALIZED
		IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_PRESENT_SRC_KHR
		IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR
		IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR
		IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR
		IMAGE_LAYOUT_SHARED_PRESENT_KHR
		IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT
		IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR
	copyDstLayoutCount                  = 23
	pCopyDstLayouts: count = 23
		IMAGE_LAYOUT_GENERAL
		IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL
		IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL
		IMAGE_LAYOUT_PREINITIALIZED
		IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_READ_ONLY_OPTIMAL
		IMAGE_LAYOUT_ATTACHMENT_OPTIMAL
		IMAGE_LAYOUT_PRESENT_SRC_KHR
		IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR
		IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR
		IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR
		IMAGE_LAYOUT_SHARED_PRESENT_KHR
		IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT
		IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR
	optimalTilingLayoutUUID             = 32342e30-2e38-2d31-2b70-316161616161
	identicalMemoryTypeRequirements     = false

Device Extensions: count = 124
	VK_AMDX_shader_enqueue                        : extension revision 1
	VK_ARM_rasterization_order_attachment_access  : extension revision 1
	VK_EXT_4444_formats                           : extension revision 1
	VK_EXT_attachment_feedback_loop_dynamic_state : extension revision 1
	VK_EXT_attachment_feedback_loop_layout        : extension revision 2
	VK_EXT_border_color_swizzle                   : extension revision 1
	VK_EXT_calibrated_timestamps                  : extension revision 2
	VK_EXT_color_write_enable                     : extension revision 1
	VK_EXT_conditional_rendering                  : extension revision 2
	VK_EXT_custom_border_color                    : extension revision 12
	VK_EXT_depth_clip_control                     : extension revision 1
	VK_EXT_depth_clip_enable                      : extension revision 1
	VK_EXT_depth_range_unrestricted               : extension revision 1
	VK_EXT_descriptor_buffer                      : extension revision 1
	VK_EXT_descriptor_indexing                    : extension revision 2
	VK_EXT_dynamic_rendering_unused_attachments   : extension revision 1
	VK_EXT_extended_dynamic_state                 : extension revision 1
	VK_EXT_extended_dynamic_state2                : extension revision 1
	VK_EXT_extended_dynamic_state3                : extension revision 2
	VK_EXT_external_memory_host                   : extension revision 1
	VK_EXT_graphics_pipeline_library              : extension revision 1
	VK_EXT_host_image_copy                        : extension revision 1
	VK_EXT_host_query_reset                       : extension revision 1
	VK_EXT_image_2d_view_of_3d                    : extension revision 1
	VK_EXT_image_robustness                       : extension revision 1
	VK_EXT_image_sliced_view_of_3d                : extension revision 1
	VK_EXT_index_type_uint8                       : extension revision 1
	VK_EXT_inline_uniform_block                   : extension revision 1
	VK_EXT_line_rasterization                     : extension revision 1
	VK_EXT_load_store_op_none                     : extension revision 1
	VK_EXT_memory_budget                          : extension revision 1
	VK_EXT_memory_priority                        : extension revision 1
	VK_EXT_mesh_shader                            : extension revision 1
	VK_EXT_multi_draw                             : extension revision 1
	VK_EXT_multisampled_render_to_single_sampled  : extension revision 1
	VK_EXT_mutable_descriptor_type                : extension revision 1
	VK_EXT_nested_command_buffer                  : extension revision 1
	VK_EXT_non_seamless_cube_map                  : extension revision 1
	VK_EXT_pageable_device_local_memory           : extension revision 1
	VK_EXT_pipeline_creation_cache_control        : extension revision 3
	VK_EXT_pipeline_creation_feedback             : extension revision 1
	VK_EXT_post_depth_coverage                    : extension revision 1
	VK_EXT_primitive_topology_list_restart        : extension revision 1
	VK_EXT_primitives_generated_query             : extension revision 1
	VK_EXT_private_data                           : extension revision 1
	VK_EXT_provoking_vertex                       : extension revision 1
	VK_EXT_rasterization_order_attachment_access  : extension revision 1
	VK_EXT_robustness2                            : extension revision 1
	VK_EXT_sampler_filter_minmax                  : extension revision 2
	VK_EXT_scalar_block_layout                    : extension revision 1
	VK_EXT_separate_stencil_usage                 : extension revision 1
	VK_EXT_shader_atomic_float                    : extension revision 1
	VK_EXT_shader_atomic_float2                   : extension revision 1
	VK_EXT_shader_demote_to_helper_invocation     : extension revision 1
	VK_EXT_shader_object                          : extension revision 1
	VK_EXT_shader_stencil_export                  : extension revision 1
	VK_EXT_shader_subgroup_ballot                 : extension revision 1
	VK_EXT_shader_subgroup_vote                   : extension revision 1
	VK_EXT_shader_viewport_index_layer            : extension revision 1
	VK_EXT_subgroup_size_control                  : extension revision 2
	VK_EXT_texel_buffer_alignment                 : extension revision 1
	VK_EXT_transform_feedback                     : extension revision 1
	VK_EXT_vertex_attribute_divisor               : extension revision 3
	VK_EXT_vertex_input_dynamic_state             : extension revision 2
	VK_EXT_ycbcr_2plane_444_formats               : extension revision 1
	VK_EXT_ycbcr_image_arrays                     : extension revision 1
	VK_GOOGLE_decorate_string                     : extension revision 1
	VK_GOOGLE_hlsl_functionality1                 : extension revision 1
	VK_KHR_16bit_storage                          : extension revision 1
	VK_KHR_8bit_storage                           : extension revision 1
	VK_KHR_bind_memory2                           : extension revision 1
	VK_KHR_buffer_device_address                  : extension revision 1
	VK_KHR_copy_commands2                         : extension revision 1
	VK_KHR_create_renderpass2                     : extension revision 1
	VK_KHR_dedicated_allocation                   : extension revision 3
	VK_KHR_depth_stencil_resolve                  : extension revision 1
	VK_KHR_descriptor_update_template             : extension revision 1
	VK_KHR_device_group                           : extension revision 4
	VK_KHR_draw_indirect_count                    : extension revision 1
	VK_KHR_driver_properties                      : extension revision 1
	VK_KHR_dynamic_rendering                      : extension revision 1
	VK_KHR_external_fence                         : extension revision 1
	VK_KHR_external_memory                        : extension revision 1
	VK_KHR_external_memory_fd                     : extension revision 1
	VK_KHR_external_semaphore                     : extension revision 1
	VK_KHR_format_feature_flags2                  : extension revision 2
	VK_KHR_get_memory_requirements2               : extension revision 1
	VK_KHR_image_format_list                      : extension revision 1
	VK_KHR_imageless_framebuffer                  : extension revision 1
	VK_KHR_incremental_present                    : extension revision 2
	VK_KHR_maintenance1                           : extension revision 2
	VK_KHR_maintenance2                           : extension revision 1
	VK_KHR_maintenance3                           : extension revision 1
	VK_KHR_maintenance4                           : extension revision 2
	VK_KHR_maintenance5                           : extension revision 1
	VK_KHR_maintenance6                           : extension revision 1
	VK_KHR_map_memory2                            : extension revision 1
	VK_KHR_multiview                              : extension revision 1
	VK_KHR_pipeline_library                       : extension revision 1
	VK_KHR_push_descriptor                        : extension revision 2
	VK_KHR_relaxed_block_layout                   : extension revision 1
	VK_KHR_sampler_mirror_clamp_to_edge           : extension revision 3
	VK_KHR_sampler_ycbcr_conversion               : extension revision 14
	VK_KHR_separate_depth_stencil_layouts         : extension revision 1
	VK_KHR_shader_atomic_int64                    : extension revision 1
	VK_KHR_shader_clock                           : extension revision 1
	VK_KHR_shader_draw_parameters                 : extension revision 1
	VK_KHR_shader_float16_int8                    : extension revision 1
	VK_KHR_shader_float_controls                  : extension revision 4
	VK_KHR_shader_integer_dot_product             : extension revision 1
	VK_KHR_shader_non_semantic_info               : extension revision 1
	VK_KHR_shader_subgroup_extended_types         : extension revision 1
	VK_KHR_shader_terminate_invocation            : extension revision 1
	VK_KHR_spirv_1_4                              : extension revision 1
	VK_KHR_storage_buffer_storage_class           : extension revision 1
	VK_KHR_swapchain                              : extension revision 70
	VK_KHR_swapchain_mutable_format               : extension revision 1
	VK_KHR_synchronization2                       : extension revision 1
	VK_KHR_timeline_semaphore                     : extension revision 2
	VK_KHR_uniform_buffer_standard_layout         : extension revision 1
	VK_KHR_variable_pointers                      : extension revision 1
	VK_KHR_vulkan_memory_model                    : extension revision 3
	VK_KHR_zero_initialize_workgroup_memory       : extension revision 1
	VK_NV_device_generated_commands               : extension revision 3

VkQueueFamilyProperties:
========================
	queueProperties[0]:
	-------------------
		minImageTransferGranularity = (1,1,1)
		queueCount                  = 1
		queueFlags                  = QUEUE_GRAPHICS_BIT | QUEUE_COMPUTE_BIT | QUEUE_TRANSFER_BIT
		timestampValidBits          = 64
		present support             = false

VkPhysicalDeviceMemoryProperties:
=================================
memoryHeaps: count = 1
	memoryHeaps[0]:
		size   = 3505938432 (0xd0f86000) (3.27 GiB)
		budget = 3505938432 (0xd0f86000) (3.27 GiB)
		usage  = 522092544 (0x1f1e8000) (497.91 MiB)
		flags: count = 1
			MEMORY_HEAP_DEVICE_LOCAL_BIT
memoryTypes: count = 1
	memoryTypes[0]:
		heapIndex     = 0
		propertyFlags = 0x000f: count = 4
			MEMORY_PROPERTY_DEVICE_LOCAL_BIT
			MEMORY_PROPERTY_HOST_VISIBLE_BIT
			MEMORY_PROPERTY_HOST_COHERENT_BIT
			MEMORY_PROPERTY_HOST_CACHED_BIT
		usable for:
			IMAGE_TILING_OPTIMAL:
				color images
				FORMAT_D16_UNORM
				FORMAT_X8_D24_UNORM_PACK32
				FORMAT_D32_SFLOAT
				FORMAT_S8_UINT
				FORMAT_D24_UNORM_S8_UINT
				FORMAT_D32_SFLOAT_S8_UINT
				(non-sparse)
			IMAGE_TILING_LINEAR:
				color images
				(non-sparse)

VkPhysicalDeviceFeatures:
=========================
	robustBufferAccess                      = true
	fullDrawIndexUint32                     = true
	imageCubeArray                          = true
	independentBlend                        = true
	geometryShader                          = true
	tessellationShader                      = true
	sampleRateShading                       = true
	dualSrcBlend                            = true
	logicOp                                 = true
	multiDrawIndirect                       = true
	drawIndirectFirstInstance               = true
	depthClamp                              = true
	depthBiasClamp                          = true
	fillModeNonSolid                        = true
	depthBounds                             = false
	wideLines                               = true
	largePoints                             = true
	alphaToOne                              = true
	multiViewport                           = true
	samplerAnisotropy                       = true
	textureCompressionETC2                  = false
	textureCompressionASTC_LDR              = false
	textureCompressionBC                    = true
	occlusionQueryPrecise                   = true
	pipelineStatisticsQuery                 = true
	vertexPipelineStoresAndAtomics          = true
	fragmentStoresAndAtomics                = true
	shaderTessellationAndGeometryPointSize  = true
	shaderImageGatherExtended               = true
	shaderStorageImageExtendedFormats       = true
	shaderStorageImageMultisample           = true
	shaderStorageImageReadWithoutFormat     = true
	shaderStorageImageWriteWithoutFormat    = true
	shaderUniformBufferArrayDynamicIndexing = true
	shaderSampledImageArrayDynamicIndexing  = true
	shaderStorageBufferArrayDynamicIndexing = true
	shaderStorageImageArrayDynamicIndexing  = true
	shaderClipDistance                      = true
	shaderCullDistance                      = true
	shaderFloat64                           = true
	shaderInt64                             = true
	shaderInt16                             = true
	shaderResourceResidency                 = false
	shaderResourceMinLod                    = false
	sparseBinding                           = false
	sparseResidencyBuffer                   = false
	sparseResidencyImage2D                  = false
	sparseResidencyImage3D                  = false
	sparseResidency2Samples                 = false
	sparseResidency4Samples                 = false
	sparseResidency8Samples                 = false
	sparseResidency16Samples                = false
	sparseResidencyAliased                  = false
	variableMultisampleRate                 = false
	inheritedQueries                        = false

VkPhysicalDevice4444FormatsFeaturesEXT:
---------------------------------------
	formatA4R4G4B4 = true
	formatA4B4G4R4 = true

VkPhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT:
--------------------------------------------------------------
	attachmentFeedbackLoopDynamicState = true

VkPhysicalDeviceAttachmentFeedbackLoopLayoutFeaturesEXT:
--------------------------------------------------------
	attachmentFeedbackLoopLayout = true

VkPhysicalDeviceBorderColorSwizzleFeaturesEXT:
----------------------------------------------
	borderColorSwizzle          = true
	borderColorSwizzleFromImage = true

VkPhysicalDeviceColorWriteEnableFeaturesEXT:
--------------------------------------------
	colorWriteEnable = true

VkPhysicalDeviceConditionalRenderingFeaturesEXT:
------------------------------------------------
	conditionalRendering          = true
	inheritedConditionalRendering = false

VkPhysicalDeviceCustomBorderColorFeaturesEXT:
---------------------------------------------
	customBorderColors             = true
	customBorderColorWithoutFormat = true

VkPhysicalDeviceDepthClipControlFeaturesEXT:
--------------------------------------------
	depthClipControl = true

VkPhysicalDeviceDepthClipEnableFeaturesEXT:
-------------------------------------------
	depthClipEnable = true

VkPhysicalDeviceDescriptorBufferFeaturesEXT:
--------------------------------------------
	descriptorBuffer                   = true
	descriptorBufferCaptureReplay      = false
	descriptorBufferImageLayoutIgnored = true
	descriptorBufferPushDescriptors    = true

VkPhysicalDeviceDynamicRenderingUnusedAttachmentsFeaturesEXT:
-------------------------------------------------------------
	dynamicRenderingUnusedAttachments = true

VkPhysicalDeviceExtendedDynamicState2FeaturesEXT:
-------------------------------------------------
	extendedDynamicState2                   = true
	extendedDynamicState2LogicOp            = true
	extendedDynamicState2PatchControlPoints = true

VkPhysicalDeviceExtendedDynamicState3FeaturesEXT:
-------------------------------------------------
	extendedDynamicState3TessellationDomainOrigin         = true
	extendedDynamicState3DepthClampEnable                 = true
	extendedDynamicState3PolygonMode                      = true
	extendedDynamicState3RasterizationSamples             = true
	extendedDynamicState3SampleMask                       = true
	extendedDynamicState3AlphaToCoverageEnable            = true
	extendedDynamicState3AlphaToOneEnable                 = true
	extendedDynamicState3LogicOpEnable                    = true
	extendedDynamicState3ColorBlendEnable                 = true
	extendedDynamicState3ColorBlendEquation               = true
	extendedDynamicState3ColorWriteMask                   = true
	extendedDynamicState3RasterizationStream              = false
	extendedDynamicState3ConservativeRasterizationMode    = false
	extendedDynamicState3ExtraPrimitiveOverestimationSize = false
	extendedDynamicState3DepthClipEnable                  = true
	extendedDynamicState3SampleLocationsEnable            = false
	extendedDynamicState3ColorBlendAdvanced               = false
	extendedDynamicState3ProvokingVertexMode              = true
	extendedDynamicState3LineRasterizationMode            = true
	extendedDynamicState3LineStippleEnable                = true
	extendedDynamicState3DepthClipNegativeOneToOne        = true
	extendedDynamicState3ViewportWScalingEnable           = false
	extendedDynamicState3ViewportSwizzle                  = false
	extendedDynamicState3CoverageToColorEnable            = false
	extendedDynamicState3CoverageToColorLocation          = false
	extendedDynamicState3CoverageModulationMode           = false
	extendedDynamicState3CoverageModulationTableEnable    = false
	extendedDynamicState3CoverageModulationTable          = false
	extendedDynamicState3CoverageReductionMode            = false
	extendedDynamicState3RepresentativeFragmentTestEnable = false
	extendedDynamicState3ShadingRateImageEnable           = false

VkPhysicalDeviceExtendedDynamicStateFeaturesEXT:
------------------------------------------------
	extendedDynamicState = true

VkPhysicalDeviceGraphicsPipelineLibraryFeaturesEXT:
---------------------------------------------------
	graphicsPipelineLibrary = true

VkPhysicalDeviceHostImageCopyFeaturesEXT:
-----------------------------------------
	hostImageCopy = true

VkPhysicalDeviceImage2DViewOf3DFeaturesEXT:
-------------------------------------------
	image2DViewOf3D   = true
	sampler2DViewOf3D = true

VkPhysicalDeviceImageSlicedViewOf3DFeaturesEXT:
-----------------------------------------------
	imageSlicedViewOf3D = true

VkPhysicalDeviceIndexTypeUint8FeaturesKHR:
------------------------------------------
	indexTypeUint8 = true

VkPhysicalDeviceLineRasterizationFeaturesKHR:
---------------------------------------------
	rectangularLines         = true
	bresenhamLines           = true
	smoothLines              = true
	stippledRectangularLines = true
	stippledBresenhamLines   = true
	stippledSmoothLines      = true

VkPhysicalDeviceMaintenance5FeaturesKHR:
----------------------------------------
	maintenance5 = true

VkPhysicalDeviceMaintenance6FeaturesKHR:
----------------------------------------
	maintenance6 = true

VkPhysicalDeviceMemoryPriorityFeaturesEXT:
------------------------------------------
	memoryPriority = true

VkPhysicalDeviceMeshShaderFeaturesEXT:
--------------------------------------
	taskShader                             = true
	meshShader                             = true
	multiviewMeshShader                    = false
	primitiveFragmentShadingRateMeshShader = false
	meshShaderQueries                      = true

VkPhysicalDeviceMultiDrawFeaturesEXT:
-------------------------------------
	multiDraw = true

VkPhysicalDeviceMultisampledRenderToSingleSampledFeaturesEXT:
-------------------------------------------------------------
	multisampledRenderToSingleSampled = true

VkPhysicalDeviceMutableDescriptorTypeFeaturesEXT:
-------------------------------------------------
	mutableDescriptorType = true

VkPhysicalDeviceNestedCommandBufferFeaturesEXT:
-----------------------------------------------
	nestedCommandBuffer                = true
	nestedCommandBufferRendering       = true
	nestedCommandBufferSimultaneousUse = true

VkPhysicalDeviceNonSeamlessCubeMapFeaturesEXT:
----------------------------------------------
	nonSeamlessCubeMap = true

VkPhysicalDevicePageableDeviceLocalMemoryFeaturesEXT:
-----------------------------------------------------
	pageableDeviceLocalMemory = true

VkPhysicalDevicePrimitiveTopologyListRestartFeaturesEXT:
--------------------------------------------------------
	primitiveTopologyListRestart      = true
	primitiveTopologyPatchListRestart = true

VkPhysicalDevicePrimitivesGeneratedQueryFeaturesEXT:
----------------------------------------------------
	primitivesGeneratedQuery                      = true
	primitivesGeneratedQueryWithRasterizerDiscard = true
	primitivesGeneratedQueryWithNonZeroStreams    = true

VkPhysicalDeviceProvokingVertexFeaturesEXT:
-------------------------------------------
	provokingVertexLast                       = true
	transformFeedbackPreservesProvokingVertex = true

VkPhysicalDeviceRasterizationOrderAttachmentAccessFeaturesEXT:
--------------------------------------------------------------
	rasterizationOrderColorAttachmentAccess   = true
	rasterizationOrderDepthAttachmentAccess   = true
	rasterizationOrderStencilAttachmentAccess = true

VkPhysicalDeviceRobustness2FeaturesEXT:
---------------------------------------
	robustBufferAccess2 = true
	robustImageAccess2  = true
	nullDescriptor      = true

VkPhysicalDeviceShaderAtomicFloat2FeaturesEXT:
----------------------------------------------
	shaderBufferFloat16Atomics      = false
	shaderBufferFloat16AtomicAdd    = false
	shaderBufferFloat16AtomicMinMax = false
	shaderBufferFloat32AtomicMinMax = true
	shaderBufferFloat64AtomicMinMax = false
	shaderSharedFloat16Atomics      = false
	shaderSharedFloat16AtomicAdd    = false
	shaderSharedFloat16AtomicMinMax = false
	shaderSharedFloat32AtomicMinMax = true
	shaderSharedFloat64AtomicMinMax = false
	shaderImageFloat32AtomicMinMax  = true
	sparseImageFloat32AtomicMinMax  = false

VkPhysicalDeviceShaderAtomicFloatFeaturesEXT:
---------------------------------------------
	shaderBufferFloat32Atomics   = true
	shaderBufferFloat32AtomicAdd = true
	shaderBufferFloat64Atomics   = false
	shaderBufferFloat64AtomicAdd = false
	shaderSharedFloat32Atomics   = true
	shaderSharedFloat32AtomicAdd = true
	shaderSharedFloat64Atomics   = false
	shaderSharedFloat64AtomicAdd = false
	shaderImageFloat32Atomics    = true
	shaderImageFloat32AtomicAdd  = true
	sparseImageFloat32Atomics    = false
	sparseImageFloat32AtomicAdd  = false

VkPhysicalDeviceShaderClockFeaturesKHR:
---------------------------------------
	shaderSubgroupClock = true
	shaderDeviceClock   = true

VkPhysicalDeviceShaderObjectFeaturesEXT:
----------------------------------------
	shaderObject = true

VkPhysicalDeviceTexelBufferAlignmentFeaturesEXT:
------------------------------------------------
	texelBufferAlignment = true

VkPhysicalDeviceTransformFeedbackFeaturesEXT:
---------------------------------------------
	transformFeedback = true
	geometryStreams   = true

VkPhysicalDeviceVertexAttributeDivisorFeaturesKHR:
--------------------------------------------------
	vertexAttributeInstanceRateDivisor     = true
	vertexAttributeInstanceRateZeroDivisor = true

VkPhysicalDeviceVertexInputDynamicStateFeaturesEXT:
---------------------------------------------------
	vertexInputDynamicState = true

VkPhysicalDeviceVulkan11Features:
---------------------------------
	storageBuffer16BitAccess           = true
	uniformAndStorageBuffer16BitAccess = true
	storagePushConstant16              = true
	storageInputOutput16               = false
	multiview                          = true
	multiviewGeometryShader            = true
	multiviewTessellationShader        = true
	variablePointersStorageBuffer      = true
	variablePointers                   = true
	protectedMemory                    = false
	samplerYcbcrConversion             = true
	shaderDrawParameters               = true

VkPhysicalDeviceVulkan12Features:
---------------------------------
	samplerMirrorClampToEdge                           = true
	drawIndirectCount                                  = true
	storageBuffer8BitAccess                            = true
	uniformAndStorageBuffer8BitAccess                  = true
	storagePushConstant8                               = true
	shaderBufferInt64Atomics                           = true
	shaderSharedInt64Atomics                           = true
	shaderFloat16                                      = true
	shaderInt8                                         = true
	descriptorIndexing                                 = true
	shaderInputAttachmentArrayDynamicIndexing          = true
	shaderUniformTexelBufferArrayDynamicIndexing       = true
	shaderStorageTexelBufferArrayDynamicIndexing       = true
	shaderUniformBufferArrayNonUniformIndexing         = true
	shaderSampledImageArrayNonUniformIndexing          = true
	shaderStorageBufferArrayNonUniformIndexing         = true
	shaderStorageImageArrayNonUniformIndexing          = true
	shaderInputAttachmentArrayNonUniformIndexing       = true
	shaderUniformTexelBufferArrayNonUniformIndexing    = true
	shaderStorageTexelBufferArrayNonUniformIndexing    = true
	descriptorBindingUniformBufferUpdateAfterBind      = true
	descriptorBindingSampledImageUpdateAfterBind       = true
	descriptorBindingStorageImageUpdateAfterBind       = true
	descriptorBindingStorageBufferUpdateAfterBind      = true
	descriptorBindingUniformTexelBufferUpdateAfterBind = true
	descriptorBindingStorageTexelBufferUpdateAfterBind = true
	descriptorBindingUpdateUnusedWhilePending          = true
	descriptorBindingPartiallyBound                    = true
	descriptorBindingVariableDescriptorCount           = true
	runtimeDescriptorArray                             = true
	samplerFilterMinmax                                = true
	scalarBlockLayout                                  = true
	imagelessFramebuffer                               = true
	uniformBufferStandardLayout                        = true
	shaderSubgroupExtendedTypes                        = true
	separateDepthStencilLayouts                        = true
	hostQueryReset                                     = true
	timelineSemaphore                                  = true
	bufferDeviceAddress                                = true
	bufferDeviceAddressCaptureReplay                   = false
	bufferDeviceAddressMultiDevice                     = false
	vulkanMemoryModel                                  = true
	vulkanMemoryModelDeviceScope                       = true
	vulkanMemoryModelAvailabilityVisibilityChains      = true
	shaderOutputViewportIndex                          = true
	shaderOutputLayer                                  = true
	subgroupBroadcastDynamicId                         = true

VkPhysicalDeviceVulkan13Features:
---------------------------------
	robustImageAccess                                  = true
	inlineUniformBlock                                 = true
	descriptorBindingInlineUniformBlockUpdateAfterBind = true
	pipelineCreationCacheControl                       = true
	privateData                                        = true
	shaderDemoteToHelperInvocation                     = true
	shaderTerminateInvocation                          = true
	subgroupSizeControl                                = true
	computeFullSubgroups                               = true
	synchronization2                                   = true
	textureCompressionASTC_HDR                         = false
	shaderZeroInitializeWorkgroupMemory                = true
	dynamicRendering                                   = true
	shaderIntegerDotProduct                            = true
	maintenance4                                       = true

VkPhysicalDeviceYcbcr2Plane444FormatsFeaturesEXT:
-------------------------------------------------
	ycbcr2plane444Formats = true

VkPhysicalDeviceYcbcrImageArraysFeaturesEXT:
--------------------------------------------
	ycbcrImageArrays = true

Comments

Chen-Yu Tsai May 31, 2024, 4 a.m. UTC | #1
On Thu, May 30, 2024 at 4:35 PM Chen-Yu Tsai <wenst@chromium.org> wrote:
>
> Hi everyone,
>
> This series enables the PowerVR GPU found in the MT8173 SoC, found in
> some Chromebooks.
>
> This version is different from the initial powervr driver submission [1]
> in that it splits out the GPU glue layer support out of the powervr
> driver and into a separate clock and power domain driver. The glue code
> is otherwise the same, and also the same as found in the ChromeOS
> kernels, with some extra comments and macro names added where possible.
>
> Patch 1 adds a binding for the glue layer, called mfgtop. The glue layer
> contains clock and power controls for the GPU.
>
> Patch 2 adds a driver for the glue layer.
>
> Patch 3 adds an entry for the MT8173 GPU and 6XT series to the PowerVR
> binding.
>
> Patch 4 adds an entry for the PowerVR 6XT series GPU to the driver.
>
> Patch 5 corrects the clock for the GPU (called MFG) power domain.
>
> Patch 6 adds device nodes for the GPU and glue layer to the MT8173 dtsi
> file.
>
> Patch 2 and 6 depend on patch 1 to build. I suppose some common
> immutable tree would be needed from the MediaTek maintainers.
>
> The kernel driver successfully probes the hardware and loads the
> "rogue_4.40.2.51_v1.fw" firmware provided by Imagination Technologies [2].
> Userspace was tested with Mesa 24.0.8 from Debian Trixie rebuilt with
> the powervr vulkan driver enabled. `vulkaninfo` gives some information
> about the GPU (attached at the end), but running the `triangle` example
> from the Sascha Willems demos [3] with -DUSE_D2D_WSI=ON as recommended [4]
> failed with:
>
>     Can't find a display and a display mode!
>
> Same program worked correctly on a BeaglePlay and displayed a color
> gradient triangle. Not sure what went wrong here.

Frank mentioned over IRC that giving `triangle` a screen resolution would
make it work, and it did! Thanks Frank!

OTOH I'm getting some extra warnings not seen on the BeaglePlay:

    MESA: error: No hard coded passthrough rta vertex shader.
Returning empty shader.
    MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:71:
FINISHME: Missing reset support for brn51764
    MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:74:
FINISHME: Missing reset support for brn58839
    MESA: warning: ../src/imagination/vulkan/pvr_border.c:104:
FINISHME: Devices without tpu_border_colour_enhanced require entries
for compressed formats to be stored in the table pre-compressed.

I also get a constant stream of kernel error messages, all the same:

    powervr 13000000.gpu: [drm] Received unknown FWCCB command 2abc0069

And the first few frames seem to flicker. (Though that could also be the
display driver that's at fault.)


For reference, on the BeaglePlay I see:

    MESA: error: No hard coded idfwdf program. Returning empty program.
    MESA: error: No hard coded passthrough vertex shader. Returning
empty shader.
    MESA: warning:
../src/imagination/vulkan/pvr_descriptor_set.c:1073: FINISHME: Entry
tracker for allocations?


Regards
ChenYu


> Anyway, please have a look and test.
>
>
> Thanks
> ChenYu
>
> [1] https://lore.kernel.org/dri-devel/20220815165156.118212-2-sarah.walker@imgtec.com/
> [2] https://gitlab.freedesktop.org/imagination/linux-firmware/-/tree/powervr
> [3] https://github.com/SaschaWillems/Vulkan
> [4] https://lore.kernel.org/dri-devel/f2b2671e-5acc-4dec-9c2e-3c9cd2e1f19e@imgtec.com/
>
> Chen-Yu Tsai (6):
>   dt-bindings: clock: mediatek: Add mt8173 mfgtop
>   clk: mediatek: Add mt8173-mfgtop driver
>   dt-bindings: gpu: powervr-rogue: Add MediaTek MT8173 GPU
>   drm/imagination: Add compatible string entry for Series6XT
>   arm64: dts: mediatek: mt8173: Fix MFG_ASYNC power domain clock
>   arm64: dts: mediatek: mt8173: Add GPU device nodes
>
>  .../clock/mediatek,mt8173-mfgtop.yaml         |  71 ++++++
>  .../bindings/gpu/img,powervr-rogue.yaml       |  24 +-
>  arch/arm64/boot/dts/mediatek/mt8173.dtsi      |  26 +-
>  drivers/clk/mediatek/Kconfig                  |   9 +
>  drivers/clk/mediatek/Makefile                 |   1 +
>  drivers/clk/mediatek/clk-mt8173-mfgtop.c      | 240 ++++++++++++++++++
>  drivers/gpu/drm/imagination/pvr_drv.c         |   1 +
>  include/dt-bindings/clock/mt8173-clk.h        |   7 +
>  8 files changed, 374 insertions(+), 5 deletions(-)
>  create mode 100644 Documentation/devicetree/bindings/clock/mediatek,mt8173-mfgtop.yaml
>  create mode 100644 drivers/clk/mediatek/clk-mt8173-mfgtop.c
>
>
> base-commit: 1613e604df0cd359cf2a7fbd9be7a0bcfacfabd0
>
> Vulkan info output:
>
> WARNING: [Loader Message] Code 0 : terminator_CreateInstance: Received return code -3 from call to vkCreateInstance in ICD /usr/lib/aarch64-linux-gnu/libvulkan_virtio.so. Skipping this driver.
> 'DISPLAY' environment variable not set... skipping surface info
> ERROR: [../src/panfrost/vulkan/panvk_device.c:386] Code 0 : WARNING: panvk is not a conformant vulkan implementation, pass PAN_I_WANT_A_BROKEN_VULKAN_DRIVER=1 if you know what you're doing. (VK_ERROR_INCOMPATIBLE_DRIVER)
> MESA: error: No hard coded idfwdf program. Returning empty program.
> MESA: error: No hard coded passthrough rta vertex shader. Returning empty shader.
> MESA: error: No hard coded passthrough vertex shader. Returning empty shader.
> MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:71: FINISHME: Missing reset support for brn51764
> MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:74: FINISHME: Missing reset support for brn58839
> MESA: warning: ../src/imagination/vulkan/pvr_border.c:104: FINISHME: Devices without tpu_border_colour_enhanced require entries for compressed formats to be stored in the table pre-compressed.
> ==========
> VULKANINFO
> ==========
>
> Vulkan Instance Version: 1.3.280
>
>
> Instance Extensions: count = 23
> ===============================
>         VK_EXT_acquire_drm_display             : extension revision 1
>         VK_EXT_acquire_xlib_display            : extension revision 1
>         VK_EXT_debug_report                    : extension revision 10
>         VK_EXT_debug_utils                     : extension revision 2
>         VK_EXT_direct_mode_display             : extension revision 1
>         VK_EXT_display_surface_counter         : extension revision 1
>         VK_EXT_surface_maintenance1            : extension revision 1
>         VK_EXT_swapchain_colorspace            : extension revision 4
>         VK_KHR_device_group_creation           : extension revision 1
>         VK_KHR_display                         : extension revision 23
>         VK_KHR_external_fence_capabilities     : extension revision 1
>         VK_KHR_external_memory_capabilities    : extension revision 1
>         VK_KHR_external_semaphore_capabilities : extension revision 1
>         VK_KHR_get_display_properties2         : extension revision 1
>         VK_KHR_get_physical_device_properties2 : extension revision 2
>         VK_KHR_get_surface_capabilities2       : extension revision 1
>         VK_KHR_portability_enumeration         : extension revision 1
>         VK_KHR_surface                         : extension revision 25
>         VK_KHR_surface_protected_capabilities  : extension revision 1
>         VK_KHR_wayland_surface                 : extension revision 6
>         VK_KHR_xcb_surface                     : extension revision 6
>         VK_KHR_xlib_surface                    : extension revision 6
>         VK_LUNARG_direct_driver_loading        : extension revision 1
>
> Layers: count = 2
> =================
> VK_LAYER_MESA_device_select (Linux device selection layer) Vulkan version 1.3.211, layer version 1:
>         Layer Extensions: count = 0
>         Devices: count = 2
>                 GPU id = 0 (Imagination PowerVR Rogue GX6250)
>                 Layer-Device Extensions: count = 0
>
>                 GPU id = 1 (llvmpipe (LLVM 17.0.6, 128 bits))
>                 Layer-Device Extensions: count = 0
>
> VK_LAYER_MESA_overlay (Mesa Overlay layer) Vulkan version 1.3.211, layer version 1:
>         Layer Extensions: count = 0
>         Devices: count = 2
>                 GPU id = 0 (Imagination PowerVR Rogue GX6250)
>                 Layer-Device Extensions: count = 0
>
>                 GPU id = 1 (llvmpipe (LLVM 17.0.6, 128 bits))
>                 Layer-Device Extensions: count = 0
>
> Device Properties and Extensions:
> =================================
> GPU0:
> VkPhysicalDeviceProperties:
> ---------------------------
>         apiVersion        = 1.0.274 (4194578)
>         driverVersion     = 24.0.8 (100663304)
>         vendorID          = 0x1010
>         deviceID          = 0x6250
>         deviceType        = PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU
>         deviceName        = Imagination PowerVR Rogue GX6250
>         pipelineCacheUUID = 6ddf30eb-d118-41f1-455f-580ae751c27b
>
> VkPhysicalDeviceLimits:
> -----------------------
>         maxImageDimension1D                             = 8192
>         maxImageDimension2D                             = 8192
>         maxImageDimension3D                             = 2048
>         maxImageDimensionCube                           = 8192
>         maxImageArrayLayers                             = 2048
>         maxTexelBufferElements                          = 65536
>         maxUniformBufferRange                           = 134217728
>         maxStorageBufferRange                           = 134217728
>         maxPushConstantsSize                            = 256
>         maxMemoryAllocationCount                        = 4294967295
>         maxSamplerAllocationCount                       = 4294967295
>         bufferImageGranularity                          = 0x00000001
>         sparseAddressSpaceSize                          = 0x4000000000
>         maxBoundDescriptorSets                          = 4
>         maxPerStageDescriptorSamplers                   = 32
>         maxPerStageDescriptorUniformBuffers             = 64
>         maxPerStageDescriptorStorageBuffers             = 36
>         maxPerStageDescriptorSampledImages              = 48
>         maxPerStageDescriptorStorageImages              = 8
>         maxPerStageDescriptorInputAttachments           = 8
>         maxPerStageResources                            = 224
>         maxDescriptorSetSamplers                        = 256
>         maxDescriptorSetUniformBuffers                  = 256
>         maxDescriptorSetUniformBuffersDynamic           = 8
>         maxDescriptorSetStorageBuffers                  = 256
>         maxDescriptorSetStorageBuffersDynamic           = 8
>         maxDescriptorSetSampledImages                   = 256
>         maxDescriptorSetStorageImages                   = 256
>         maxDescriptorSetInputAttachments                = 256
>         maxVertexInputAttributes                        = 16
>         maxVertexInputBindings                          = 16
>         maxVertexInputAttributeOffset                   = 65535
>         maxVertexInputBindingStride                     = 2147483648
>         maxVertexOutputComponents                       = 128
>         maxTessellationGenerationLevel                  = 0
>         maxTessellationPatchSize                        = 0
>         maxTessellationControlPerVertexInputComponents  = 0
>         maxTessellationControlPerVertexOutputComponents = 0
>         maxTessellationControlPerPatchOutputComponents  = 0
>         maxTessellationControlTotalOutputComponents     = 0
>         maxTessellationEvaluationInputComponents        = 0
>         maxTessellationEvaluationOutputComponents       = 0
>         maxGeometryShaderInvocations                    = 0
>         maxGeometryInputComponents                      = 0
>         maxGeometryOutputComponents                     = 0
>         maxGeometryOutputVertices                       = 0
>         maxGeometryTotalOutputComponents                = 0
>         maxFragmentInputComponents                      = 128
>         maxFragmentOutputAttachments                    = 8
>         maxFragmentDualSrcAttachments                   = 0
>         maxFragmentCombinedOutputResources              = 52
>         maxComputeSharedMemorySize                      = 16384
>         maxComputeWorkGroupCount: count = 3
>                 65536
>                 65536
>                 65536
>         maxComputeWorkGroupInvocations                  = 512
>         maxComputeWorkGroupSize: count = 3
>                 512
>                 512
>                 64
>         subPixelPrecisionBits                           = 8
>         subTexelPrecisionBits                           = 8
>         mipmapPrecisionBits                             = 8
>         maxDrawIndexedIndexValue                        = 4294967295
>         maxDrawIndirectCount                            = 2147483648
>         maxSamplerLodBias                               = 16
>         maxSamplerAnisotropy                            = 1
>         maxViewports                                    = 1
>         maxViewportDimensions: count = 2
>                 8192
>                 8192
>         viewportBoundsRange: count = 2
>                 -16384
>                 16384
>         viewportSubPixelBits                            = 0
>         minMemoryMapAlignment                           = 64
>         minTexelBufferOffsetAlignment                   = 0x00000010
>         minUniformBufferOffsetAlignment                 = 0x00000004
>         minStorageBufferOffsetAlignment                 = 0x00000004
>         minTexelOffset                                  = -8
>         maxTexelOffset                                  = 7
>         minTexelGatherOffset                            = -8
>         maxTexelGatherOffset                            = 7
>         minInterpolationOffset                          = -0.5
>         maxInterpolationOffset                          = 0.5
>         subPixelInterpolationOffsetBits                 = 4
>         maxFramebufferWidth                             = 8192
>         maxFramebufferHeight                            = 8192
>         maxFramebufferLayers                            = 2048
>         framebufferColorSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         framebufferDepthSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         framebufferStencilSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         framebufferNoAttachmentsSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         maxColorAttachments                             = 8
>         sampledImageColorSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         sampledImageIntegerSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         sampledImageDepthSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         sampledImageStencilSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         storageImageSampleCounts: count = 4
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_2_BIT
>                 SAMPLE_COUNT_4_BIT
>                 SAMPLE_COUNT_8_BIT
>         maxSampleMaskWords                              = 1
>         timestampComputeAndGraphics                     = false
>         timestampPeriod                                 = 0
>         maxClipDistances                                = 8
>         maxCullDistances                                = 8
>         maxCombinedClipAndCullDistances                 = 8
>         discreteQueuePriorities                         = 2
>         pointSizeRange: count = 2
>                 1
>                 511
>         lineWidthRange: count = 2
>                 0.0625
>                 16
>         pointSizeGranularity                            = 0.0625
>         lineWidthGranularity                            = 0.0625
>         strictLines                                     = false
>         standardSampleLocations                         = true
>         optimalBufferCopyOffsetAlignment                = 0x00000004
>         optimalBufferCopyRowPitchAlignment              = 0x00000004
>         nonCoherentAtomSize                             = 0x00000001
>
> VkPhysicalDeviceSparseProperties:
> ---------------------------------
>         residencyStandard2DBlockShape            = false
>         residencyStandard2DMultisampleBlockShape = false
>         residencyStandard3DBlockShape            = false
>         residencyAlignedMipSize                  = false
>         residencyNonResidentStrict               = false
>
> VkPhysicalDeviceTexelBufferAlignmentPropertiesEXT:
> --------------------------------------------------
>         storageTexelBufferOffsetAlignmentBytes       = 0x00000010
>         storageTexelBufferOffsetSingleTexelAlignment = true
>         uniformTexelBufferOffsetAlignmentBytes       = 0x00000010
>         uniformTexelBufferOffsetSingleTexelAlignment = false
>
> VkPhysicalDeviceTimelineSemaphorePropertiesKHR:
> -----------------------------------------------
>         maxTimelineSemaphoreValueDifference = 18446744073709551615
>
> Device Extensions: count = 20
>         VK_EXT_external_memory_dma_buf        : extension revision 1
>         VK_EXT_host_query_reset               : extension revision 1
>         VK_EXT_private_data                   : extension revision 1
>         VK_EXT_scalar_block_layout            : extension revision 1
>         VK_EXT_texel_buffer_alignment         : extension revision 1
>         VK_EXT_tooling_info                   : extension revision 1
>         VK_KHR_bind_memory2                   : extension revision 1
>         VK_KHR_copy_commands2                 : extension revision 1
>         VK_KHR_external_fence                 : extension revision 1
>         VK_KHR_external_fence_fd              : extension revision 1
>         VK_KHR_external_memory                : extension revision 1
>         VK_KHR_external_memory_fd             : extension revision 1
>         VK_KHR_external_semaphore             : extension revision 1
>         VK_KHR_external_semaphore_fd          : extension revision 1
>         VK_KHR_format_feature_flags2          : extension revision 2
>         VK_KHR_get_memory_requirements2       : extension revision 1
>         VK_KHR_image_format_list              : extension revision 1
>         VK_KHR_swapchain                      : extension revision 70
>         VK_KHR_timeline_semaphore             : extension revision 2
>         VK_KHR_uniform_buffer_standard_layout : extension revision 1
>
> VkQueueFamilyProperties:
> ========================
>         queueProperties[0]:
>         -------------------
>                 minImageTransferGranularity = (1,1,1)
>                 queueCount                  = 2
>                 queueFlags                  = QUEUE_GRAPHICS_BIT | QUEUE_COMPUTE_BIT | QUEUE_TRANSFER_BIT
>                 timestampValidBits          = 0
>                 present support             = false
>
> VkPhysicalDeviceMemoryProperties:
> =================================
> memoryHeaps: count = 1
>         memoryHeaps[0]:
>                 size   = 1752969216 (0x687c3000) (1.63 GiB)
>                 flags: count = 1
>                         MEMORY_HEAP_DEVICE_LOCAL_BIT
> memoryTypes: count = 1
>         memoryTypes[0]:
>                 heapIndex     = 0
>                 propertyFlags = 0x0007: count = 3
>                         MEMORY_PROPERTY_DEVICE_LOCAL_BIT
>                         MEMORY_PROPERTY_HOST_VISIBLE_BIT
>                         MEMORY_PROPERTY_HOST_COHERENT_BIT
>                 usable for:
>                         IMAGE_TILING_OPTIMAL:
>                                 color images
>                                 FORMAT_D16_UNORM
>                                 FORMAT_D32_SFLOAT
>                                 FORMAT_S8_UINT
>                                 FORMAT_D24_UNORM_S8_UINT
>                                 (non-sparse)
>                         IMAGE_TILING_LINEAR:
>                                 color images
>                                 (non-sparse)
>
> VkPhysicalDeviceFeatures:
> =========================
>         robustBufferAccess                      = true
>         fullDrawIndexUint32                     = true
>         imageCubeArray                          = true
>         independentBlend                        = false
>         geometryShader                          = false
>         tessellationShader                      = false
>         sampleRateShading                       = true
>         dualSrcBlend                            = false
>         logicOp                                 = false
>         multiDrawIndirect                       = true
>         drawIndirectFirstInstance               = true
>         depthClamp                              = true
>         depthBiasClamp                          = true
>         fillModeNonSolid                        = false
>         depthBounds                             = false
>         wideLines                               = true
>         largePoints                             = true
>         alphaToOne                              = false
>         multiViewport                           = false
>         samplerAnisotropy                       = false
>         textureCompressionETC2                  = true
>         textureCompressionASTC_LDR              = false
>         textureCompressionBC                    = false
>         occlusionQueryPrecise                   = false
>         pipelineStatisticsQuery                 = false
>         vertexPipelineStoresAndAtomics          = true
>         fragmentStoresAndAtomics                = true
>         shaderTessellationAndGeometryPointSize  = false
>         shaderImageGatherExtended               = false
>         shaderStorageImageExtendedFormats       = true
>         shaderStorageImageMultisample           = false
>         shaderStorageImageReadWithoutFormat     = true
>         shaderStorageImageWriteWithoutFormat    = false
>         shaderUniformBufferArrayDynamicIndexing = true
>         shaderSampledImageArrayDynamicIndexing  = true
>         shaderStorageBufferArrayDynamicIndexing = true
>         shaderStorageImageArrayDynamicIndexing  = true
>         shaderClipDistance                      = false
>         shaderCullDistance                      = false
>         shaderFloat64                           = false
>         shaderInt64                             = true
>         shaderInt16                             = true
>         shaderResourceResidency                 = false
>         shaderResourceMinLod                    = false
>         sparseBinding                           = false
>         sparseResidencyBuffer                   = false
>         sparseResidencyImage2D                  = false
>         sparseResidencyImage3D                  = false
>         sparseResidency2Samples                 = false
>         sparseResidency4Samples                 = false
>         sparseResidency8Samples                 = false
>         sparseResidency16Samples                = false
>         sparseResidencyAliased                  = false
>         variableMultisampleRate                 = false
>         inheritedQueries                        = false
>
> VkPhysicalDeviceHostQueryResetFeaturesEXT:
> ------------------------------------------
>         hostQueryReset = true
>
> VkPhysicalDevicePrivateDataFeaturesEXT:
> ---------------------------------------
>         privateData = true
>
> VkPhysicalDeviceScalarBlockLayoutFeaturesEXT:
> ---------------------------------------------
>         scalarBlockLayout = true
>
> VkPhysicalDeviceTexelBufferAlignmentFeaturesEXT:
> ------------------------------------------------
>         texelBufferAlignment = true
>
> VkPhysicalDeviceTimelineSemaphoreFeaturesKHR:
> ---------------------------------------------
>         timelineSemaphore = true
>
> VkPhysicalDeviceUniformBufferStandardLayoutFeaturesKHR:
> -------------------------------------------------------
>         uniformBufferStandardLayout = true
>
>
> GPU1:
> VkPhysicalDeviceProperties:
> ---------------------------
>         apiVersion        = 1.3.274 (4206866)
>         driverVersion     = 0.0.1 (1)
>         vendorID          = 0x10005
>         deviceID          = 0x0000
>         deviceType        = PHYSICAL_DEVICE_TYPE_CPU
>         deviceName        = llvmpipe (LLVM 17.0.6, 128 bits)
>         pipelineCacheUUID = 32342e30-2e38-2d31-2b70-316161616161
>
> VkPhysicalDeviceLimits:
> -----------------------
>         maxImageDimension1D                             = 16384
>         maxImageDimension2D                             = 16384
>         maxImageDimension3D                             = 4096
>         maxImageDimensionCube                           = 32768
>         maxImageArrayLayers                             = 2048
>         maxTexelBufferElements                          = 134217728
>         maxUniformBufferRange                           = 65536
>         maxStorageBufferRange                           = 134217728
>         maxPushConstantsSize                            = 256
>         maxMemoryAllocationCount                        = 4294967295
>         maxSamplerAllocationCount                       = 32768
>         bufferImageGranularity                          = 0x00000040
>         sparseAddressSpaceSize                          = 0x00000000
>         maxBoundDescriptorSets                          = 8
>         maxPerStageDescriptorSamplers                   = 1000000
>         maxPerStageDescriptorUniformBuffers             = 1000000
>         maxPerStageDescriptorStorageBuffers             = 1000000
>         maxPerStageDescriptorSampledImages              = 1000000
>         maxPerStageDescriptorStorageImages              = 1000000
>         maxPerStageDescriptorInputAttachments           = 1000000
>         maxPerStageResources                            = 1000000
>         maxDescriptorSetSamplers                        = 1000000
>         maxDescriptorSetUniformBuffers                  = 1000000
>         maxDescriptorSetUniformBuffersDynamic           = 1000000
>         maxDescriptorSetStorageBuffers                  = 1000000
>         maxDescriptorSetStorageBuffersDynamic           = 1000000
>         maxDescriptorSetSampledImages                   = 1000000
>         maxDescriptorSetStorageImages                   = 1000000
>         maxDescriptorSetInputAttachments                = 1000000
>         maxVertexInputAttributes                        = 32
>         maxVertexInputBindings                          = 32
>         maxVertexInputAttributeOffset                   = 2047
>         maxVertexInputBindingStride                     = 2048
>         maxVertexOutputComponents                       = 128
>         maxTessellationGenerationLevel                  = 64
>         maxTessellationPatchSize                        = 32
>         maxTessellationControlPerVertexInputComponents  = 128
>         maxTessellationControlPerVertexOutputComponents = 128
>         maxTessellationControlPerPatchOutputComponents  = 128
>         maxTessellationControlTotalOutputComponents     = 4096
>         maxTessellationEvaluationInputComponents        = 128
>         maxTessellationEvaluationOutputComponents       = 128
>         maxGeometryShaderInvocations                    = 32
>         maxGeometryInputComponents                      = 64
>         maxGeometryOutputComponents                     = 128
>         maxGeometryOutputVertices                       = 1024
>         maxGeometryTotalOutputComponents                = 1024
>         maxFragmentInputComponents                      = 128
>         maxFragmentOutputAttachments                    = 8
>         maxFragmentDualSrcAttachments                   = 2
>         maxFragmentCombinedOutputResources              = 104
>         maxComputeSharedMemorySize                      = 32768
>         maxComputeWorkGroupCount: count = 3
>                 65535
>                 65535
>                 65535
>         maxComputeWorkGroupInvocations                  = 1024
>         maxComputeWorkGroupSize: count = 3
>                 1024
>                 1024
>                 1024
>         subPixelPrecisionBits                           = 8
>         subTexelPrecisionBits                           = 8
>         mipmapPrecisionBits                             = 4
>         maxDrawIndexedIndexValue                        = 4294967295
>         maxDrawIndirectCount                            = 4294967295
>         maxSamplerLodBias                               = 16
>         maxSamplerAnisotropy                            = 16
>         maxViewports                                    = 16
>         maxViewportDimensions: count = 2
>                 16384
>                 16384
>         viewportBoundsRange: count = 2
>                 -32768
>                 32768
>         viewportSubPixelBits                            = 0
>         minMemoryMapAlignment                           = 64
>         minTexelBufferOffsetAlignment                   = 0x00000010
>         minUniformBufferOffsetAlignment                 = 0x00000010
>         minStorageBufferOffsetAlignment                 = 0x00000010
>         minTexelOffset                                  = -32
>         maxTexelOffset                                  = 31
>         minTexelGatherOffset                            = -32
>         maxTexelGatherOffset                            = 31
>         minInterpolationOffset                          = -2
>         maxInterpolationOffset                          = 2
>         subPixelInterpolationOffsetBits                 = 8
>         maxFramebufferWidth                             = 16384
>         maxFramebufferHeight                            = 16384
>         maxFramebufferLayers                            = 2048
>         framebufferColorSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         framebufferDepthSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         framebufferStencilSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         framebufferNoAttachmentsSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         maxColorAttachments                             = 8
>         sampledImageColorSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         sampledImageIntegerSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         sampledImageDepthSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         sampledImageStencilSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         storageImageSampleCounts: count = 2
>                 SAMPLE_COUNT_1_BIT
>                 SAMPLE_COUNT_4_BIT
>         maxSampleMaskWords                              = 1
>         timestampComputeAndGraphics                     = true
>         timestampPeriod                                 = 1
>         maxClipDistances                                = 8
>         maxCullDistances                                = 8
>         maxCombinedClipAndCullDistances                 = 8
>         discreteQueuePriorities                         = 2
>         pointSizeRange: count = 2
>                 0
>                 255
>         lineWidthRange: count = 2
>                 1
>                 255
>         pointSizeGranularity                            = 0.125
>         lineWidthGranularity                            = 0.0078125
>         strictLines                                     = true
>         standardSampleLocations                         = true
>         optimalBufferCopyOffsetAlignment                = 0x00000080
>         optimalBufferCopyRowPitchAlignment              = 0x00000080
>         nonCoherentAtomSize                             = 0x00000040
>
> VkPhysicalDeviceSparseProperties:
> ---------------------------------
>         residencyStandard2DBlockShape            = false
>         residencyStandard2DMultisampleBlockShape = false
>         residencyStandard3DBlockShape            = false
>         residencyAlignedMipSize                  = false
>         residencyNonResidentStrict               = false
>
> VkPhysicalDeviceCustomBorderColorPropertiesEXT:
> -----------------------------------------------
>         maxCustomBorderColorSamplers = 32768
>
> VkPhysicalDeviceDescriptorBufferDensityMapPropertiesEXT:
> --------------------------------------------------------
>         combinedImageSamplerDensityMapDescriptorSize = 0
>
> VkPhysicalDeviceDescriptorBufferPropertiesEXT:
> ----------------------------------------------
>         combinedImageSamplerDescriptorSingleArray            = true
>         bufferlessPushDescriptors                            = true
>         allowSamplerImageViewPostSubmitCreation              = false
>         descriptorBufferOffsetAlignment                      = 0x00000004
>         maxDescriptorBufferBindings                          = 8
>         maxResourceDescriptorBufferBindings                  = 8
>         maxSamplerDescriptorBufferBindings                   = 8
>         maxEmbeddedImmutableSamplerBindings                  = 8
>         maxEmbeddedImmutableSamplers                         = 2032
>         bufferCaptureReplayDescriptorDataSize                = 0
>         imageCaptureReplayDescriptorDataSize                 = 0
>         imageViewCaptureReplayDescriptorDataSize             = 0
>         samplerCaptureReplayDescriptorDataSize               = 0
>         accelerationStructureCaptureReplayDescriptorDataSize = 0
>         samplerDescriptorSize                                = 256
>         combinedImageSamplerDescriptorSize                   = 256
>         sampledImageDescriptorSize                           = 256
>         storageImageDescriptorSize                           = 256
>         uniformTexelBufferDescriptorSize                     = 256
>         robustUniformTexelBufferDescriptorSize               = 256
>         storageTexelBufferDescriptorSize                     = 256
>         robustStorageTexelBufferDescriptorSize               = 256
>         uniformBufferDescriptorSize                          = 256
>         robustUniformBufferDescriptorSize                    = 256
>         storageBufferDescriptorSize                          = 256
>         robustStorageBufferDescriptorSize                    = 256
>         inputAttachmentDescriptorSize                        = 256
>         accelerationStructureDescriptorSize                  = 0
>         maxSamplerDescriptorBufferRange                      = 0x08000000
>         maxResourceDescriptorBufferRange                     = 0x10000000
>         samplerDescriptorBufferAddressSpaceSize              = 0x08000000
>         resourceDescriptorBufferAddressSpaceSize             = 0x08000000
>         descriptorBufferAddressSpaceSize                     = 0x08000000
>
> VkPhysicalDeviceExtendedDynamicState3PropertiesEXT:
> ---------------------------------------------------
>         dynamicPrimitiveTopologyUnrestricted = true
>
> VkPhysicalDeviceExternalMemoryHostPropertiesEXT:
> ------------------------------------------------
>         minImportedHostPointerAlignment = 0x00001000
>
> VkPhysicalDeviceGraphicsPipelineLibraryPropertiesEXT:
> -----------------------------------------------------
>         graphicsPipelineLibraryFastLinking                        = true
>         graphicsPipelineLibraryIndependentInterpolationDecoration = true
>
> VkPhysicalDeviceLineRasterizationPropertiesKHR:
> -----------------------------------------------
>         lineSubPixelPrecisionBits = 8
>
> VkPhysicalDeviceMaintenance5PropertiesKHR:
> ------------------------------------------
>         earlyFragmentMultisampleCoverageAfterSampleCounting = true
>         earlyFragmentSampleMaskTestBeforeSampleCounting     = false
>         depthStencilSwizzleOneSupport                       = false
>         polygonModePointSize                                = true
>         nonStrictSinglePixelWideLinesUseParallelogram       = false
>         nonStrictWideLinesUseParallelogram                  = false
>
> VkPhysicalDeviceMaintenance6PropertiesKHR:
> ------------------------------------------
>         blockTexelViewCompatibleMultipleLayers = true
>         maxCombinedImageSamplerDescriptorCount = 3
>         fragmentShadingRateClampCombinerInputs = false
>
> VkPhysicalDeviceMeshShaderPropertiesEXT:
> ----------------------------------------
>         maxTaskWorkGroupTotalCount            = 4194304
>         maxTaskWorkGroupCount: count = 3
>                 65536
>                 65536
>                 65536
>         maxTaskWorkGroupInvocations           = 1024
>         maxTaskWorkGroupSize: count = 3
>                 1024
>                 1024
>                 1024
>         maxTaskPayloadSize                    = 16384
>         maxTaskSharedMemorySize               = 32768
>         maxTaskPayloadAndSharedMemorySize     = 32768
>         maxMeshWorkGroupTotalCount            = 4194304
>         maxMeshWorkGroupCount: count = 3
>                 65536
>                 65536
>                 65536
>         maxMeshWorkGroupInvocations           = 1024
>         maxMeshWorkGroupSize: count = 3
>                 1024
>                 1024
>                 1024
>         maxMeshSharedMemorySize               = 28672
>         maxMeshPayloadAndSharedMemorySize     = 45056
>         maxMeshOutputMemorySize               = 32768
>         maxMeshPayloadAndOutputMemorySize     = 49152
>         maxMeshOutputComponents               = 128
>         maxMeshOutputVertices                 = 256
>         maxMeshOutputPrimitives               = 256
>         maxMeshOutputLayers                   = 8
>         maxMeshMultiviewViewCount             = 0
>         meshOutputPerVertexGranularity        = 1
>         meshOutputPerPrimitiveGranularity     = 1
>         maxPreferredTaskWorkGroupInvocations  = 64
>         maxPreferredMeshWorkGroupInvocations  = 128
>         prefersLocalInvocationVertexOutput    = true
>         prefersLocalInvocationPrimitiveOutput = true
>         prefersCompactVertexOutput            = true
>         prefersCompactPrimitiveOutput         = false
>
> VkPhysicalDeviceMultiDrawPropertiesEXT:
> ---------------------------------------
>         maxMultiDrawCount = 2048
>
> VkPhysicalDeviceNestedCommandBufferPropertiesEXT:
> -------------------------------------------------
>         maxCommandBufferNestingLevel = 4294967295
>
> VkPhysicalDeviceProvokingVertexPropertiesEXT:
> ---------------------------------------------
>         provokingVertexModePerPipeline                       = true
>         transformFeedbackPreservesTriangleFanProvokingVertex = true
>
> VkPhysicalDevicePushDescriptorPropertiesKHR:
> --------------------------------------------
>         maxPushDescriptors = 32
>
> VkPhysicalDeviceRobustness2PropertiesEXT:
> -----------------------------------------
>         robustStorageBufferAccessSizeAlignment = 0x00000001
>         robustUniformBufferAccessSizeAlignment = 0x00000001
>
> VkPhysicalDeviceShaderObjectPropertiesEXT:
> ------------------------------------------
>         shaderBinaryUUID     = 32342e30-2e38-2d31-2b70-316161616161
>         shaderBinaryVersion  = 1
>
> VkPhysicalDeviceTransformFeedbackPropertiesEXT:
> -----------------------------------------------
>         maxTransformFeedbackStreams                = 4
>         maxTransformFeedbackBuffers                = 4
>         maxTransformFeedbackBufferSize             = 0xffffffff
>         maxTransformFeedbackStreamDataSize         = 512
>         maxTransformFeedbackBufferDataSize         = 512
>         maxTransformFeedbackBufferDataStride       = 512
>         transformFeedbackQueries                   = true
>         transformFeedbackStreamsLinesTriangles     = false
>         transformFeedbackRasterizationStreamSelect = false
>         transformFeedbackDraw                      = true
>
> VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT:
> ----------------------------------------------------
>         maxVertexAttribDivisor = 4294967295
>
> VkPhysicalDeviceVulkan11Properties:
> -----------------------------------
>         deviceUUID                        = 6d657361-3234-2e30-2e38-2d312b703100
>         driverUUID                        = 6c6c766d-7069-7065-5555-494400000000
>         deviceNodeMask                    = 0
>         deviceLUIDValid                   = false
>         subgroupSize                      = 4
>         subgroupSupportedStages: count = 4
>                 SHADER_STAGE_FRAGMENT_BIT
>                 SHADER_STAGE_COMPUTE_BIT
>                 SHADER_STAGE_TASK_BIT_EXT
>                 SHADER_STAGE_MESH_BIT_EXT
>         subgroupSupportedOperations: count = 7
>                 SUBGROUP_FEATURE_BASIC_BIT
>                 SUBGROUP_FEATURE_VOTE_BIT
>                 SUBGROUP_FEATURE_ARITHMETIC_BIT
>                 SUBGROUP_FEATURE_BALLOT_BIT
>                 SUBGROUP_FEATURE_SHUFFLE_BIT
>                 SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT
>                 SUBGROUP_FEATURE_QUAD_BIT
>         subgroupQuadOperationsInAllStages = false
>         pointClippingBehavior             = POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES
>         maxMultiviewViewCount             = 6
>         maxMultiviewInstanceIndex         = 2147483647
>         protectedNoFault                  = false
>         maxPerSetDescriptors              = 1000000
>         maxMemoryAllocationSize           = 0x80000000
>
> VkPhysicalDeviceVulkan12Properties:
> -----------------------------------
>         driverID                                             = DRIVER_ID_MESA_LLVMPIPE
>         driverName                                           = llvmpipe
>         driverInfo                                           = Mesa 24.0.8-1+p1 (LLVM 17.0.6)
>         conformanceVersion:
>                 major    = 1
>                 minor    = 3
>                 subminor = 1
>                 patch    = 1
>         denormBehaviorIndependence                           = SHADER_FLOAT_CONTROLS_INDEPENDENCE_ALL
>         roundingModeIndependence                             = SHADER_FLOAT_CONTROLS_INDEPENDENCE_ALL
>         shaderSignedZeroInfNanPreserveFloat16                = true
>         shaderSignedZeroInfNanPreserveFloat32                = true
>         shaderSignedZeroInfNanPreserveFloat64                = true
>         shaderDenormPreserveFloat16                          = false
>         shaderDenormPreserveFloat32                          = false
>         shaderDenormPreserveFloat64                          = false
>         shaderDenormFlushToZeroFloat16                       = false
>         shaderDenormFlushToZeroFloat32                       = false
>         shaderDenormFlushToZeroFloat64                       = false
>         shaderRoundingModeRTEFloat16                         = true
>         shaderRoundingModeRTEFloat32                         = true
>         shaderRoundingModeRTEFloat64                         = true
>         shaderRoundingModeRTZFloat16                         = false
>         shaderRoundingModeRTZFloat32                         = false
>         shaderRoundingModeRTZFloat64                         = false
>         maxUpdateAfterBindDescriptorsInAllPools              = 4294967295
>         shaderUniformBufferArrayNonUniformIndexingNative     = true
>         shaderSampledImageArrayNonUniformIndexingNative      = true
>         shaderStorageBufferArrayNonUniformIndexingNative     = true
>         shaderStorageImageArrayNonUniformIndexingNative      = true
>         shaderInputAttachmentArrayNonUniformIndexingNative   = true
>         robustBufferAccessUpdateAfterBind                    = true
>         quadDivergentImplicitLod                             = true
>         maxPerStageDescriptorUpdateAfterBindSamplers         = 1000000
>         maxPerStageDescriptorUpdateAfterBindUniformBuffers   = 1000000
>         maxPerStageDescriptorUpdateAfterBindStorageBuffers   = 1000000
>         maxPerStageDescriptorUpdateAfterBindSampledImages    = 1000000
>         maxPerStageDescriptorUpdateAfterBindStorageImages    = 1000000
>         maxPerStageDescriptorUpdateAfterBindInputAttachments = 1000000
>         maxPerStageUpdateAfterBindResources                  = 1000000
>         maxDescriptorSetUpdateAfterBindSamplers              = 1000000
>         maxDescriptorSetUpdateAfterBindUniformBuffers        = 1000000
>         maxDescriptorSetUpdateAfterBindUniformBuffersDynamic = 1000000
>         maxDescriptorSetUpdateAfterBindStorageBuffers        = 1000000
>         maxDescriptorSetUpdateAfterBindStorageBuffersDynamic = 1000000
>         maxDescriptorSetUpdateAfterBindSampledImages         = 1000000
>         maxDescriptorSetUpdateAfterBindStorageImages         = 1000000
>         maxDescriptorSetUpdateAfterBindInputAttachments      = 1000000
>         supportedDepthResolveModes: count = 2
>                 RESOLVE_MODE_SAMPLE_ZERO_BIT
>                 RESOLVE_MODE_AVERAGE_BIT
>         supportedStencilResolveModes: count = 1
>                 RESOLVE_MODE_SAMPLE_ZERO_BIT
>         independentResolveNone                               = false
>         independentResolve                                   = false
>         filterMinmaxSingleComponentFormats                   = true
>         filterMinmaxImageComponentMapping                    = true
>         maxTimelineSemaphoreValueDifference                  = 18446744073709551615
>         framebufferIntegerColorSampleCounts: count = 1
>                 SAMPLE_COUNT_1_BIT
>
> VkPhysicalDeviceVulkan13Properties:
> -----------------------------------
>         minSubgroupSize                                                               = 4
>         maxSubgroupSize                                                               = 4
>         maxComputeWorkgroupSubgroups                                                  = 32
>         requiredSubgroupSizeStages: count = 2
>                 SHADER_STAGE_FRAGMENT_BIT
>                 SHADER_STAGE_COMPUTE_BIT
>         maxInlineUniformBlockSize                                                     = 4096
>         maxPerStageDescriptorInlineUniformBlocks                                      = 8
>         maxPerStageDescriptorUpdateAfterBindInlineUniformBlocks                       = 8
>         maxDescriptorSetInlineUniformBlocks                                           = 8
>         maxDescriptorSetUpdateAfterBindInlineUniformBlocks                            = 8
>         maxInlineUniformTotalSize                                                     = 262144
>         integerDotProduct8BitUnsignedAccelerated                                      = false
>         integerDotProduct8BitSignedAccelerated                                        = false
>         integerDotProduct8BitMixedSignednessAccelerated                               = false
>         integerDotProduct4x8BitPackedUnsignedAccelerated                              = false
>         integerDotProduct4x8BitPackedSignedAccelerated                                = false
>         integerDotProduct4x8BitPackedMixedSignednessAccelerated                       = false
>         integerDotProduct16BitUnsignedAccelerated                                     = false
>         integerDotProduct16BitSignedAccelerated                                       = false
>         integerDotProduct16BitMixedSignednessAccelerated                              = false
>         integerDotProduct32BitUnsignedAccelerated                                     = false
>         integerDotProduct32BitSignedAccelerated                                       = false
>         integerDotProduct32BitMixedSignednessAccelerated                              = false
>         integerDotProduct64BitUnsignedAccelerated                                     = false
>         integerDotProduct64BitSignedAccelerated                                       = false
>         integerDotProduct64BitMixedSignednessAccelerated                              = false
>         integerDotProductAccumulatingSaturating8BitUnsignedAccelerated                = false
>         integerDotProductAccumulatingSaturating8BitSignedAccelerated                  = false
>         integerDotProductAccumulatingSaturating8BitMixedSignednessAccelerated         = false
>         integerDotProductAccumulatingSaturating4x8BitPackedUnsignedAccelerated        = false
>         integerDotProductAccumulatingSaturating4x8BitPackedSignedAccelerated          = false
>         integerDotProductAccumulatingSaturating4x8BitPackedMixedSignednessAccelerated = false
>         integerDotProductAccumulatingSaturating16BitUnsignedAccelerated               = false
>         integerDotProductAccumulatingSaturating16BitSignedAccelerated                 = false
>         integerDotProductAccumulatingSaturating16BitMixedSignednessAccelerated        = false
>         integerDotProductAccumulatingSaturating32BitUnsignedAccelerated               = false
>         integerDotProductAccumulatingSaturating32BitSignedAccelerated                 = false
>         integerDotProductAccumulatingSaturating32BitMixedSignednessAccelerated        = false
>         integerDotProductAccumulatingSaturating64BitUnsignedAccelerated               = false
>         integerDotProductAccumulatingSaturating64BitSignedAccelerated                 = false
>         integerDotProductAccumulatingSaturating64BitMixedSignednessAccelerated        = false
>         storageTexelBufferOffsetAlignmentBytes                                        = 0x00000010
>         storageTexelBufferOffsetSingleTexelAlignment                                  = true
>         uniformTexelBufferOffsetAlignmentBytes                                        = 0x00000010
>         uniformTexelBufferOffsetSingleTexelAlignment                                  = true
>         maxBufferSize                                                                 = 0xffffffff
>
> VkPhysicalDeviceHostImageCopyPropertiesEXT:
> -------------------------------------------
>         copySrcLayoutCount                  = 23
>         pCopySrcLayouts: count = 23
>                 IMAGE_LAYOUT_GENERAL
>                 IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL
>                 IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL
>                 IMAGE_LAYOUT_PREINITIALIZED
>                 IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_PRESENT_SRC_KHR
>                 IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR
>                 IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR
>                 IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR
>                 IMAGE_LAYOUT_SHARED_PRESENT_KHR
>                 IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT
>                 IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR
>         copyDstLayoutCount                  = 23
>         pCopyDstLayouts: count = 23
>                 IMAGE_LAYOUT_GENERAL
>                 IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL
>                 IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL
>                 IMAGE_LAYOUT_PREINITIALIZED
>                 IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_READ_ONLY_OPTIMAL
>                 IMAGE_LAYOUT_ATTACHMENT_OPTIMAL
>                 IMAGE_LAYOUT_PRESENT_SRC_KHR
>                 IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR
>                 IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR
>                 IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR
>                 IMAGE_LAYOUT_SHARED_PRESENT_KHR
>                 IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT
>                 IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR
>         optimalTilingLayoutUUID             = 32342e30-2e38-2d31-2b70-316161616161
>         identicalMemoryTypeRequirements     = false
>
> Device Extensions: count = 124
>         VK_AMDX_shader_enqueue                        : extension revision 1
>         VK_ARM_rasterization_order_attachment_access  : extension revision 1
>         VK_EXT_4444_formats                           : extension revision 1
>         VK_EXT_attachment_feedback_loop_dynamic_state : extension revision 1
>         VK_EXT_attachment_feedback_loop_layout        : extension revision 2
>         VK_EXT_border_color_swizzle                   : extension revision 1
>         VK_EXT_calibrated_timestamps                  : extension revision 2
>         VK_EXT_color_write_enable                     : extension revision 1
>         VK_EXT_conditional_rendering                  : extension revision 2
>         VK_EXT_custom_border_color                    : extension revision 12
>         VK_EXT_depth_clip_control                     : extension revision 1
>         VK_EXT_depth_clip_enable                      : extension revision 1
>         VK_EXT_depth_range_unrestricted               : extension revision 1
>         VK_EXT_descriptor_buffer                      : extension revision 1
>         VK_EXT_descriptor_indexing                    : extension revision 2
>         VK_EXT_dynamic_rendering_unused_attachments   : extension revision 1
>         VK_EXT_extended_dynamic_state                 : extension revision 1
>         VK_EXT_extended_dynamic_state2                : extension revision 1
>         VK_EXT_extended_dynamic_state3                : extension revision 2
>         VK_EXT_external_memory_host                   : extension revision 1
>         VK_EXT_graphics_pipeline_library              : extension revision 1
>         VK_EXT_host_image_copy                        : extension revision 1
>         VK_EXT_host_query_reset                       : extension revision 1
>         VK_EXT_image_2d_view_of_3d                    : extension revision 1
>         VK_EXT_image_robustness                       : extension revision 1
>         VK_EXT_image_sliced_view_of_3d                : extension revision 1
>         VK_EXT_index_type_uint8                       : extension revision 1
>         VK_EXT_inline_uniform_block                   : extension revision 1
>         VK_EXT_line_rasterization                     : extension revision 1
>         VK_EXT_load_store_op_none                     : extension revision 1
>         VK_EXT_memory_budget                          : extension revision 1
>         VK_EXT_memory_priority                        : extension revision 1
>         VK_EXT_mesh_shader                            : extension revision 1
>         VK_EXT_multi_draw                             : extension revision 1
>         VK_EXT_multisampled_render_to_single_sampled  : extension revision 1
>         VK_EXT_mutable_descriptor_type                : extension revision 1
>         VK_EXT_nested_command_buffer                  : extension revision 1
>         VK_EXT_non_seamless_cube_map                  : extension revision 1
>         VK_EXT_pageable_device_local_memory           : extension revision 1
>         VK_EXT_pipeline_creation_cache_control        : extension revision 3
>         VK_EXT_pipeline_creation_feedback             : extension revision 1
>         VK_EXT_post_depth_coverage                    : extension revision 1
>         VK_EXT_primitive_topology_list_restart        : extension revision 1
>         VK_EXT_primitives_generated_query             : extension revision 1
>         VK_EXT_private_data                           : extension revision 1
>         VK_EXT_provoking_vertex                       : extension revision 1
>         VK_EXT_rasterization_order_attachment_access  : extension revision 1
>         VK_EXT_robustness2                            : extension revision 1
>         VK_EXT_sampler_filter_minmax                  : extension revision 2
>         VK_EXT_scalar_block_layout                    : extension revision 1
>         VK_EXT_separate_stencil_usage                 : extension revision 1
>         VK_EXT_shader_atomic_float                    : extension revision 1
>         VK_EXT_shader_atomic_float2                   : extension revision 1
>         VK_EXT_shader_demote_to_helper_invocation     : extension revision 1
>         VK_EXT_shader_object                          : extension revision 1
>         VK_EXT_shader_stencil_export                  : extension revision 1
>         VK_EXT_shader_subgroup_ballot                 : extension revision 1
>         VK_EXT_shader_subgroup_vote                   : extension revision 1
>         VK_EXT_shader_viewport_index_layer            : extension revision 1
>         VK_EXT_subgroup_size_control                  : extension revision 2
>         VK_EXT_texel_buffer_alignment                 : extension revision 1
>         VK_EXT_transform_feedback                     : extension revision 1
>         VK_EXT_vertex_attribute_divisor               : extension revision 3
>         VK_EXT_vertex_input_dynamic_state             : extension revision 2
>         VK_EXT_ycbcr_2plane_444_formats               : extension revision 1
>         VK_EXT_ycbcr_image_arrays                     : extension revision 1
>         VK_GOOGLE_decorate_string                     : extension revision 1
>         VK_GOOGLE_hlsl_functionality1                 : extension revision 1
>         VK_KHR_16bit_storage                          : extension revision 1
>         VK_KHR_8bit_storage                           : extension revision 1
>         VK_KHR_bind_memory2                           : extension revision 1
>         VK_KHR_buffer_device_address                  : extension revision 1
>         VK_KHR_copy_commands2                         : extension revision 1
>         VK_KHR_create_renderpass2                     : extension revision 1
>         VK_KHR_dedicated_allocation                   : extension revision 3
>         VK_KHR_depth_stencil_resolve                  : extension revision 1
>         VK_KHR_descriptor_update_template             : extension revision 1
>         VK_KHR_device_group                           : extension revision 4
>         VK_KHR_draw_indirect_count                    : extension revision 1
>         VK_KHR_driver_properties                      : extension revision 1
>         VK_KHR_dynamic_rendering                      : extension revision 1
>         VK_KHR_external_fence                         : extension revision 1
>         VK_KHR_external_memory                        : extension revision 1
>         VK_KHR_external_memory_fd                     : extension revision 1
>         VK_KHR_external_semaphore                     : extension revision 1
>         VK_KHR_format_feature_flags2                  : extension revision 2
>         VK_KHR_get_memory_requirements2               : extension revision 1
>         VK_KHR_image_format_list                      : extension revision 1
>         VK_KHR_imageless_framebuffer                  : extension revision 1
>         VK_KHR_incremental_present                    : extension revision 2
>         VK_KHR_maintenance1                           : extension revision 2
>         VK_KHR_maintenance2                           : extension revision 1
>         VK_KHR_maintenance3                           : extension revision 1
>         VK_KHR_maintenance4                           : extension revision 2
>         VK_KHR_maintenance5                           : extension revision 1
>         VK_KHR_maintenance6                           : extension revision 1
>         VK_KHR_map_memory2                            : extension revision 1
>         VK_KHR_multiview                              : extension revision 1
>         VK_KHR_pipeline_library                       : extension revision 1
>         VK_KHR_push_descriptor                        : extension revision 2
>         VK_KHR_relaxed_block_layout                   : extension revision 1
>         VK_KHR_sampler_mirror_clamp_to_edge           : extension revision 3
>         VK_KHR_sampler_ycbcr_conversion               : extension revision 14
>         VK_KHR_separate_depth_stencil_layouts         : extension revision 1
>         VK_KHR_shader_atomic_int64                    : extension revision 1
>         VK_KHR_shader_clock                           : extension revision 1
>         VK_KHR_shader_draw_parameters                 : extension revision 1
>         VK_KHR_shader_float16_int8                    : extension revision 1
>         VK_KHR_shader_float_controls                  : extension revision 4
>         VK_KHR_shader_integer_dot_product             : extension revision 1
>         VK_KHR_shader_non_semantic_info               : extension revision 1
>         VK_KHR_shader_subgroup_extended_types         : extension revision 1
>         VK_KHR_shader_terminate_invocation            : extension revision 1
>         VK_KHR_spirv_1_4                              : extension revision 1
>         VK_KHR_storage_buffer_storage_class           : extension revision 1
>         VK_KHR_swapchain                              : extension revision 70
>         VK_KHR_swapchain_mutable_format               : extension revision 1
>         VK_KHR_synchronization2                       : extension revision 1
>         VK_KHR_timeline_semaphore                     : extension revision 2
>         VK_KHR_uniform_buffer_standard_layout         : extension revision 1
>         VK_KHR_variable_pointers                      : extension revision 1
>         VK_KHR_vulkan_memory_model                    : extension revision 3
>         VK_KHR_zero_initialize_workgroup_memory       : extension revision 1
>         VK_NV_device_generated_commands               : extension revision 3
>
> VkQueueFamilyProperties:
> ========================
>         queueProperties[0]:
>         -------------------
>                 minImageTransferGranularity = (1,1,1)
>                 queueCount                  = 1
>                 queueFlags                  = QUEUE_GRAPHICS_BIT | QUEUE_COMPUTE_BIT | QUEUE_TRANSFER_BIT
>                 timestampValidBits          = 64
>                 present support             = false
>
> VkPhysicalDeviceMemoryProperties:
> =================================
> memoryHeaps: count = 1
>         memoryHeaps[0]:
>                 size   = 3505938432 (0xd0f86000) (3.27 GiB)
>                 budget = 3505938432 (0xd0f86000) (3.27 GiB)
>                 usage  = 522092544 (0x1f1e8000) (497.91 MiB)
>                 flags: count = 1
>                         MEMORY_HEAP_DEVICE_LOCAL_BIT
> memoryTypes: count = 1
>         memoryTypes[0]:
>                 heapIndex     = 0
>                 propertyFlags = 0x000f: count = 4
>                         MEMORY_PROPERTY_DEVICE_LOCAL_BIT
>                         MEMORY_PROPERTY_HOST_VISIBLE_BIT
>                         MEMORY_PROPERTY_HOST_COHERENT_BIT
>                         MEMORY_PROPERTY_HOST_CACHED_BIT
>                 usable for:
>                         IMAGE_TILING_OPTIMAL:
>                                 color images
>                                 FORMAT_D16_UNORM
>                                 FORMAT_X8_D24_UNORM_PACK32
>                                 FORMAT_D32_SFLOAT
>                                 FORMAT_S8_UINT
>                                 FORMAT_D24_UNORM_S8_UINT
>                                 FORMAT_D32_SFLOAT_S8_UINT
>                                 (non-sparse)
>                         IMAGE_TILING_LINEAR:
>                                 color images
>                                 (non-sparse)
>
> VkPhysicalDeviceFeatures:
> =========================
>         robustBufferAccess                      = true
>         fullDrawIndexUint32                     = true
>         imageCubeArray                          = true
>         independentBlend                        = true
>         geometryShader                          = true
>         tessellationShader                      = true
>         sampleRateShading                       = true
>         dualSrcBlend                            = true
>         logicOp                                 = true
>         multiDrawIndirect                       = true
>         drawIndirectFirstInstance               = true
>         depthClamp                              = true
>         depthBiasClamp                          = true
>         fillModeNonSolid                        = true
>         depthBounds                             = false
>         wideLines                               = true
>         largePoints                             = true
>         alphaToOne                              = true
>         multiViewport                           = true
>         samplerAnisotropy                       = true
>         textureCompressionETC2                  = false
>         textureCompressionASTC_LDR              = false
>         textureCompressionBC                    = true
>         occlusionQueryPrecise                   = true
>         pipelineStatisticsQuery                 = true
>         vertexPipelineStoresAndAtomics          = true
>         fragmentStoresAndAtomics                = true
>         shaderTessellationAndGeometryPointSize  = true
>         shaderImageGatherExtended               = true
>         shaderStorageImageExtendedFormats       = true
>         shaderStorageImageMultisample           = true
>         shaderStorageImageReadWithoutFormat     = true
>         shaderStorageImageWriteWithoutFormat    = true
>         shaderUniformBufferArrayDynamicIndexing = true
>         shaderSampledImageArrayDynamicIndexing  = true
>         shaderStorageBufferArrayDynamicIndexing = true
>         shaderStorageImageArrayDynamicIndexing  = true
>         shaderClipDistance                      = true
>         shaderCullDistance                      = true
>         shaderFloat64                           = true
>         shaderInt64                             = true
>         shaderInt16                             = true
>         shaderResourceResidency                 = false
>         shaderResourceMinLod                    = false
>         sparseBinding                           = false
>         sparseResidencyBuffer                   = false
>         sparseResidencyImage2D                  = false
>         sparseResidencyImage3D                  = false
>         sparseResidency2Samples                 = false
>         sparseResidency4Samples                 = false
>         sparseResidency8Samples                 = false
>         sparseResidency16Samples                = false
>         sparseResidencyAliased                  = false
>         variableMultisampleRate                 = false
>         inheritedQueries                        = false
>
> VkPhysicalDevice4444FormatsFeaturesEXT:
> ---------------------------------------
>         formatA4R4G4B4 = true
>         formatA4B4G4R4 = true
>
> VkPhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT:
> --------------------------------------------------------------
>         attachmentFeedbackLoopDynamicState = true
>
> VkPhysicalDeviceAttachmentFeedbackLoopLayoutFeaturesEXT:
> --------------------------------------------------------
>         attachmentFeedbackLoopLayout = true
>
> VkPhysicalDeviceBorderColorSwizzleFeaturesEXT:
> ----------------------------------------------
>         borderColorSwizzle          = true
>         borderColorSwizzleFromImage = true
>
> VkPhysicalDeviceColorWriteEnableFeaturesEXT:
> --------------------------------------------
>         colorWriteEnable = true
>
> VkPhysicalDeviceConditionalRenderingFeaturesEXT:
> ------------------------------------------------
>         conditionalRendering          = true
>         inheritedConditionalRendering = false
>
> VkPhysicalDeviceCustomBorderColorFeaturesEXT:
> ---------------------------------------------
>         customBorderColors             = true
>         customBorderColorWithoutFormat = true
>
> VkPhysicalDeviceDepthClipControlFeaturesEXT:
> --------------------------------------------
>         depthClipControl = true
>
> VkPhysicalDeviceDepthClipEnableFeaturesEXT:
> -------------------------------------------
>         depthClipEnable = true
>
> VkPhysicalDeviceDescriptorBufferFeaturesEXT:
> --------------------------------------------
>         descriptorBuffer                   = true
>         descriptorBufferCaptureReplay      = false
>         descriptorBufferImageLayoutIgnored = true
>         descriptorBufferPushDescriptors    = true
>
> VkPhysicalDeviceDynamicRenderingUnusedAttachmentsFeaturesEXT:
> -------------------------------------------------------------
>         dynamicRenderingUnusedAttachments = true
>
> VkPhysicalDeviceExtendedDynamicState2FeaturesEXT:
> -------------------------------------------------
>         extendedDynamicState2                   = true
>         extendedDynamicState2LogicOp            = true
>         extendedDynamicState2PatchControlPoints = true
>
> VkPhysicalDeviceExtendedDynamicState3FeaturesEXT:
> -------------------------------------------------
>         extendedDynamicState3TessellationDomainOrigin         = true
>         extendedDynamicState3DepthClampEnable                 = true
>         extendedDynamicState3PolygonMode                      = true
>         extendedDynamicState3RasterizationSamples             = true
>         extendedDynamicState3SampleMask                       = true
>         extendedDynamicState3AlphaToCoverageEnable            = true
>         extendedDynamicState3AlphaToOneEnable                 = true
>         extendedDynamicState3LogicOpEnable                    = true
>         extendedDynamicState3ColorBlendEnable                 = true
>         extendedDynamicState3ColorBlendEquation               = true
>         extendedDynamicState3ColorWriteMask                   = true
>         extendedDynamicState3RasterizationStream              = false
>         extendedDynamicState3ConservativeRasterizationMode    = false
>         extendedDynamicState3ExtraPrimitiveOverestimationSize = false
>         extendedDynamicState3DepthClipEnable                  = true
>         extendedDynamicState3SampleLocationsEnable            = false
>         extendedDynamicState3ColorBlendAdvanced               = false
>         extendedDynamicState3ProvokingVertexMode              = true
>         extendedDynamicState3LineRasterizationMode            = true
>         extendedDynamicState3LineStippleEnable                = true
>         extendedDynamicState3DepthClipNegativeOneToOne        = true
>         extendedDynamicState3ViewportWScalingEnable           = false
>         extendedDynamicState3ViewportSwizzle                  = false
>         extendedDynamicState3CoverageToColorEnable            = false
>         extendedDynamicState3CoverageToColorLocation          = false
>         extendedDynamicState3CoverageModulationMode           = false
>         extendedDynamicState3CoverageModulationTableEnable    = false
>         extendedDynamicState3CoverageModulationTable          = false
>         extendedDynamicState3CoverageReductionMode            = false
>         extendedDynamicState3RepresentativeFragmentTestEnable = false
>         extendedDynamicState3ShadingRateImageEnable           = false
>
> VkPhysicalDeviceExtendedDynamicStateFeaturesEXT:
> ------------------------------------------------
>         extendedDynamicState = true
>
> VkPhysicalDeviceGraphicsPipelineLibraryFeaturesEXT:
> ---------------------------------------------------
>         graphicsPipelineLibrary = true
>
> VkPhysicalDeviceHostImageCopyFeaturesEXT:
> -----------------------------------------
>         hostImageCopy = true
>
> VkPhysicalDeviceImage2DViewOf3DFeaturesEXT:
> -------------------------------------------
>         image2DViewOf3D   = true
>         sampler2DViewOf3D = true
>
> VkPhysicalDeviceImageSlicedViewOf3DFeaturesEXT:
> -----------------------------------------------
>         imageSlicedViewOf3D = true
>
> VkPhysicalDeviceIndexTypeUint8FeaturesKHR:
> ------------------------------------------
>         indexTypeUint8 = true
>
> VkPhysicalDeviceLineRasterizationFeaturesKHR:
> ---------------------------------------------
>         rectangularLines         = true
>         bresenhamLines           = true
>         smoothLines              = true
>         stippledRectangularLines = true
>         stippledBresenhamLines   = true
>         stippledSmoothLines      = true
>
> VkPhysicalDeviceMaintenance5FeaturesKHR:
> ----------------------------------------
>         maintenance5 = true
>
> VkPhysicalDeviceMaintenance6FeaturesKHR:
> ----------------------------------------
>         maintenance6 = true
>
> VkPhysicalDeviceMemoryPriorityFeaturesEXT:
> ------------------------------------------
>         memoryPriority = true
>
> VkPhysicalDeviceMeshShaderFeaturesEXT:
> --------------------------------------
>         taskShader                             = true
>         meshShader                             = true
>         multiviewMeshShader                    = false
>         primitiveFragmentShadingRateMeshShader = false
>         meshShaderQueries                      = true
>
> VkPhysicalDeviceMultiDrawFeaturesEXT:
> -------------------------------------
>         multiDraw = true
>
> VkPhysicalDeviceMultisampledRenderToSingleSampledFeaturesEXT:
> -------------------------------------------------------------
>         multisampledRenderToSingleSampled = true
>
> VkPhysicalDeviceMutableDescriptorTypeFeaturesEXT:
> -------------------------------------------------
>         mutableDescriptorType = true
>
> VkPhysicalDeviceNestedCommandBufferFeaturesEXT:
> -----------------------------------------------
>         nestedCommandBuffer                = true
>         nestedCommandBufferRendering       = true
>         nestedCommandBufferSimultaneousUse = true
>
> VkPhysicalDeviceNonSeamlessCubeMapFeaturesEXT:
> ----------------------------------------------
>         nonSeamlessCubeMap = true
>
> VkPhysicalDevicePageableDeviceLocalMemoryFeaturesEXT:
> -----------------------------------------------------
>         pageableDeviceLocalMemory = true
>
> VkPhysicalDevicePrimitiveTopologyListRestartFeaturesEXT:
> --------------------------------------------------------
>         primitiveTopologyListRestart      = true
>         primitiveTopologyPatchListRestart = true
>
> VkPhysicalDevicePrimitivesGeneratedQueryFeaturesEXT:
> ----------------------------------------------------
>         primitivesGeneratedQuery                      = true
>         primitivesGeneratedQueryWithRasterizerDiscard = true
>         primitivesGeneratedQueryWithNonZeroStreams    = true
>
> VkPhysicalDeviceProvokingVertexFeaturesEXT:
> -------------------------------------------
>         provokingVertexLast                       = true
>         transformFeedbackPreservesProvokingVertex = true
>
> VkPhysicalDeviceRasterizationOrderAttachmentAccessFeaturesEXT:
> --------------------------------------------------------------
>         rasterizationOrderColorAttachmentAccess   = true
>         rasterizationOrderDepthAttachmentAccess   = true
>         rasterizationOrderStencilAttachmentAccess = true
>
> VkPhysicalDeviceRobustness2FeaturesEXT:
> ---------------------------------------
>         robustBufferAccess2 = true
>         robustImageAccess2  = true
>         nullDescriptor      = true
>
> VkPhysicalDeviceShaderAtomicFloat2FeaturesEXT:
> ----------------------------------------------
>         shaderBufferFloat16Atomics      = false
>         shaderBufferFloat16AtomicAdd    = false
>         shaderBufferFloat16AtomicMinMax = false
>         shaderBufferFloat32AtomicMinMax = true
>         shaderBufferFloat64AtomicMinMax = false
>         shaderSharedFloat16Atomics      = false
>         shaderSharedFloat16AtomicAdd    = false
>         shaderSharedFloat16AtomicMinMax = false
>         shaderSharedFloat32AtomicMinMax = true
>         shaderSharedFloat64AtomicMinMax = false
>         shaderImageFloat32AtomicMinMax  = true
>         sparseImageFloat32AtomicMinMax  = false
>
> VkPhysicalDeviceShaderAtomicFloatFeaturesEXT:
> ---------------------------------------------
>         shaderBufferFloat32Atomics   = true
>         shaderBufferFloat32AtomicAdd = true
>         shaderBufferFloat64Atomics   = false
>         shaderBufferFloat64AtomicAdd = false
>         shaderSharedFloat32Atomics   = true
>         shaderSharedFloat32AtomicAdd = true
>         shaderSharedFloat64Atomics   = false
>         shaderSharedFloat64AtomicAdd = false
>         shaderImageFloat32Atomics    = true
>         shaderImageFloat32AtomicAdd  = true
>         sparseImageFloat32Atomics    = false
>         sparseImageFloat32AtomicAdd  = false
>
> VkPhysicalDeviceShaderClockFeaturesKHR:
> ---------------------------------------
>         shaderSubgroupClock = true
>         shaderDeviceClock   = true
>
> VkPhysicalDeviceShaderObjectFeaturesEXT:
> ----------------------------------------
>         shaderObject = true
>
> VkPhysicalDeviceTexelBufferAlignmentFeaturesEXT:
> ------------------------------------------------
>         texelBufferAlignment = true
>
> VkPhysicalDeviceTransformFeedbackFeaturesEXT:
> ---------------------------------------------
>         transformFeedback = true
>         geometryStreams   = true
>
> VkPhysicalDeviceVertexAttributeDivisorFeaturesKHR:
> --------------------------------------------------
>         vertexAttributeInstanceRateDivisor     = true
>         vertexAttributeInstanceRateZeroDivisor = true
>
> VkPhysicalDeviceVertexInputDynamicStateFeaturesEXT:
> ---------------------------------------------------
>         vertexInputDynamicState = true
>
> VkPhysicalDeviceVulkan11Features:
> ---------------------------------
>         storageBuffer16BitAccess           = true
>         uniformAndStorageBuffer16BitAccess = true
>         storagePushConstant16              = true
>         storageInputOutput16               = false
>         multiview                          = true
>         multiviewGeometryShader            = true
>         multiviewTessellationShader        = true
>         variablePointersStorageBuffer      = true
>         variablePointers                   = true
>         protectedMemory                    = false
>         samplerYcbcrConversion             = true
>         shaderDrawParameters               = true
>
> VkPhysicalDeviceVulkan12Features:
> ---------------------------------
>         samplerMirrorClampToEdge                           = true
>         drawIndirectCount                                  = true
>         storageBuffer8BitAccess                            = true
>         uniformAndStorageBuffer8BitAccess                  = true
>         storagePushConstant8                               = true
>         shaderBufferInt64Atomics                           = true
>         shaderSharedInt64Atomics                           = true
>         shaderFloat16                                      = true
>         shaderInt8                                         = true
>         descriptorIndexing                                 = true
>         shaderInputAttachmentArrayDynamicIndexing          = true
>         shaderUniformTexelBufferArrayDynamicIndexing       = true
>         shaderStorageTexelBufferArrayDynamicIndexing       = true
>         shaderUniformBufferArrayNonUniformIndexing         = true
>         shaderSampledImageArrayNonUniformIndexing          = true
>         shaderStorageBufferArrayNonUniformIndexing         = true
>         shaderStorageImageArrayNonUniformIndexing          = true
>         shaderInputAttachmentArrayNonUniformIndexing       = true
>         shaderUniformTexelBufferArrayNonUniformIndexing    = true
>         shaderStorageTexelBufferArrayNonUniformIndexing    = true
>         descriptorBindingUniformBufferUpdateAfterBind      = true
>         descriptorBindingSampledImageUpdateAfterBind       = true
>         descriptorBindingStorageImageUpdateAfterBind       = true
>         descriptorBindingStorageBufferUpdateAfterBind      = true
>         descriptorBindingUniformTexelBufferUpdateAfterBind = true
>         descriptorBindingStorageTexelBufferUpdateAfterBind = true
>         descriptorBindingUpdateUnusedWhilePending          = true
>         descriptorBindingPartiallyBound                    = true
>         descriptorBindingVariableDescriptorCount           = true
>         runtimeDescriptorArray                             = true
>         samplerFilterMinmax                                = true
>         scalarBlockLayout                                  = true
>         imagelessFramebuffer                               = true
>         uniformBufferStandardLayout                        = true
>         shaderSubgroupExtendedTypes                        = true
>         separateDepthStencilLayouts                        = true
>         hostQueryReset                                     = true
>         timelineSemaphore                                  = true
>         bufferDeviceAddress                                = true
>         bufferDeviceAddressCaptureReplay                   = false
>         bufferDeviceAddressMultiDevice                     = false
>         vulkanMemoryModel                                  = true
>         vulkanMemoryModelDeviceScope                       = true
>         vulkanMemoryModelAvailabilityVisibilityChains      = true
>         shaderOutputViewportIndex                          = true
>         shaderOutputLayer                                  = true
>         subgroupBroadcastDynamicId                         = true
>
> VkPhysicalDeviceVulkan13Features:
> ---------------------------------
>         robustImageAccess                                  = true
>         inlineUniformBlock                                 = true
>         descriptorBindingInlineUniformBlockUpdateAfterBind = true
>         pipelineCreationCacheControl                       = true
>         privateData                                        = true
>         shaderDemoteToHelperInvocation                     = true
>         shaderTerminateInvocation                          = true
>         subgroupSizeControl                                = true
>         computeFullSubgroups                               = true
>         synchronization2                                   = true
>         textureCompressionASTC_HDR                         = false
>         shaderZeroInitializeWorkgroupMemory                = true
>         dynamicRendering                                   = true
>         shaderIntegerDotProduct                            = true
>         maintenance4                                       = true
>
> VkPhysicalDeviceYcbcr2Plane444FormatsFeaturesEXT:
> -------------------------------------------------
>         ycbcr2plane444Formats = true
>
> VkPhysicalDeviceYcbcrImageArraysFeaturesEXT:
> --------------------------------------------
>         ycbcrImageArrays = true
>
>
> --
> 2.45.1.288.g0e0cd299f1-goog
>
Adam Ford June 2, 2024, 7:53 p.m. UTC | #2
On Fri, May 31, 2024 at 6:23 AM Frank Binns <Frank.Binns@imgtec.com> wrote:
>
> Hi ChenYu,
>
> On Fri, 2024-05-31 at 12:00 +0800, Chen-Yu Tsai wrote:
> > On Thu, May 30, 2024 at 4:35 PM Chen-Yu Tsai <wenst@chromium.org> wrote:
> > > Hi everyone,
> > >
> > > This series enables the PowerVR GPU found in the MT8173 SoC, found in
> > > some Chromebooks.
>
> Thank you for the patches, I'm really happy to see these!
>
> > >
> > > This version is different from the initial powervr driver submission [1]
> > > in that it splits out the GPU glue layer support out of the powervr
> > > driver and into a separate clock and power domain driver. The glue code
> > > is otherwise the same, and also the same as found in the ChromeOS
> > > kernels, with some extra comments and macro names added where possible.
> > >
> > > Patch 1 adds a binding for the glue layer, called mfgtop. The glue layer
> > > contains clock and power controls for the GPU.
> > >
> > > Patch 2 adds a driver for the glue layer.
> > >
> > > Patch 3 adds an entry for the MT8173 GPU and 6XT series to the PowerVR
> > > binding.
> > >
> > > Patch 4 adds an entry for the PowerVR 6XT series GPU to the driver.
> > >
> > > Patch 5 corrects the clock for the GPU (called MFG) power domain.
> > >
> > > Patch 6 adds device nodes for the GPU and glue layer to the MT8173 dtsi
> > > file.
> > >
> > > Patch 2 and 6 depend on patch 1 to build. I suppose some common
> > > immutable tree would be needed from the MediaTek maintainers.
> > >
> > > The kernel driver successfully probes the hardware and loads the
> > > "rogue_4.40.2.51_v1.fw" firmware provided by Imagination Technologies [2].
> > > Userspace was tested with Mesa 24.0.8 from Debian Trixie rebuilt with
> > > the powervr vulkan driver enabled. `vulkaninfo` gives some information
> > > about the GPU (attached at the end), but running the `triangle` example
> > > from the Sascha Willems demos [3] with -DUSE_D2D_WSI=ON as recommended [4]
> > > failed with:
> > >
> > >     Can't find a display and a display mode!
> > >
> > > Same program worked correctly on a BeaglePlay and displayed a color
> > > gradient triangle. Not sure what went wrong here.
> >
> > Frank mentioned over IRC that giving `triangle` a screen resolution would
> > make it work, and it did! Thanks Frank!
>
> No problem :)
>
> I've not dug into the display mode issue, but I'm wondering if it happens
> because there isn't a mode flagged as the preferred mode.
>
> >
> > OTOH I'm getting some extra warnings not seen on the BeaglePlay:
> >
> >     MESA: error: No hard coded passthrough rta vertex shader.
> > Returning empty shader.
> >     MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:71:
> > FINISHME: Missing reset support for brn51764
> >     MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:74:
> > FINISHME: Missing reset support for brn58839
> >     MESA: warning: ../src/imagination/vulkan/pvr_border.c:104:
> > FINISHME: Devices without tpu_border_colour_enhanced require entries
> > for compressed formats to be stored in the table pre-compressed.
> >
> > I also get a constant stream of kernel error messages, all the same:
> >
> >     powervr 13000000.gpu: [drm] Received unknown FWCCB command 2abc0069
> >
> > And the first few frames seem to flicker. (Though that could also be the
> > display driver that's at fault.)
>
> The unknown commands are related to the GPU locking up, presumably because bad
> jobs are being submitted, likely due to missing bits of support for the
> Series6XT GPUs in the Vulkan driver / compiler. The unknown commands are the
> firmware notifying the host that the GPU has been reset. The GPU resets would
> explain the flickering you're seeing.

For what it's worth the GX6250 on my Renesas board appears to behave
the same way. I Used a different branch, but applied the patches to
support the BVNC.  I then tweaked it for my Renesas hardware.   I ran
vkd3d-gears, and I get several frames before it glitched out and
reappeared.

adam

>
> Thanks
> Frank
>
> >
> >
> > For reference, on the BeaglePlay I see:
> >
> >     MESA: error: No hard coded idfwdf program. Returning empty program.
> >     MESA: error: No hard coded passthrough vertex shader. Returning
> > empty shader.
> >     MESA: warning:
> > ../src/imagination/vulkan/pvr_descriptor_set.c:1073: FINISHME: Entry
> > tracker for allocations?
> >
> >
> > Regards
> > ChenYu
> >
> >
> > > Anyway, please have a look and test.
> > >
> > >
> > > Thanks
> > > ChenYu
> > >
> > > [1] https://lore.kernel.org/dri-devel/20220815165156.118212-2-sarah.walker@imgtec.com/
> > > [2] https://gitlab.freedesktop.org/imagination/linux-firmware/-/tree/powervr
> > > [3] https://github.com/SaschaWillems/Vulkan
> > > [4] https://lore.kernel.org/dri-devel/f2b2671e-5acc-4dec-9c2e-3c9cd2e1f19e@imgtec.com/
> > >
> > > Chen-Yu Tsai (6):
> > >   dt-bindings: clock: mediatek: Add mt8173 mfgtop
> > >   clk: mediatek: Add mt8173-mfgtop driver
> > >   dt-bindings: gpu: powervr-rogue: Add MediaTek MT8173 GPU
> > >   drm/imagination: Add compatible string entry for Series6XT
> > >   arm64: dts: mediatek: mt8173: Fix MFG_ASYNC power domain clock
> > >   arm64: dts: mediatek: mt8173: Add GPU device nodes
> > >
> > >  .../clock/mediatek,mt8173-mfgtop.yaml         |  71 ++++++
> > >  .../bindings/gpu/img,powervr-rogue.yaml       |  24 +-
> > >  arch/arm64/boot/dts/mediatek/mt8173.dtsi      |  26 +-
> > >  drivers/clk/mediatek/Kconfig                  |   9 +
> > >  drivers/clk/mediatek/Makefile                 |   1 +
> > >  drivers/clk/mediatek/clk-mt8173-mfgtop.c      | 240 ++++++++++++++++++
> > >  drivers/gpu/drm/imagination/pvr_drv.c         |   1 +
> > >  include/dt-bindings/clock/mt8173-clk.h        |   7 +
> > >  8 files changed, 374 insertions(+), 5 deletions(-)
> > >  create mode 100644 Documentation/devicetree/bindings/clock/mediatek,mt8173-mfgtop.yaml
> > >  create mode 100644 drivers/clk/mediatek/clk-mt8173-mfgtop.c
> > >
> > >
> > > base-commit: 1613e604df0cd359cf2a7fbd9be7a0bcfacfabd0
> > >
> > > Vulkan info output:
> > >
> > > WARNING: [Loader Message] Code 0 : terminator_CreateInstance: Received return code -3 from call to vkCreateInstance in ICD /usr/lib/aarch64-linux-gnu/libvulkan_virtio.so. Skipping this driver.
> > > 'DISPLAY' environment variable not set... skipping surface info
> > > ERROR: [../src/panfrost/vulkan/panvk_device.c:386] Code 0 : WARNING: panvk is not a conformant vulkan implementation, pass PAN_I_WANT_A_BROKEN_VULKAN_DRIVER=1 if you know what you're doing. (VK_ERROR_INCOMPATIBLE_DRIVER)
> > > MESA: error: No hard coded idfwdf program. Returning empty program.
> > > MESA: error: No hard coded passthrough rta vertex shader. Returning empty shader.
> > > MESA: error: No hard coded passthrough vertex shader. Returning empty shader.
> > > MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:71: FINISHME: Missing reset support for brn51764
> > > MESA: warning: ../src/imagination/vulkan/pvr_job_context.c:74: FINISHME: Missing reset support for brn58839
> > > MESA: warning: ../src/imagination/vulkan/pvr_border.c:104: FINISHME: Devices without tpu_border_colour_enhanced require entries for compressed formats to be stored in the table pre-compressed.
> > > ==========
> > > VULKANINFO
> > > ==========
> > >
> > > Vulkan Instance Version: 1.3.280
> > >
> > >
> > > Instance Extensions: count = 23
> > > ===============================
> > >         VK_EXT_acquire_drm_display             : extension revision 1
> > >         VK_EXT_acquire_xlib_display            : extension revision 1
> > >         VK_EXT_debug_report                    : extension revision 10
> > >         VK_EXT_debug_utils                     : extension revision 2
> > >         VK_EXT_direct_mode_display             : extension revision 1
> > >         VK_EXT_display_surface_counter         : extension revision 1
> > >         VK_EXT_surface_maintenance1            : extension revision 1
> > >         VK_EXT_swapchain_colorspace            : extension revision 4
> > >         VK_KHR_device_group_creation           : extension revision 1
> > >         VK_KHR_display                         : extension revision 23
> > >         VK_KHR_external_fence_capabilities     : extension revision 1
> > >         VK_KHR_external_memory_capabilities    : extension revision 1
> > >         VK_KHR_external_semaphore_capabilities : extension revision 1
> > >         VK_KHR_get_display_properties2         : extension revision 1
> > >         VK_KHR_get_physical_device_properties2 : extension revision 2
> > >         VK_KHR_get_surface_capabilities2       : extension revision 1
> > >         VK_KHR_portability_enumeration         : extension revision 1
> > >         VK_KHR_surface                         : extension revision 25
> > >         VK_KHR_surface_protected_capabilities  : extension revision 1
> > >         VK_KHR_wayland_surface                 : extension revision 6
> > >         VK_KHR_xcb_surface                     : extension revision 6
> > >         VK_KHR_xlib_surface                    : extension revision 6
> > >         VK_LUNARG_direct_driver_loading        : extension revision 1
> > >
> > > Layers: count = 2
> > > =================
> > > VK_LAYER_MESA_device_select (Linux device selection layer) Vulkan version 1.3.211, layer version 1:
> > >         Layer Extensions: count = 0
> > >         Devices: count = 2
> > >                 GPU id = 0 (Imagination PowerVR Rogue GX6250)
> > >                 Layer-Device Extensions: count = 0
> > >
> > >                 GPU id = 1 (llvmpipe (LLVM 17.0.6, 128 bits))
> > >                 Layer-Device Extensions: count = 0
> > >
> > > VK_LAYER_MESA_overlay (Mesa Overlay layer) Vulkan version 1.3.211, layer version 1:
> > >         Layer Extensions: count = 0
> > >         Devices: count = 2
> > >                 GPU id = 0 (Imagination PowerVR Rogue GX6250)
> > >                 Layer-Device Extensions: count = 0
> > >
> > >                 GPU id = 1 (llvmpipe (LLVM 17.0.6, 128 bits))
> > >                 Layer-Device Extensions: count = 0
> > >
> > > Device Properties and Extensions:
> > > =================================
> > > GPU0:
> > > VkPhysicalDeviceProperties:
> > > ---------------------------
> > >         apiVersion        = 1.0.274 (4194578)
> > >         driverVersion     = 24.0.8 (100663304)
> > >         vendorID          = 0x1010
> > >         deviceID          = 0x6250
> > >         deviceType        = PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU
> > >         deviceName        = Imagination PowerVR Rogue GX6250
> > >         pipelineCacheUUID = 6ddf30eb-d118-41f1-455f-580ae751c27b
> > >
> > > VkPhysicalDeviceLimits:
> > > -----------------------
> > >         maxImageDimension1D                             = 8192
> > >         maxImageDimension2D                             = 8192
> > >         maxImageDimension3D                             = 2048
> > >         maxImageDimensionCube                           = 8192
> > >         maxImageArrayLayers                             = 2048
> > >         maxTexelBufferElements                          = 65536
> > >         maxUniformBufferRange                           = 134217728
> > >         maxStorageBufferRange                           = 134217728
> > >         maxPushConstantsSize                            = 256
> > >         maxMemoryAllocationCount                        = 4294967295
> > >         maxSamplerAllocationCount                       = 4294967295
> > >         bufferImageGranularity                          = 0x00000001
> > >         sparseAddressSpaceSize                          = 0x4000000000
> > >         maxBoundDescriptorSets                          = 4
> > >         maxPerStageDescriptorSamplers                   = 32
> > >         maxPerStageDescriptorUniformBuffers             = 64
> > >         maxPerStageDescriptorStorageBuffers             = 36
> > >         maxPerStageDescriptorSampledImages              = 48
> > >         maxPerStageDescriptorStorageImages              = 8
> > >         maxPerStageDescriptorInputAttachments           = 8
> > >         maxPerStageResources                            = 224
> > >         maxDescriptorSetSamplers                        = 256
> > >         maxDescriptorSetUniformBuffers                  = 256
> > >         maxDescriptorSetUniformBuffersDynamic           = 8
> > >         maxDescriptorSetStorageBuffers                  = 256
> > >         maxDescriptorSetStorageBuffersDynamic           = 8
> > >         maxDescriptorSetSampledImages                   = 256
> > >         maxDescriptorSetStorageImages                   = 256
> > >         maxDescriptorSetInputAttachments                = 256
> > >         maxVertexInputAttributes                        = 16
> > >         maxVertexInputBindings                          = 16
> > >         maxVertexInputAttributeOffset                   = 65535
> > >         maxVertexInputBindingStride                     = 2147483648
> > >         maxVertexOutputComponents                       = 128
> > >         maxTessellationGenerationLevel                  = 0
> > >         maxTessellationPatchSize                        = 0
> > >         maxTessellationControlPerVertexInputComponents  = 0
> > >         maxTessellationControlPerVertexOutputComponents = 0
> > >         maxTessellationControlPerPatchOutputComponents  = 0
> > >         maxTessellationControlTotalOutputComponents     = 0
> > >         maxTessellationEvaluationInputComponents        = 0
> > >         maxTessellationEvaluationOutputComponents       = 0
> > >         maxGeometryShaderInvocations                    = 0
> > >         maxGeometryInputComponents                      = 0
> > >         maxGeometryOutputComponents                     = 0
> > >         maxGeometryOutputVertices                       = 0
> > >         maxGeometryTotalOutputComponents                = 0
> > >         maxFragmentInputComponents                      = 128
> > >         maxFragmentOutputAttachments                    = 8
> > >         maxFragmentDualSrcAttachments                   = 0
> > >         maxFragmentCombinedOutputResources              = 52
> > >         maxComputeSharedMemorySize                      = 16384
> > >         maxComputeWorkGroupCount: count = 3
> > >                 65536
> > >                 65536
> > >                 65536
> > >         maxComputeWorkGroupInvocations                  = 512
> > >         maxComputeWorkGroupSize: count = 3
> > >                 512
> > >                 512
> > >                 64
> > >         subPixelPrecisionBits                           = 8
> > >         subTexelPrecisionBits                           = 8
> > >         mipmapPrecisionBits                             = 8
> > >         maxDrawIndexedIndexValue                        = 4294967295
> > >         maxDrawIndirectCount                            = 2147483648
> > >         maxSamplerLodBias                               = 16
> > >         maxSamplerAnisotropy                            = 1
> > >         maxViewports                                    = 1
> > >         maxViewportDimensions: count = 2
> > >                 8192
> > >                 8192
> > >         viewportBoundsRange: count = 2
> > >                 -16384
> > >                 16384
> > >         viewportSubPixelBits                            = 0
> > >         minMemoryMapAlignment                           = 64
> > >         minTexelBufferOffsetAlignment                   = 0x00000010
> > >         minUniformBufferOffsetAlignment                 = 0x00000004
> > >         minStorageBufferOffsetAlignment                 = 0x00000004
> > >         minTexelOffset                                  = -8
> > >         maxTexelOffset                                  = 7
> > >         minTexelGatherOffset                            = -8
> > >         maxTexelGatherOffset                            = 7
> > >         minInterpolationOffset                          = -0.5
> > >         maxInterpolationOffset                          = 0.5
> > >         subPixelInterpolationOffsetBits                 = 4
> > >         maxFramebufferWidth                             = 8192
> > >         maxFramebufferHeight                            = 8192
> > >         maxFramebufferLayers                            = 2048
> > >         framebufferColorSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         framebufferDepthSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         framebufferStencilSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         framebufferNoAttachmentsSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         maxColorAttachments                             = 8
> > >         sampledImageColorSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         sampledImageIntegerSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         sampledImageDepthSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         sampledImageStencilSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         storageImageSampleCounts: count = 4
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_2_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >                 SAMPLE_COUNT_8_BIT
> > >         maxSampleMaskWords                              = 1
> > >         timestampComputeAndGraphics                     = false
> > >         timestampPeriod                                 = 0
> > >         maxClipDistances                                = 8
> > >         maxCullDistances                                = 8
> > >         maxCombinedClipAndCullDistances                 = 8
> > >         discreteQueuePriorities                         = 2
> > >         pointSizeRange: count = 2
> > >                 1
> > >                 511
> > >         lineWidthRange: count = 2
> > >                 0.0625
> > >                 16
> > >         pointSizeGranularity                            = 0.0625
> > >         lineWidthGranularity                            = 0.0625
> > >         strictLines                                     = false
> > >         standardSampleLocations                         = true
> > >         optimalBufferCopyOffsetAlignment                = 0x00000004
> > >         optimalBufferCopyRowPitchAlignment              = 0x00000004
> > >         nonCoherentAtomSize                             = 0x00000001
> > >
> > > VkPhysicalDeviceSparseProperties:
> > > ---------------------------------
> > >         residencyStandard2DBlockShape            = false
> > >         residencyStandard2DMultisampleBlockShape = false
> > >         residencyStandard3DBlockShape            = false
> > >         residencyAlignedMipSize                  = false
> > >         residencyNonResidentStrict               = false
> > >
> > > VkPhysicalDeviceTexelBufferAlignmentPropertiesEXT:
> > > --------------------------------------------------
> > >         storageTexelBufferOffsetAlignmentBytes       = 0x00000010
> > >         storageTexelBufferOffsetSingleTexelAlignment = true
> > >         uniformTexelBufferOffsetAlignmentBytes       = 0x00000010
> > >         uniformTexelBufferOffsetSingleTexelAlignment = false
> > >
> > > VkPhysicalDeviceTimelineSemaphorePropertiesKHR:
> > > -----------------------------------------------
> > >         maxTimelineSemaphoreValueDifference = 18446744073709551615
> > >
> > > Device Extensions: count = 20
> > >         VK_EXT_external_memory_dma_buf        : extension revision 1
> > >         VK_EXT_host_query_reset               : extension revision 1
> > >         VK_EXT_private_data                   : extension revision 1
> > >         VK_EXT_scalar_block_layout            : extension revision 1
> > >         VK_EXT_texel_buffer_alignment         : extension revision 1
> > >         VK_EXT_tooling_info                   : extension revision 1
> > >         VK_KHR_bind_memory2                   : extension revision 1
> > >         VK_KHR_copy_commands2                 : extension revision 1
> > >         VK_KHR_external_fence                 : extension revision 1
> > >         VK_KHR_external_fence_fd              : extension revision 1
> > >         VK_KHR_external_memory                : extension revision 1
> > >         VK_KHR_external_memory_fd             : extension revision 1
> > >         VK_KHR_external_semaphore             : extension revision 1
> > >         VK_KHR_external_semaphore_fd          : extension revision 1
> > >         VK_KHR_format_feature_flags2          : extension revision 2
> > >         VK_KHR_get_memory_requirements2       : extension revision 1
> > >         VK_KHR_image_format_list              : extension revision 1
> > >         VK_KHR_swapchain                      : extension revision 70
> > >         VK_KHR_timeline_semaphore             : extension revision 2
> > >         VK_KHR_uniform_buffer_standard_layout : extension revision 1
> > >
> > > VkQueueFamilyProperties:
> > > ========================
> > >         queueProperties[0]:
> > >         -------------------
> > >                 minImageTransferGranularity = (1,1,1)
> > >                 queueCount                  = 2
> > >                 queueFlags                  = QUEUE_GRAPHICS_BIT | QUEUE_COMPUTE_BIT | QUEUE_TRANSFER_BIT
> > >                 timestampValidBits          = 0
> > >                 present support             = false
> > >
> > > VkPhysicalDeviceMemoryProperties:
> > > =================================
> > > memoryHeaps: count = 1
> > >         memoryHeaps[0]:
> > >                 size   = 1752969216 (0x687c3000) (1.63 GiB)
> > >                 flags: count = 1
> > >                         MEMORY_HEAP_DEVICE_LOCAL_BIT
> > > memoryTypes: count = 1
> > >         memoryTypes[0]:
> > >                 heapIndex     = 0
> > >                 propertyFlags = 0x0007: count = 3
> > >                         MEMORY_PROPERTY_DEVICE_LOCAL_BIT
> > >                         MEMORY_PROPERTY_HOST_VISIBLE_BIT
> > >                         MEMORY_PROPERTY_HOST_COHERENT_BIT
> > >                 usable for:
> > >                         IMAGE_TILING_OPTIMAL:
> > >                                 color images
> > >                                 FORMAT_D16_UNORM
> > >                                 FORMAT_D32_SFLOAT
> > >                                 FORMAT_S8_UINT
> > >                                 FORMAT_D24_UNORM_S8_UINT
> > >                                 (non-sparse)
> > >                         IMAGE_TILING_LINEAR:
> > >                                 color images
> > >                                 (non-sparse)
> > >
> > > VkPhysicalDeviceFeatures:
> > > =========================
> > >         robustBufferAccess                      = true
> > >         fullDrawIndexUint32                     = true
> > >         imageCubeArray                          = true
> > >         independentBlend                        = false
> > >         geometryShader                          = false
> > >         tessellationShader                      = false
> > >         sampleRateShading                       = true
> > >         dualSrcBlend                            = false
> > >         logicOp                                 = false
> > >         multiDrawIndirect                       = true
> > >         drawIndirectFirstInstance               = true
> > >         depthClamp                              = true
> > >         depthBiasClamp                          = true
> > >         fillModeNonSolid                        = false
> > >         depthBounds                             = false
> > >         wideLines                               = true
> > >         largePoints                             = true
> > >         alphaToOne                              = false
> > >         multiViewport                           = false
> > >         samplerAnisotropy                       = false
> > >         textureCompressionETC2                  = true
> > >         textureCompressionASTC_LDR              = false
> > >         textureCompressionBC                    = false
> > >         occlusionQueryPrecise                   = false
> > >         pipelineStatisticsQuery                 = false
> > >         vertexPipelineStoresAndAtomics          = true
> > >         fragmentStoresAndAtomics                = true
> > >         shaderTessellationAndGeometryPointSize  = false
> > >         shaderImageGatherExtended               = false
> > >         shaderStorageImageExtendedFormats       = true
> > >         shaderStorageImageMultisample           = false
> > >         shaderStorageImageReadWithoutFormat     = true
> > >         shaderStorageImageWriteWithoutFormat    = false
> > >         shaderUniformBufferArrayDynamicIndexing = true
> > >         shaderSampledImageArrayDynamicIndexing  = true
> > >         shaderStorageBufferArrayDynamicIndexing = true
> > >         shaderStorageImageArrayDynamicIndexing  = true
> > >         shaderClipDistance                      = false
> > >         shaderCullDistance                      = false
> > >         shaderFloat64                           = false
> > >         shaderInt64                             = true
> > >         shaderInt16                             = true
> > >         shaderResourceResidency                 = false
> > >         shaderResourceMinLod                    = false
> > >         sparseBinding                           = false
> > >         sparseResidencyBuffer                   = false
> > >         sparseResidencyImage2D                  = false
> > >         sparseResidencyImage3D                  = false
> > >         sparseResidency2Samples                 = false
> > >         sparseResidency4Samples                 = false
> > >         sparseResidency8Samples                 = false
> > >         sparseResidency16Samples                = false
> > >         sparseResidencyAliased                  = false
> > >         variableMultisampleRate                 = false
> > >         inheritedQueries                        = false
> > >
> > > VkPhysicalDeviceHostQueryResetFeaturesEXT:
> > > ------------------------------------------
> > >         hostQueryReset = true
> > >
> > > VkPhysicalDevicePrivateDataFeaturesEXT:
> > > ---------------------------------------
> > >         privateData = true
> > >
> > > VkPhysicalDeviceScalarBlockLayoutFeaturesEXT:
> > > ---------------------------------------------
> > >         scalarBlockLayout = true
> > >
> > > VkPhysicalDeviceTexelBufferAlignmentFeaturesEXT:
> > > ------------------------------------------------
> > >         texelBufferAlignment = true
> > >
> > > VkPhysicalDeviceTimelineSemaphoreFeaturesKHR:
> > > ---------------------------------------------
> > >         timelineSemaphore = true
> > >
> > > VkPhysicalDeviceUniformBufferStandardLayoutFeaturesKHR:
> > > -------------------------------------------------------
> > >         uniformBufferStandardLayout = true
> > >
> > >
> > > GPU1:
> > > VkPhysicalDeviceProperties:
> > > ---------------------------
> > >         apiVersion        = 1.3.274 (4206866)
> > >         driverVersion     = 0.0.1 (1)
> > >         vendorID          = 0x10005
> > >         deviceID          = 0x0000
> > >         deviceType        = PHYSICAL_DEVICE_TYPE_CPU
> > >         deviceName        = llvmpipe (LLVM 17.0.6, 128 bits)
> > >         pipelineCacheUUID = 32342e30-2e38-2d31-2b70-316161616161
> > >
> > > VkPhysicalDeviceLimits:
> > > -----------------------
> > >         maxImageDimension1D                             = 16384
> > >         maxImageDimension2D                             = 16384
> > >         maxImageDimension3D                             = 4096
> > >         maxImageDimensionCube                           = 32768
> > >         maxImageArrayLayers                             = 2048
> > >         maxTexelBufferElements                          = 134217728
> > >         maxUniformBufferRange                           = 65536
> > >         maxStorageBufferRange                           = 134217728
> > >         maxPushConstantsSize                            = 256
> > >         maxMemoryAllocationCount                        = 4294967295
> > >         maxSamplerAllocationCount                       = 32768
> > >         bufferImageGranularity                          = 0x00000040
> > >         sparseAddressSpaceSize                          = 0x00000000
> > >         maxBoundDescriptorSets                          = 8
> > >         maxPerStageDescriptorSamplers                   = 1000000
> > >         maxPerStageDescriptorUniformBuffers             = 1000000
> > >         maxPerStageDescriptorStorageBuffers             = 1000000
> > >         maxPerStageDescriptorSampledImages              = 1000000
> > >         maxPerStageDescriptorStorageImages              = 1000000
> > >         maxPerStageDescriptorInputAttachments           = 1000000
> > >         maxPerStageResources                            = 1000000
> > >         maxDescriptorSetSamplers                        = 1000000
> > >         maxDescriptorSetUniformBuffers                  = 1000000
> > >         maxDescriptorSetUniformBuffersDynamic           = 1000000
> > >         maxDescriptorSetStorageBuffers                  = 1000000
> > >         maxDescriptorSetStorageBuffersDynamic           = 1000000
> > >         maxDescriptorSetSampledImages                   = 1000000
> > >         maxDescriptorSetStorageImages                   = 1000000
> > >         maxDescriptorSetInputAttachments                = 1000000
> > >         maxVertexInputAttributes                        = 32
> > >         maxVertexInputBindings                          = 32
> > >         maxVertexInputAttributeOffset                   = 2047
> > >         maxVertexInputBindingStride                     = 2048
> > >         maxVertexOutputComponents                       = 128
> > >         maxTessellationGenerationLevel                  = 64
> > >         maxTessellationPatchSize                        = 32
> > >         maxTessellationControlPerVertexInputComponents  = 128
> > >         maxTessellationControlPerVertexOutputComponents = 128
> > >         maxTessellationControlPerPatchOutputComponents  = 128
> > >         maxTessellationControlTotalOutputComponents     = 4096
> > >         maxTessellationEvaluationInputComponents        = 128
> > >         maxTessellationEvaluationOutputComponents       = 128
> > >         maxGeometryShaderInvocations                    = 32
> > >         maxGeometryInputComponents                      = 64
> > >         maxGeometryOutputComponents                     = 128
> > >         maxGeometryOutputVertices                       = 1024
> > >         maxGeometryTotalOutputComponents                = 1024
> > >         maxFragmentInputComponents                      = 128
> > >         maxFragmentOutputAttachments                    = 8
> > >         maxFragmentDualSrcAttachments                   = 2
> > >         maxFragmentCombinedOutputResources              = 104
> > >         maxComputeSharedMemorySize                      = 32768
> > >         maxComputeWorkGroupCount: count = 3
> > >                 65535
> > >                 65535
> > >                 65535
> > >         maxComputeWorkGroupInvocations                  = 1024
> > >         maxComputeWorkGroupSize: count = 3
> > >                 1024
> > >                 1024
> > >                 1024
> > >         subPixelPrecisionBits                           = 8
> > >         subTexelPrecisionBits                           = 8
> > >         mipmapPrecisionBits                             = 4
> > >         maxDrawIndexedIndexValue                        = 4294967295
> > >         maxDrawIndirectCount                            = 4294967295
> > >         maxSamplerLodBias                               = 16
> > >         maxSamplerAnisotropy                            = 16
> > >         maxViewports                                    = 16
> > >         maxViewportDimensions: count = 2
> > >                 16384
> > >                 16384
> > >         viewportBoundsRange: count = 2
> > >                 -32768
> > >                 32768
> > >         viewportSubPixelBits                            = 0
> > >         minMemoryMapAlignment                           = 64
> > >         minTexelBufferOffsetAlignment                   = 0x00000010
> > >         minUniformBufferOffsetAlignment                 = 0x00000010
> > >         minStorageBufferOffsetAlignment                 = 0x00000010
> > >         minTexelOffset                                  = -32
> > >         maxTexelOffset                                  = 31
> > >         minTexelGatherOffset                            = -32
> > >         maxTexelGatherOffset                            = 31
> > >         minInterpolationOffset                          = -2
> > >         maxInterpolationOffset                          = 2
> > >         subPixelInterpolationOffsetBits                 = 8
> > >         maxFramebufferWidth                             = 16384
> > >         maxFramebufferHeight                            = 16384
> > >         maxFramebufferLayers                            = 2048
> > >         framebufferColorSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         framebufferDepthSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         framebufferStencilSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         framebufferNoAttachmentsSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         maxColorAttachments                             = 8
> > >         sampledImageColorSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         sampledImageIntegerSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         sampledImageDepthSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         sampledImageStencilSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         storageImageSampleCounts: count = 2
> > >                 SAMPLE_COUNT_1_BIT
> > >                 SAMPLE_COUNT_4_BIT
> > >         maxSampleMaskWords                              = 1
> > >         timestampComputeAndGraphics                     = true
> > >         timestampPeriod                                 = 1
> > >         maxClipDistances                                = 8
> > >         maxCullDistances                                = 8
> > >         maxCombinedClipAndCullDistances                 = 8
> > >         discreteQueuePriorities                         = 2
> > >         pointSizeRange: count = 2
> > >                 0
> > >                 255
> > >         lineWidthRange: count = 2
> > >                 1
> > >                 255
> > >         pointSizeGranularity                            = 0.125
> > >         lineWidthGranularity                            = 0.0078125
> > >         strictLines                                     = true
> > >         standardSampleLocations                         = true
> > >         optimalBufferCopyOffsetAlignment                = 0x00000080
> > >         optimalBufferCopyRowPitchAlignment              = 0x00000080
> > >         nonCoherentAtomSize                             = 0x00000040
> > >
> > > VkPhysicalDeviceSparseProperties:
> > > ---------------------------------
> > >         residencyStandard2DBlockShape            = false
> > >         residencyStandard2DMultisampleBlockShape = false
> > >         residencyStandard3DBlockShape            = false
> > >         residencyAlignedMipSize                  = false
> > >         residencyNonResidentStrict               = false
> > >
> > > VkPhysicalDeviceCustomBorderColorPropertiesEXT:
> > > -----------------------------------------------
> > >         maxCustomBorderColorSamplers = 32768
> > >
> > > VkPhysicalDeviceDescriptorBufferDensityMapPropertiesEXT:
> > > --------------------------------------------------------
> > >         combinedImageSamplerDensityMapDescriptorSize = 0
> > >
> > > VkPhysicalDeviceDescriptorBufferPropertiesEXT:
> > > ----------------------------------------------
> > >         combinedImageSamplerDescriptorSingleArray            = true
> > >         bufferlessPushDescriptors                            = true
> > >         allowSamplerImageViewPostSubmitCreation              = false
> > >         descriptorBufferOffsetAlignment                      = 0x00000004
> > >         maxDescriptorBufferBindings                          = 8
> > >         maxResourceDescriptorBufferBindings                  = 8
> > >         maxSamplerDescriptorBufferBindings                   = 8
> > >         maxEmbeddedImmutableSamplerBindings                  = 8
> > >         maxEmbeddedImmutableSamplers                         = 2032
> > >         bufferCaptureReplayDescriptorDataSize                = 0
> > >         imageCaptureReplayDescriptorDataSize                 = 0
> > >         imageViewCaptureReplayDescriptorDataSize             = 0
> > >         samplerCaptureReplayDescriptorDataSize               = 0
> > >         accelerationStructureCaptureReplayDescriptorDataSize = 0
> > >         samplerDescriptorSize                                = 256
> > >         combinedImageSamplerDescriptorSize                   = 256
> > >         sampledImageDescriptorSize                           = 256
> > >         storageImageDescriptorSize                           = 256
> > >         uniformTexelBufferDescriptorSize                     = 256
> > >         robustUniformTexelBufferDescriptorSize               = 256
> > >         storageTexelBufferDescriptorSize                     = 256
> > >         robustStorageTexelBufferDescriptorSize               = 256
> > >         uniformBufferDescriptorSize                          = 256
> > >         robustUniformBufferDescriptorSize                    = 256
> > >         storageBufferDescriptorSize                          = 256
> > >         robustStorageBufferDescriptorSize                    = 256
> > >         inputAttachmentDescriptorSize                        = 256
> > >         accelerationStructureDescriptorSize                  = 0
> > >         maxSamplerDescriptorBufferRange                      = 0x08000000
> > >         maxResourceDescriptorBufferRange                     = 0x10000000
> > >         samplerDescriptorBufferAddressSpaceSize              = 0x08000000
> > >         resourceDescriptorBufferAddressSpaceSize             = 0x08000000
> > >         descriptorBufferAddressSpaceSize                     = 0x08000000
> > >
> > > VkPhysicalDeviceExtendedDynamicState3PropertiesEXT:
> > > ---------------------------------------------------
> > >         dynamicPrimitiveTopologyUnrestricted = true
> > >
> > > VkPhysicalDeviceExternalMemoryHostPropertiesEXT:
> > > ------------------------------------------------
> > >         minImportedHostPointerAlignment = 0x00001000
> > >
> > > VkPhysicalDeviceGraphicsPipelineLibraryPropertiesEXT:
> > > -----------------------------------------------------
> > >         graphicsPipelineLibraryFastLinking                        = true
> > >         graphicsPipelineLibraryIndependentInterpolationDecoration = true
> > >
> > > VkPhysicalDeviceLineRasterizationPropertiesKHR:
> > > -----------------------------------------------
> > >         lineSubPixelPrecisionBits = 8
> > >
> > > VkPhysicalDeviceMaintenance5PropertiesKHR:
> > > ------------------------------------------
> > >         earlyFragmentMultisampleCoverageAfterSampleCounting = true
> > >         earlyFragmentSampleMaskTestBeforeSampleCounting     = false
> > >         depthStencilSwizzleOneSupport                       = false
> > >         polygonModePointSize                                = true
> > >         nonStrictSinglePixelWideLinesUseParallelogram       = false
> > >         nonStrictWideLinesUseParallelogram                  = false
> > >
> > > VkPhysicalDeviceMaintenance6PropertiesKHR:
> > > ------------------------------------------
> > >         blockTexelViewCompatibleMultipleLayers = true
> > >         maxCombinedImageSamplerDescriptorCount = 3
> > >         fragmentShadingRateClampCombinerInputs = false
> > >
> > > VkPhysicalDeviceMeshShaderPropertiesEXT:
> > > ----------------------------------------
> > >         maxTaskWorkGroupTotalCount            = 4194304
> > >         maxTaskWorkGroupCount: count = 3
> > >                 65536
> > >                 65536
> > >                 65536
> > >         maxTaskWorkGroupInvocations           = 1024
> > >         maxTaskWorkGroupSize: count = 3
> > >                 1024
> > >                 1024
> > >                 1024
> > >         maxTaskPayloadSize                    = 16384
> > >         maxTaskSharedMemorySize               = 32768
> > >         maxTaskPayloadAndSharedMemorySize     = 32768
> > >         maxMeshWorkGroupTotalCount            = 4194304
> > >         maxMeshWorkGroupCount: count = 3
> > >                 65536
> > >                 65536
> > >                 65536
> > >         maxMeshWorkGroupInvocations           = 1024
> > >         maxMeshWorkGroupSize: count = 3
> > >                 1024
> > >                 1024
> > >                 1024
> > >         maxMeshSharedMemorySize               = 28672
> > >         maxMeshPayloadAndSharedMemorySize     = 45056
> > >         maxMeshOutputMemorySize               = 32768
> > >         maxMeshPayloadAndOutputMemorySize     = 49152
> > >         maxMeshOutputComponents               = 128
> > >         maxMeshOutputVertices                 = 256
> > >         maxMeshOutputPrimitives               = 256
> > >         maxMeshOutputLayers                   = 8
> > >         maxMeshMultiviewViewCount             = 0
> > >         meshOutputPerVertexGranularity        = 1
> > >         meshOutputPerPrimitiveGranularity     = 1
> > >         maxPreferredTaskWorkGroupInvocations  = 64
> > >         maxPreferredMeshWorkGroupInvocations  = 128
> > >         prefersLocalInvocationVertexOutput    = true
> > >         prefersLocalInvocationPrimitiveOutput = true
> > >         prefersCompactVertexOutput            = true
> > >         prefersCompactPrimitiveOutput         = false
> > >
> > > VkPhysicalDeviceMultiDrawPropertiesEXT:
> > > ---------------------------------------
> > >         maxMultiDrawCount = 2048
> > >
> > > VkPhysicalDeviceNestedCommandBufferPropertiesEXT:
> > > -------------------------------------------------
> > >         maxCommandBufferNestingLevel = 4294967295
> > >
> > > VkPhysicalDeviceProvokingVertexPropertiesEXT:
> > > ---------------------------------------------
> > >         provokingVertexModePerPipeline                       = true
> > >         transformFeedbackPreservesTriangleFanProvokingVertex = true
> > >
> > > VkPhysicalDevicePushDescriptorPropertiesKHR:
> > > --------------------------------------------
> > >         maxPushDescriptors = 32
> > >
> > > VkPhysicalDeviceRobustness2PropertiesEXT:
> > > -----------------------------------------
> > >         robustStorageBufferAccessSizeAlignment = 0x00000001
> > >         robustUniformBufferAccessSizeAlignment = 0x00000001
> > >
> > > VkPhysicalDeviceShaderObjectPropertiesEXT:
> > > ------------------------------------------
> > >         shaderBinaryUUID     = 32342e30-2e38-2d31-2b70-316161616161
> > >         shaderBinaryVersion  = 1
> > >
> > > VkPhysicalDeviceTransformFeedbackPropertiesEXT:
> > > -----------------------------------------------
> > >         maxTransformFeedbackStreams                = 4
> > >         maxTransformFeedbackBuffers                = 4
> > >         maxTransformFeedbackBufferSize             = 0xffffffff
> > >         maxTransformFeedbackStreamDataSize         = 512
> > >         maxTransformFeedbackBufferDataSize         = 512
> > >         maxTransformFeedbackBufferDataStride       = 512
> > >         transformFeedbackQueries                   = true
> > >         transformFeedbackStreamsLinesTriangles     = false
> > >         transformFeedbackRasterizationStreamSelect = false
> > >         transformFeedbackDraw                      = true
> > >
> > > VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT:
> > > ----------------------------------------------------
> > >         maxVertexAttribDivisor = 4294967295
> > >
> > > VkPhysicalDeviceVulkan11Properties:
> > > -----------------------------------
> > >         deviceUUID                        = 6d657361-3234-2e30-2e38-2d312b703100
> > >         driverUUID                        = 6c6c766d-7069-7065-5555-494400000000
> > >         deviceNodeMask                    = 0
> > >         deviceLUIDValid                   = false
> > >         subgroupSize                      = 4
> > >         subgroupSupportedStages: count = 4
> > >                 SHADER_STAGE_FRAGMENT_BIT
> > >                 SHADER_STAGE_COMPUTE_BIT
> > >                 SHADER_STAGE_TASK_BIT_EXT
> > >                 SHADER_STAGE_MESH_BIT_EXT
> > >         subgroupSupportedOperations: count = 7
> > >                 SUBGROUP_FEATURE_BASIC_BIT
> > >                 SUBGROUP_FEATURE_VOTE_BIT
> > >                 SUBGROUP_FEATURE_ARITHMETIC_BIT
> > >                 SUBGROUP_FEATURE_BALLOT_BIT
> > >                 SUBGROUP_FEATURE_SHUFFLE_BIT
> > >                 SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT
> > >                 SUBGROUP_FEATURE_QUAD_BIT
> > >         subgroupQuadOperationsInAllStages = false
> > >         pointClippingBehavior             = POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES
> > >         maxMultiviewViewCount             = 6
> > >         maxMultiviewInstanceIndex         = 2147483647
> > >         protectedNoFault                  = false
> > >         maxPerSetDescriptors              = 1000000
> > >         maxMemoryAllocationSize           = 0x80000000
> > >
> > > VkPhysicalDeviceVulkan12Properties:
> > > -----------------------------------
> > >         driverID                                             = DRIVER_ID_MESA_LLVMPIPE
> > >         driverName                                           = llvmpipe
> > >         driverInfo                                           = Mesa 24.0.8-1+p1 (LLVM 17.0.6)
> > >         conformanceVersion:
> > >                 major    = 1
> > >                 minor    = 3
> > >                 subminor = 1
> > >                 patch    = 1
> > >         denormBehaviorIndependence                           = SHADER_FLOAT_CONTROLS_INDEPENDENCE_ALL
> > >         roundingModeIndependence                             = SHADER_FLOAT_CONTROLS_INDEPENDENCE_ALL
> > >         shaderSignedZeroInfNanPreserveFloat16                = true
> > >         shaderSignedZeroInfNanPreserveFloat32                = true
> > >         shaderSignedZeroInfNanPreserveFloat64                = true
> > >         shaderDenormPreserveFloat16                          = false
> > >         shaderDenormPreserveFloat32                          = false
> > >         shaderDenormPreserveFloat64                          = false
> > >         shaderDenormFlushToZeroFloat16                       = false
> > >         shaderDenormFlushToZeroFloat32                       = false
> > >         shaderDenormFlushToZeroFloat64                       = false
> > >         shaderRoundingModeRTEFloat16                         = true
> > >         shaderRoundingModeRTEFloat32                         = true
> > >         shaderRoundingModeRTEFloat64                         = true
> > >         shaderRoundingModeRTZFloat16                         = false
> > >         shaderRoundingModeRTZFloat32                         = false
> > >         shaderRoundingModeRTZFloat64                         = false
> > >         maxUpdateAfterBindDescriptorsInAllPools              = 4294967295
> > >         shaderUniformBufferArrayNonUniformIndexingNative     = true
> > >         shaderSampledImageArrayNonUniformIndexingNative      = true
> > >         shaderStorageBufferArrayNonUniformIndexingNative     = true
> > >         shaderStorageImageArrayNonUniformIndexingNative      = true
> > >         shaderInputAttachmentArrayNonUniformIndexingNative   = true
> > >         robustBufferAccessUpdateAfterBind                    = true
> > >         quadDivergentImplicitLod                             = true
> > >         maxPerStageDescriptorUpdateAfterBindSamplers         = 1000000
> > >         maxPerStageDescriptorUpdateAfterBindUniformBuffers   = 1000000
> > >         maxPerStageDescriptorUpdateAfterBindStorageBuffers   = 1000000
> > >         maxPerStageDescriptorUpdateAfterBindSampledImages    = 1000000
> > >         maxPerStageDescriptorUpdateAfterBindStorageImages    = 1000000
> > >         maxPerStageDescriptorUpdateAfterBindInputAttachments = 1000000
> > >         maxPerStageUpdateAfterBindResources                  = 1000000
> > >         maxDescriptorSetUpdateAfterBindSamplers              = 1000000
> > >         maxDescriptorSetUpdateAfterBindUniformBuffers        = 1000000
> > >         maxDescriptorSetUpdateAfterBindUniformBuffersDynamic = 1000000
> > >         maxDescriptorSetUpdateAfterBindStorageBuffers        = 1000000
> > >         maxDescriptorSetUpdateAfterBindStorageBuffersDynamic = 1000000
> > >         maxDescriptorSetUpdateAfterBindSampledImages         = 1000000
> > >         maxDescriptorSetUpdateAfterBindStorageImages         = 1000000
> > >         maxDescriptorSetUpdateAfterBindInputAttachments      = 1000000
> > >         supportedDepthResolveModes: count = 2
> > >                 RESOLVE_MODE_SAMPLE_ZERO_BIT
> > >                 RESOLVE_MODE_AVERAGE_BIT
> > >         supportedStencilResolveModes: count = 1
> > >                 RESOLVE_MODE_SAMPLE_ZERO_BIT
> > >         independentResolveNone                               = false
> > >         independentResolve                                   = false
> > >         filterMinmaxSingleComponentFormats                   = true
> > >         filterMinmaxImageComponentMapping                    = true
> > >         maxTimelineSemaphoreValueDifference                  = 18446744073709551615
> > >         framebufferIntegerColorSampleCounts: count = 1
> > >                 SAMPLE_COUNT_1_BIT
> > >
> > > VkPhysicalDeviceVulkan13Properties:
> > > -----------------------------------
> > >         minSubgroupSize                                                               = 4
> > >         maxSubgroupSize                                                               = 4
> > >         maxComputeWorkgroupSubgroups                                                  = 32
> > >         requiredSubgroupSizeStages: count = 2
> > >                 SHADER_STAGE_FRAGMENT_BIT
> > >                 SHADER_STAGE_COMPUTE_BIT
> > >         maxInlineUniformBlockSize                                                     = 4096
> > >         maxPerStageDescriptorInlineUniformBlocks                                      = 8
> > >         maxPerStageDescriptorUpdateAfterBindInlineUniformBlocks                       = 8
> > >         maxDescriptorSetInlineUniformBlocks                                           = 8
> > >         maxDescriptorSetUpdateAfterBindInlineUniformBlocks                            = 8
> > >         maxInlineUniformTotalSize                                                     = 262144
> > >         integerDotProduct8BitUnsignedAccelerated                                      = false
> > >         integerDotProduct8BitSignedAccelerated                                        = false
> > >         integerDotProduct8BitMixedSignednessAccelerated                               = false
> > >         integerDotProduct4x8BitPackedUnsignedAccelerated                              = false
> > >         integerDotProduct4x8BitPackedSignedAccelerated                                = false
> > >         integerDotProduct4x8BitPackedMixedSignednessAccelerated                       = false
> > >         integerDotProduct16BitUnsignedAccelerated                                     = false
> > >         integerDotProduct16BitSignedAccelerated                                       = false
> > >         integerDotProduct16BitMixedSignednessAccelerated                              = false
> > >         integerDotProduct32BitUnsignedAccelerated                                     = false
> > >         integerDotProduct32BitSignedAccelerated                                       = false
> > >         integerDotProduct32BitMixedSignednessAccelerated                              = false
> > >         integerDotProduct64BitUnsignedAccelerated                                     = false
> > >         integerDotProduct64BitSignedAccelerated                                       = false
> > >         integerDotProduct64BitMixedSignednessAccelerated                              = false
> > >         integerDotProductAccumulatingSaturating8BitUnsignedAccelerated                = false
> > >         integerDotProductAccumulatingSaturating8BitSignedAccelerated                  = false
> > >         integerDotProductAccumulatingSaturating8BitMixedSignednessAccelerated         = false
> > >         integerDotProductAccumulatingSaturating4x8BitPackedUnsignedAccelerated        = false
> > >         integerDotProductAccumulatingSaturating4x8BitPackedSignedAccelerated          = false
> > >         integerDotProductAccumulatingSaturating4x8BitPackedMixedSignednessAccelerated = false
> > >         integerDotProductAccumulatingSaturating16BitUnsignedAccelerated               = false
> > >         integerDotProductAccumulatingSaturating16BitSignedAccelerated                 = false
> > >         integerDotProductAccumulatingSaturating16BitMixedSignednessAccelerated        = false
> > >         integerDotProductAccumulatingSaturating32BitUnsignedAccelerated               = false
> > >         integerDotProductAccumulatingSaturating32BitSignedAccelerated                 = false
> > >         integerDotProductAccumulatingSaturating32BitMixedSignednessAccelerated        = false
> > >         integerDotProductAccumulatingSaturating64BitUnsignedAccelerated               = false
> > >         integerDotProductAccumulatingSaturating64BitSignedAccelerated                 = false
> > >         integerDotProductAccumulatingSaturating64BitMixedSignednessAccelerated        = false
> > >         storageTexelBufferOffsetAlignmentBytes                                        = 0x00000010
> > >         storageTexelBufferOffsetSingleTexelAlignment                                  = true
> > >         uniformTexelBufferOffsetAlignmentBytes                                        = 0x00000010
> > >         uniformTexelBufferOffsetSingleTexelAlignment                                  = true
> > >         maxBufferSize                                                                 = 0xffffffff
> > >
> > > VkPhysicalDeviceHostImageCopyPropertiesEXT:
> > > -------------------------------------------
> > >         copySrcLayoutCount                  = 23
> > >         pCopySrcLayouts: count = 23
> > >                 IMAGE_LAYOUT_GENERAL
> > >                 IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL
> > >                 IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL
> > >                 IMAGE_LAYOUT_PREINITIALIZED
> > >                 IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_PRESENT_SRC_KHR
> > >                 IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR
> > >                 IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR
> > >                 IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR
> > >                 IMAGE_LAYOUT_SHARED_PRESENT_KHR
> > >                 IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT
> > >                 IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR
> > >         copyDstLayoutCount                  = 23
> > >         pCopyDstLayouts: count = 23
> > >                 IMAGE_LAYOUT_GENERAL
> > >                 IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL
> > >                 IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL
> > >                 IMAGE_LAYOUT_PREINITIALIZED
> > >                 IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_DEPTH_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_STENCIL_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_STENCIL_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_READ_ONLY_OPTIMAL
> > >                 IMAGE_LAYOUT_ATTACHMENT_OPTIMAL
> > >                 IMAGE_LAYOUT_PRESENT_SRC_KHR
> > >                 IMAGE_LAYOUT_VIDEO_DECODE_DST_KHR
> > >                 IMAGE_LAYOUT_VIDEO_DECODE_SRC_KHR
> > >                 IMAGE_LAYOUT_VIDEO_DECODE_DPB_KHR
> > >                 IMAGE_LAYOUT_SHARED_PRESENT_KHR
> > >                 IMAGE_LAYOUT_FRAGMENT_DENSITY_MAP_OPTIMAL_EXT
> > >                 IMAGE_LAYOUT_FRAGMENT_SHADING_RATE_ATTACHMENT_OPTIMAL_KHR
> > >         optimalTilingLayoutUUID             = 32342e30-2e38-2d31-2b70-316161616161
> > >         identicalMemoryTypeRequirements     = false
> > >
> > > Device Extensions: count = 124
> > >         VK_AMDX_shader_enqueue                        : extension revision 1
> > >         VK_ARM_rasterization_order_attachment_access  : extension revision 1
> > >         VK_EXT_4444_formats                           : extension revision 1
> > >         VK_EXT_attachment_feedback_loop_dynamic_state : extension revision 1
> > >         VK_EXT_attachment_feedback_loop_layout        : extension revision 2
> > >         VK_EXT_border_color_swizzle                   : extension revision 1
> > >         VK_EXT_calibrated_timestamps                  : extension revision 2
> > >         VK_EXT_color_write_enable                     : extension revision 1
> > >         VK_EXT_conditional_rendering                  : extension revision 2
> > >         VK_EXT_custom_border_color                    : extension revision 12
> > >         VK_EXT_depth_clip_control                     : extension revision 1
> > >         VK_EXT_depth_clip_enable                      : extension revision 1
> > >         VK_EXT_depth_range_unrestricted               : extension revision 1
> > >         VK_EXT_descriptor_buffer                      : extension revision 1
> > >         VK_EXT_descriptor_indexing                    : extension revision 2
> > >         VK_EXT_dynamic_rendering_unused_attachments   : extension revision 1
> > >         VK_EXT_extended_dynamic_state                 : extension revision 1
> > >         VK_EXT_extended_dynamic_state2                : extension revision 1
> > >         VK_EXT_extended_dynamic_state3                : extension revision 2
> > >         VK_EXT_external_memory_host                   : extension revision 1
> > >         VK_EXT_graphics_pipeline_library              : extension revision 1
> > >         VK_EXT_host_image_copy                        : extension revision 1
> > >         VK_EXT_host_query_reset                       : extension revision 1
> > >         VK_EXT_image_2d_view_of_3d                    : extension revision 1
> > >         VK_EXT_image_robustness                       : extension revision 1
> > >         VK_EXT_image_sliced_view_of_3d                : extension revision 1
> > >         VK_EXT_index_type_uint8                       : extension revision 1
> > >         VK_EXT_inline_uniform_block                   : extension revision 1
> > >         VK_EXT_line_rasterization                     : extension revision 1
> > >         VK_EXT_load_store_op_none                     : extension revision 1
> > >         VK_EXT_memory_budget                          : extension revision 1
> > >         VK_EXT_memory_priority                        : extension revision 1
> > >         VK_EXT_mesh_shader                            : extension revision 1
> > >         VK_EXT_multi_draw                             : extension revision 1
> > >         VK_EXT_multisampled_render_to_single_sampled  : extension revision 1
> > >         VK_EXT_mutable_descriptor_type                : extension revision 1
> > >         VK_EXT_nested_command_buffer                  : extension revision 1
> > >         VK_EXT_non_seamless_cube_map                  : extension revision 1
> > >         VK_EXT_pageable_device_local_memory           : extension revision 1
> > >         VK_EXT_pipeline_creation_cache_control        : extension revision 3
> > >         VK_EXT_pipeline_creation_feedback             : extension revision 1
> > >         VK_EXT_post_depth_coverage                    : extension revision 1
> > >         VK_EXT_primitive_topology_list_restart        : extension revision 1
> > >         VK_EXT_primitives_generated_query             : extension revision 1
> > >         VK_EXT_private_data                           : extension revision 1
> > >         VK_EXT_provoking_vertex                       : extension revision 1
> > >         VK_EXT_rasterization_order_attachment_access  : extension revision 1
> > >         VK_EXT_robustness2                            : extension revision 1
> > >         VK_EXT_sampler_filter_minmax                  : extension revision 2
> > >         VK_EXT_scalar_block_layout                    : extension revision 1
> > >         VK_EXT_separate_stencil_usage                 : extension revision 1
> > >         VK_EXT_shader_atomic_float                    : extension revision 1
> > >         VK_EXT_shader_atomic_float2                   : extension revision 1
> > >         VK_EXT_shader_demote_to_helper_invocation     : extension revision 1
> > >         VK_EXT_shader_object                          : extension revision 1
> > >         VK_EXT_shader_stencil_export                  : extension revision 1
> > >         VK_EXT_shader_subgroup_ballot                 : extension revision 1
> > >         VK_EXT_shader_subgroup_vote                   : extension revision 1
> > >         VK_EXT_shader_viewport_index_layer            : extension revision 1
> > >         VK_EXT_subgroup_size_control                  : extension revision 2
> > >         VK_EXT_texel_buffer_alignment                 : extension revision 1
> > >         VK_EXT_transform_feedback                     : extension revision 1
> > >         VK_EXT_vertex_attribute_divisor               : extension revision 3
> > >         VK_EXT_vertex_input_dynamic_state             : extension revision 2
> > >         VK_EXT_ycbcr_2plane_444_formats               : extension revision 1
> > >         VK_EXT_ycbcr_image_arrays                     : extension revision 1
> > >         VK_GOOGLE_decorate_string                     : extension revision 1
> > >         VK_GOOGLE_hlsl_functionality1                 : extension revision 1
> > >         VK_KHR_16bit_storage                          : extension revision 1
> > >         VK_KHR_8bit_storage                           : extension revision 1
> > >         VK_KHR_bind_memory2                           : extension revision 1
> > >         VK_KHR_buffer_device_address                  : extension revision 1
> > >         VK_KHR_copy_commands2                         : extension revision 1
> > >         VK_KHR_create_renderpass2                     : extension revision 1
> > >         VK_KHR_dedicated_allocation                   : extension revision 3
> > >         VK_KHR_depth_stencil_resolve                  : extension revision 1
> > >         VK_KHR_descriptor_update_template             : extension revision 1
> > >         VK_KHR_device_group                           : extension revision 4
> > >         VK_KHR_draw_indirect_count                    : extension revision 1
> > >         VK_KHR_driver_properties                      : extension revision 1
> > >         VK_KHR_dynamic_rendering                      : extension revision 1
> > >         VK_KHR_external_fence                         : extension revision 1
> > >         VK_KHR_external_memory                        : extension revision 1
> > >         VK_KHR_external_memory_fd                     : extension revision 1
> > >         VK_KHR_external_semaphore                     : extension revision 1
> > >         VK_KHR_format_feature_flags2                  : extension revision 2
> > >         VK_KHR_get_memory_requirements2               : extension revision 1
> > >         VK_KHR_image_format_list                      : extension revision 1
> > >         VK_KHR_imageless_framebuffer                  : extension revision 1
> > >         VK_KHR_incremental_present                    : extension revision 2
> > >         VK_KHR_maintenance1                           : extension revision 2
> > >         VK_KHR_maintenance2                           : extension revision 1
> > >         VK_KHR_maintenance3                           : extension revision 1
> > >         VK_KHR_maintenance4                           : extension revision 2
> > >         VK_KHR_maintenance5                           : extension revision 1
> > >         VK_KHR_maintenance6                           : extension revision 1
> > >         VK_KHR_map_memory2                            : extension revision 1
> > >         VK_KHR_multiview                              : extension revision 1
> > >         VK_KHR_pipeline_library                       : extension revision 1
> > >         VK_KHR_push_descriptor                        : extension revision 2
> > >         VK_KHR_relaxed_block_layout                   : extension revision 1
> > >         VK_KHR_sampler_mirror_clamp_to_edge           : extension revision 3
> > >         VK_KHR_sampler_ycbcr_conversion               : extension revision 14
> > >         VK_KHR_separate_depth_stencil_layouts         : extension revision 1
> > >         VK_KHR_shader_atomic_int64                    : extension revision 1
> > >         VK_KHR_shader_clock                           : extension revision 1
> > >         VK_KHR_shader_draw_parameters                 : extension revision 1
> > >         VK_KHR_shader_float16_int8                    : extension revision 1
> > >         VK_KHR_shader_float_controls                  : extension revision 4
> > >         VK_KHR_shader_integer_dot_product             : extension revision 1
> > >         VK_KHR_shader_non_semantic_info               : extension revision 1
> > >         VK_KHR_shader_subgroup_extended_types         : extension revision 1
> > >         VK_KHR_shader_terminate_invocation            : extension revision 1
> > >         VK_KHR_spirv_1_4                              : extension revision 1
> > >         VK_KHR_storage_buffer_storage_class           : extension revision 1
> > >         VK_KHR_swapchain                              : extension revision 70
> > >         VK_KHR_swapchain_mutable_format               : extension revision 1
> > >         VK_KHR_synchronization2                       : extension revision 1
> > >         VK_KHR_timeline_semaphore                     : extension revision 2
> > >         VK_KHR_uniform_buffer_standard_layout         : extension revision 1
> > >         VK_KHR_variable_pointers                      : extension revision 1
> > >         VK_KHR_vulkan_memory_model                    : extension revision 3
> > >         VK_KHR_zero_initialize_workgroup_memory       : extension revision 1
> > >         VK_NV_device_generated_commands               : extension revision 3
> > >
> > > VkQueueFamilyProperties:
> > > ========================
> > >         queueProperties[0]:
> > >         -------------------
> > >                 minImageTransferGranularity = (1,1,1)
> > >                 queueCount                  = 1
> > >                 queueFlags                  = QUEUE_GRAPHICS_BIT | QUEUE_COMPUTE_BIT | QUEUE_TRANSFER_BIT
> > >                 timestampValidBits          = 64
> > >                 present support             = false
> > >
> > > VkPhysicalDeviceMemoryProperties:
> > > =================================
> > > memoryHeaps: count = 1
> > >         memoryHeaps[0]:
> > >                 size   = 3505938432 (0xd0f86000) (3.27 GiB)
> > >                 budget = 3505938432 (0xd0f86000) (3.27 GiB)
> > >                 usage  = 522092544 (0x1f1e8000) (497.91 MiB)
> > >                 flags: count = 1
> > >                         MEMORY_HEAP_DEVICE_LOCAL_BIT
> > > memoryTypes: count = 1
> > >         memoryTypes[0]:
> > >                 heapIndex     = 0
> > >                 propertyFlags = 0x000f: count = 4
> > >                         MEMORY_PROPERTY_DEVICE_LOCAL_BIT
> > >                         MEMORY_PROPERTY_HOST_VISIBLE_BIT
> > >                         MEMORY_PROPERTY_HOST_COHERENT_BIT
> > >                         MEMORY_PROPERTY_HOST_CACHED_BIT
> > >                 usable for:
> > >                         IMAGE_TILING_OPTIMAL:
> > >                                 color images
> > >                                 FORMAT_D16_UNORM
> > >                                 FORMAT_X8_D24_UNORM_PACK32
> > >                                 FORMAT_D32_SFLOAT
> > >                                 FORMAT_S8_UINT
> > >                                 FORMAT_D24_UNORM_S8_UINT
> > >                                 FORMAT_D32_SFLOAT_S8_UINT
> > >                                 (non-sparse)
> > >                         IMAGE_TILING_LINEAR:
> > >                                 color images
> > >                                 (non-sparse)
> > >
> > > VkPhysicalDeviceFeatures:
> > > =========================
> > >         robustBufferAccess                      = true
> > >         fullDrawIndexUint32                     = true
> > >         imageCubeArray                          = true
> > >         independentBlend                        = true
> > >         geometryShader                          = true
> > >         tessellationShader                      = true
> > >         sampleRateShading                       = true
> > >         dualSrcBlend                            = true
> > >         logicOp                                 = true
> > >         multiDrawIndirect                       = true
> > >         drawIndirectFirstInstance               = true
> > >         depthClamp                              = true
> > >         depthBiasClamp                          = true
> > >         fillModeNonSolid                        = true
> > >         depthBounds                             = false
> > >         wideLines                               = true
> > >         largePoints                             = true
> > >         alphaToOne                              = true
> > >         multiViewport                           = true
> > >         samplerAnisotropy                       = true
> > >         textureCompressionETC2                  = false
> > >         textureCompressionASTC_LDR              = false
> > >         textureCompressionBC                    = true
> > >         occlusionQueryPrecise                   = true
> > >         pipelineStatisticsQuery                 = true
> > >         vertexPipelineStoresAndAtomics          = true
> > >         fragmentStoresAndAtomics                = true
> > >         shaderTessellationAndGeometryPointSize  = true
> > >         shaderImageGatherExtended               = true
> > >         shaderStorageImageExtendedFormats       = true
> > >         shaderStorageImageMultisample           = true
> > >         shaderStorageImageReadWithoutFormat     = true
> > >         shaderStorageImageWriteWithoutFormat    = true
> > >         shaderUniformBufferArrayDynamicIndexing = true
> > >         shaderSampledImageArrayDynamicIndexing  = true
> > >         shaderStorageBufferArrayDynamicIndexing = true
> > >         shaderStorageImageArrayDynamicIndexing  = true
> > >         shaderClipDistance                      = true
> > >         shaderCullDistance                      = true
> > >         shaderFloat64                           = true
> > >         shaderInt64                             = true
> > >         shaderInt16                             = true
> > >         shaderResourceResidency                 = false
> > >         shaderResourceMinLod                    = false
> > >         sparseBinding                           = false
> > >         sparseResidencyBuffer                   = false
> > >         sparseResidencyImage2D                  = false
> > >         sparseResidencyImage3D                  = false
> > >         sparseResidency2Samples                 = false
> > >         sparseResidency4Samples                 = false
> > >         sparseResidency8Samples                 = false
> > >         sparseResidency16Samples                = false
> > >         sparseResidencyAliased                  = false
> > >         variableMultisampleRate                 = false
> > >         inheritedQueries                        = false
> > >
> > > VkPhysicalDevice4444FormatsFeaturesEXT:
> > > ---------------------------------------
> > >         formatA4R4G4B4 = true
> > >         formatA4B4G4R4 = true
> > >
> > > VkPhysicalDeviceAttachmentFeedbackLoopDynamicStateFeaturesEXT:
> > > --------------------------------------------------------------
> > >         attachmentFeedbackLoopDynamicState = true
> > >
> > > VkPhysicalDeviceAttachmentFeedbackLoopLayoutFeaturesEXT:
> > > --------------------------------------------------------
> > >         attachmentFeedbackLoopLayout = true
> > >
> > > VkPhysicalDeviceBorderColorSwizzleFeaturesEXT:
> > > ----------------------------------------------
> > >         borderColorSwizzle          = true
> > >         borderColorSwizzleFromImage = true
> > >
> > > VkPhysicalDeviceColorWriteEnableFeaturesEXT:
> > > --------------------------------------------
> > >         colorWriteEnable = true
> > >
> > > VkPhysicalDeviceConditionalRenderingFeaturesEXT:
> > > ------------------------------------------------
> > >         conditionalRendering          = true
> > >         inheritedConditionalRendering = false
> > >
> > > VkPhysicalDeviceCustomBorderColorFeaturesEXT:
> > > ---------------------------------------------
> > >         customBorderColors             = true
> > >         customBorderColorWithoutFormat = true
> > >
> > > VkPhysicalDeviceDepthClipControlFeaturesEXT:
> > > --------------------------------------------
> > >         depthClipControl = true
> > >
> > > VkPhysicalDeviceDepthClipEnableFeaturesEXT:
> > > -------------------------------------------
> > >         depthClipEnable = true
> > >
> > > VkPhysicalDeviceDescriptorBufferFeaturesEXT:
> > > --------------------------------------------
> > >         descriptorBuffer                   = true
> > >         descriptorBufferCaptureReplay      = false
> > >         descriptorBufferImageLayoutIgnored = true
> > >         descriptorBufferPushDescriptors    = true
> > >
> > > VkPhysicalDeviceDynamicRenderingUnusedAttachmentsFeaturesEXT:
> > > -------------------------------------------------------------
> > >         dynamicRenderingUnusedAttachments = true
> > >
> > > VkPhysicalDeviceExtendedDynamicState2FeaturesEXT:
> > > -------------------------------------------------
> > >         extendedDynamicState2                   = true
> > >         extendedDynamicState2LogicOp            = true
> > >         extendedDynamicState2PatchControlPoints = true
> > >
> > > VkPhysicalDeviceExtendedDynamicState3FeaturesEXT:
> > > -------------------------------------------------
> > >         extendedDynamicState3TessellationDomainOrigin         = true
> > >         extendedDynamicState3DepthClampEnable                 = true
> > >         extendedDynamicState3PolygonMode                      = true
> > >         extendedDynamicState3RasterizationSamples             = true
> > >         extendedDynamicState3SampleMask                       = true
> > >         extendedDynamicState3AlphaToCoverageEnable            = true
> > >         extendedDynamicState3AlphaToOneEnable                 = true
> > >         extendedDynamicState3LogicOpEnable                    = true
> > >         extendedDynamicState3ColorBlendEnable                 = true
> > >         extendedDynamicState3ColorBlendEquation               = true
> > >         extendedDynamicState3ColorWriteMask                   = true
> > >         extendedDynamicState3RasterizationStream              = false
> > >         extendedDynamicState3ConservativeRasterizationMode    = false
> > >         extendedDynamicState3ExtraPrimitiveOverestimationSize = false
> > >         extendedDynamicState3DepthClipEnable                  = true
> > >         extendedDynamicState3SampleLocationsEnable            = false
> > >         extendedDynamicState3ColorBlendAdvanced               = false
> > >         extendedDynamicState3ProvokingVertexMode              = true
> > >         extendedDynamicState3LineRasterizationMode            = true
> > >         extendedDynamicState3LineStippleEnable                = true
> > >         extendedDynamicState3DepthClipNegativeOneToOne        = true
> > >         extendedDynamicState3ViewportWScalingEnable           = false
> > >         extendedDynamicState3ViewportSwizzle                  = false
> > >         extendedDynamicState3CoverageToColorEnable            = false
> > >         extendedDynamicState3CoverageToColorLocation          = false
> > >         extendedDynamicState3CoverageModulationMode           = false
> > >         extendedDynamicState3CoverageModulationTableEnable    = false
> > >         extendedDynamicState3CoverageModulationTable          = false
> > >         extendedDynamicState3CoverageReductionMode            = false
> > >         extendedDynamicState3RepresentativeFragmentTestEnable = false
> > >         extendedDynamicState3ShadingRateImageEnable           = false
> > >
> > > VkPhysicalDeviceExtendedDynamicStateFeaturesEXT:
> > > ------------------------------------------------
> > >         extendedDynamicState = true
> > >
> > > VkPhysicalDeviceGraphicsPipelineLibraryFeaturesEXT:
> > > ---------------------------------------------------
> > >         graphicsPipelineLibrary = true
> > >
> > > VkPhysicalDeviceHostImageCopyFeaturesEXT:
> > > -----------------------------------------
> > >         hostImageCopy = true
> > >
> > > VkPhysicalDeviceImage2DViewOf3DFeaturesEXT:
> > > -------------------------------------------
> > >         image2DViewOf3D   = true
> > >         sampler2DViewOf3D = true
> > >
> > > VkPhysicalDeviceImageSlicedViewOf3DFeaturesEXT:
> > > -----------------------------------------------
> > >         imageSlicedViewOf3D = true
> > >
> > > VkPhysicalDeviceIndexTypeUint8FeaturesKHR:
> > > ------------------------------------------
> > >         indexTypeUint8 = true
> > >
> > > VkPhysicalDeviceLineRasterizationFeaturesKHR:
> > > ---------------------------------------------
> > >         rectangularLines         = true
> > >         bresenhamLines           = true
> > >         smoothLines              = true
> > >         stippledRectangularLines = true
> > >         stippledBresenhamLines   = true
> > >         stippledSmoothLines      = true
> > >
> > > VkPhysicalDeviceMaintenance5FeaturesKHR:
> > > ----------------------------------------
> > >         maintenance5 = true
> > >
> > > VkPhysicalDeviceMaintenance6FeaturesKHR:
> > > ----------------------------------------
> > >         maintenance6 = true
> > >
> > > VkPhysicalDeviceMemoryPriorityFeaturesEXT:
> > > ------------------------------------------
> > >         memoryPriority = true
> > >
> > > VkPhysicalDeviceMeshShaderFeaturesEXT:
> > > --------------------------------------
> > >         taskShader                             = true
> > >         meshShader                             = true
> > >         multiviewMeshShader                    = false
> > >         primitiveFragmentShadingRateMeshShader = false
> > >         meshShaderQueries                      = true
> > >
> > > VkPhysicalDeviceMultiDrawFeaturesEXT:
> > > -------------------------------------
> > >         multiDraw = true
> > >
> > > VkPhysicalDeviceMultisampledRenderToSingleSampledFeaturesEXT:
> > > -------------------------------------------------------------
> > >         multisampledRenderToSingleSampled = true
> > >
> > > VkPhysicalDeviceMutableDescriptorTypeFeaturesEXT:
> > > -------------------------------------------------
> > >         mutableDescriptorType = true
> > >
> > > VkPhysicalDeviceNestedCommandBufferFeaturesEXT:
> > > -----------------------------------------------
> > >         nestedCommandBuffer                = true
> > >         nestedCommandBufferRendering       = true
> > >         nestedCommandBufferSimultaneousUse = true
> > >
> > > VkPhysicalDeviceNonSeamlessCubeMapFeaturesEXT:
> > > ----------------------------------------------
> > >         nonSeamlessCubeMap = true
> > >
> > > VkPhysicalDevicePageableDeviceLocalMemoryFeaturesEXT:
> > > -----------------------------------------------------
> > >         pageableDeviceLocalMemory = true
> > >
> > > VkPhysicalDevicePrimitiveTopologyListRestartFeaturesEXT:
> > > --------------------------------------------------------
> > >         primitiveTopologyListRestart      = true
> > >         primitiveTopologyPatchListRestart = true
> > >
> > > VkPhysicalDevicePrimitivesGeneratedQueryFeaturesEXT:
> > > ----------------------------------------------------
> > >         primitivesGeneratedQuery                      = true
> > >         primitivesGeneratedQueryWithRasterizerDiscard = true
> > >         primitivesGeneratedQueryWithNonZeroStreams    = true
> > >
> > > VkPhysicalDeviceProvokingVertexFeaturesEXT:
> > > -------------------------------------------
> > >         provokingVertexLast                       = true
> > >         transformFeedbackPreservesProvokingVertex = true
> > >
> > > VkPhysicalDeviceRasterizationOrderAttachmentAccessFeaturesEXT:
> > > --------------------------------------------------------------
> > >         rasterizationOrderColorAttachmentAccess   = true
> > >         rasterizationOrderDepthAttachmentAccess   = true
> > >         rasterizationOrderStencilAttachmentAccess = true
> > >
> > > VkPhysicalDeviceRobustness2FeaturesEXT:
> > > ---------------------------------------
> > >         robustBufferAccess2 = true
> > >         robustImageAccess2  = true
> > >         nullDescriptor      = true
> > >
> > > VkPhysicalDeviceShaderAtomicFloat2FeaturesEXT:
> > > ----------------------------------------------
> > >         shaderBufferFloat16Atomics      = false
> > >         shaderBufferFloat16AtomicAdd    = false
> > >         shaderBufferFloat16AtomicMinMax = false
> > >         shaderBufferFloat32AtomicMinMax = true
> > >         shaderBufferFloat64AtomicMinMax = false
> > >         shaderSharedFloat16Atomics      = false
> > >         shaderSharedFloat16AtomicAdd    = false
> > >         shaderSharedFloat16AtomicMinMax = false
> > >         shaderSharedFloat32AtomicMinMax = true
> > >         shaderSharedFloat64AtomicMinMax = false
> > >         shaderImageFloat32AtomicMinMax  = true
> > >         sparseImageFloat32AtomicMinMax  = false
> > >
> > > VkPhysicalDeviceShaderAtomicFloatFeaturesEXT:
> > > ---------------------------------------------
> > >         shaderBufferFloat32Atomics   = true
> > >         shaderBufferFloat32AtomicAdd = true
> > >         shaderBufferFloat64Atomics   = false
> > >         shaderBufferFloat64AtomicAdd = false
> > >         shaderSharedFloat32Atomics   = true
> > >         shaderSharedFloat32AtomicAdd = true
> > >         shaderSharedFloat64Atomics   = false
> > >         shaderSharedFloat64AtomicAdd = false
> > >         shaderImageFloat32Atomics    = true
> > >         shaderImageFloat32AtomicAdd  = true
> > >         sparseImageFloat32Atomics    = false
> > >         sparseImageFloat32AtomicAdd  = false
> > >
> > > VkPhysicalDeviceShaderClockFeaturesKHR:
> > > ---------------------------------------
> > >         shaderSubgroupClock = true
> > >         shaderDeviceClock   = true
> > >
> > > VkPhysicalDeviceShaderObjectFeaturesEXT:
> > > ----------------------------------------
> > >         shaderObject = true
> > >
> > > VkPhysicalDeviceTexelBufferAlignmentFeaturesEXT:
> > > ------------------------------------------------
> > >         texelBufferAlignment = true
> > >
> > > VkPhysicalDeviceTransformFeedbackFeaturesEXT:
> > > ---------------------------------------------
> > >         transformFeedback = true
> > >         geometryStreams   = true
> > >
> > > VkPhysicalDeviceVertexAttributeDivisorFeaturesKHR:
> > > --------------------------------------------------
> > >         vertexAttributeInstanceRateDivisor     = true
> > >         vertexAttributeInstanceRateZeroDivisor = true
> > >
> > > VkPhysicalDeviceVertexInputDynamicStateFeaturesEXT:
> > > ---------------------------------------------------
> > >         vertexInputDynamicState = true
> > >
> > > VkPhysicalDeviceVulkan11Features:
> > > ---------------------------------
> > >         storageBuffer16BitAccess           = true
> > >         uniformAndStorageBuffer16BitAccess = true
> > >         storagePushConstant16              = true
> > >         storageInputOutput16               = false
> > >         multiview                          = true
> > >         multiviewGeometryShader            = true
> > >         multiviewTessellationShader        = true
> > >         variablePointersStorageBuffer      = true
> > >         variablePointers                   = true
> > >         protectedMemory                    = false
> > >         samplerYcbcrConversion             = true
> > >         shaderDrawParameters               = true
> > >
> > > VkPhysicalDeviceVulkan12Features:
> > > ---------------------------------
> > >         samplerMirrorClampToEdge                           = true
> > >         drawIndirectCount                                  = true
> > >         storageBuffer8BitAccess                            = true
> > >         uniformAndStorageBuffer8BitAccess                  = true
> > >         storagePushConstant8                               = true
> > >         shaderBufferInt64Atomics                           = true
> > >         shaderSharedInt64Atomics                           = true
> > >         shaderFloat16                                      = true
> > >         shaderInt8                                         = true
> > >         descriptorIndexing                                 = true
> > >         shaderInputAttachmentArrayDynamicIndexing          = true
> > >         shaderUniformTexelBufferArrayDynamicIndexing       = true
> > >         shaderStorageTexelBufferArrayDynamicIndexing       = true
> > >         shaderUniformBufferArrayNonUniformIndexing         = true
> > >         shaderSampledImageArrayNonUniformIndexing          = true
> > >         shaderStorageBufferArrayNonUniformIndexing         = true
> > >         shaderStorageImageArrayNonUniformIndexing          = true
> > >         shaderInputAttachmentArrayNonUniformIndexing       = true
> > >         shaderUniformTexelBufferArrayNonUniformIndexing    = true
> > >         shaderStorageTexelBufferArrayNonUniformIndexing    = true
> > >         descriptorBindingUniformBufferUpdateAfterBind      = true
> > >         descriptorBindingSampledImageUpdateAfterBind       = true
> > >         descriptorBindingStorageImageUpdateAfterBind       = true
> > >         descriptorBindingStorageBufferUpdateAfterBind      = true
> > >         descriptorBindingUniformTexelBufferUpdateAfterBind = true
> > >         descriptorBindingStorageTexelBufferUpdateAfterBind = true
> > >         descriptorBindingUpdateUnusedWhilePending          = true
> > >         descriptorBindingPartiallyBound                    = true
> > >         descriptorBindingVariableDescriptorCount           = true
> > >         runtimeDescriptorArray                             = true
> > >         samplerFilterMinmax                                = true
> > >         scalarBlockLayout                                  = true
> > >         imagelessFramebuffer                               = true
> > >         uniformBufferStandardLayout                        = true
> > >         shaderSubgroupExtendedTypes                        = true
> > >         separateDepthStencilLayouts                        = true
> > >         hostQueryReset                                     = true
> > >         timelineSemaphore                                  = true
> > >         bufferDeviceAddress                                = true
> > >         bufferDeviceAddressCaptureReplay                   = false
> > >         bufferDeviceAddressMultiDevice                     = false
> > >         vulkanMemoryModel                                  = true
> > >         vulkanMemoryModelDeviceScope                       = true
> > >         vulkanMemoryModelAvailabilityVisibilityChains      = true
> > >         shaderOutputViewportIndex                          = true
> > >         shaderOutputLayer                                  = true
> > >         subgroupBroadcastDynamicId                         = true
> > >
> > > VkPhysicalDeviceVulkan13Features:
> > > ---------------------------------
> > >         robustImageAccess                                  = true
> > >         inlineUniformBlock                                 = true
> > >         descriptorBindingInlineUniformBlockUpdateAfterBind = true
> > >         pipelineCreationCacheControl                       = true
> > >         privateData                                        = true
> > >         shaderDemoteToHelperInvocation                     = true
> > >         shaderTerminateInvocation                          = true
> > >         subgroupSizeControl                                = true
> > >         computeFullSubgroups                               = true
> > >         synchronization2                                   = true
> > >         textureCompressionASTC_HDR                         = false
> > >         shaderZeroInitializeWorkgroupMemory                = true
> > >         dynamicRendering                                   = true
> > >         shaderIntegerDotProduct                            = true
> > >         maintenance4                                       = true
> > >
> > > VkPhysicalDeviceYcbcr2Plane444FormatsFeaturesEXT:
> > > -------------------------------------------------
> > >         ycbcr2plane444Formats = true
> > >
> > > VkPhysicalDeviceYcbcrImageArraysFeaturesEXT:
> > > --------------------------------------------
> > >         ycbcrImageArrays = true
> > >
> > >
> > > --
> > > 2.45.1.288.g0e0cd299f1-goog
> > >