vulkan

package
v0.0.0-...-15b4445 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 6, 2022 License: Apache-2.0 Imports: 49 Imported by: 0

README

Vulkan Status

Trace and Replay

Vulkan is currently WIP. Many samples, and applications work correctly, but some bugs may still be present.

Mid-Execution Capture

Mid-Execution capture allows an application to be traced starting at an arbitrary point in time.

If tracing from the command line this can be done with

gapit trace -start-defer

When using the GUI, this can be acheived by unchecking Trace from Beginning

Invalid VkDestoryXXX and VkFreeXXX Commands Due to Mid-Execution Capture

When using Mid-Execution capture, it is possible that at the time of capturing, an object's dependee has been destroyed but the object itself is still there, such objects will NOT be rebuilt for replay and the VkDestroyXXX referring to such object will be dropped for replay, also VkFreeXXX commands referring to such objects will be modified or dropped to not freeing those not-rebuilt objects.

For example: A VkImage might have been destroyed when a Mid-Execution capture starts, but the VkImageView handles that were created with the destroyed VkImage might still be there. In such cases, those VkImageView handles are invalid and will not be created during replay, also the VkFramebuffer handles that depend on those VkImageView handles will not be created during replay too. VkDestroyImageView and VkDestroyFramebuffer commands that refer to those VkImageView and VkFramebuffer handles will be dropped, so won't be called during replay.

Subcommands

When visualizing the tree of Commands, every VkQueueSubmit is expanded into a list of the commands that are run during that submission. From there you can query information about any call in the program.

Performance

We are still tuning performance for Vulkan in GAPID. For Posix based platforms we handle persistently mapped coherent memory efficiently, but for Windows this is currently in progress. Large blocks of mapped coherent memory can greatly reduce replay performance and increase trace size.

Test applications

We use a set of Test Applications to validate whether or not Vulkan support is functioning. This repository contains applications that use most parts of the API, and will be expanded as more interesting and tricky uses of the API are found.

Partial extension support

Some extensions are not supported by GAPID, but have stubs defined in the API files. The current list of partially supported extensions:

  • VK_EXT_conditional_rendering

Current Support

The current status of support for the Vulkan API on a method by method basis are as follows.

Command Name Capture Mid-Execution Subcommands
vkAllocateCommandBuffers
vkCreateDevice
vkCreateInstance
vkDestroyDevice
vkDestroyInstance
vkEnumerateDeviceExtensionProperties
vkEnumerateDeviceLayerProperties
vkEnumerateInstanceExtensionProperties
vkEnumerateInstanceLayerProperties
vkEnumeratePhysicalDevices
vkFreeCommandBuffers
vkGetDeviceProcAddr
vkGetDeviceQueue
vkGetInstanceProcAddr
vkGetPhysicalDeviceSparseImageFormatProperties
vkGetPhysicalDeviceFeatures
vkGetPhysicalDeviceFormatProperties
vkGetPhysicalDeviceImageFormatProperties
vkGetPhysicalDeviceMemoryProperties
vkGetPhysicalDeviceProperties
vkGetPhysicalDeviceQueueFamilyProperties
vkAcquireNextImageKHR
vkAllocateDescriptorSets
vkAllocateMemory
vkBeginCommandBuffer
vkBindBufferMemory
vkBindImageMemory
vkCmdBeginQuery
vkCmdBeginRenderPass
vkCmdBindDescriptorSets
vkCmdBindIndexBuffer
vkCmdBindPipeline
vkCmdBindVertexBuffers
vkCmdBlitImage
vkCmdClearAttachments
vkCmdClearColorImage
vkCmdClearDepthStencilImage
vkCmdCopyBuffer
vkCmdCopyBufferToImage
vkCmdCopyImage
vkCmdCopyImageToBuffer
vkCmdCopyQueryPoolResults
vkCmdDispatch
vkCmdDispatchIndirect
vkCmdDraw
vkCmdDrawIndexed
vkCmdDrawIndexedIndirect
vkCmdDrawIndirect
vkCmdEndQuery
vkCmdEndRenderPass
vkCmdExecuteCommands
vkCmdFillBuffer
vkCmdNextSubpass
vkCmdPipelineBarrier
vkCmdPushConstants
vkCmdResetEvent
vkCmdResetQueryPool
vkCmdResolveImage
vkCmdSetBlendConstants
vkCmdSetDepthBias
vkCmdSetDepthBounds
vkCmdSetEvent
vkCmdSetLineWidth
vkCmdSetScissor
vkCmdSetStencilCompareMask
vkCmdSetStencilReference
vkCmdSetStencilWriteMask
vkCmdSetViewport
vkCmdUpdateBuffer
vkCmdWaitEvents
vkCmdWriteTimestamp
vkCreateAndroidSurfaceKHR
vkCreateBuffer
vkCreateBufferView
vkCreateCommandPool
vkCreateComputePipelines
vkCreateDescriptorPool
vkCreateDescriptorSetLayout
vkCreateDisplayModeKHR
vkCreateDisplayPlaneSurfaceKHR
vkCreateEvent
vkCreateFramebuffer
vkCreateGraphicsPipelines
vkCreateImage
vkCreateImageView
vkCreateMirSurfaceKHR
vkCreatePipelineCache
vkCreatePipelineLayout
vkCreateQueryPool
vkCreateRenderPass
vkCreateSampler
vkCreateSemaphore
vkCreateShaderModule
vkCreateSharedSwapchainsKHR
vkCreateSwapchainKHR
vkCreateWaylandSurfaceKHR
vkCreateWin32SurfaceKHR
vkCreateXcbSurfaceKHR
vkCreateXlibSurfaceKHR
vkDestroyBuffer
vkDestroyBufferView
vkDestroyCommandPool
vkDestroyDescriptorPool
vkDestroyDescriptorSetLayout
vkDestroyEvent
vkDestroyFramebuffer
vkDestroyImage
vkDestroyImageView
vkDestroyPipeline
vkDestroyPipelineCache
vkDestroyPipelineLayout
vkDestroyQueryPool
vkDestroyRenderPass
vkDestroySampler
vkDestroySemaphore
vkDestroyShaderModule
vkDestroySwapchainKHR
vkDeviceWaitIdle
vkEndCommandBuffer
vkFlushMappedMemoryRanges
vkFreeDescriptorSets
vkFreeMemory
vkGetBufferMemoryRequirements
vkGetDeviceMemoryCommitment
vkGetDisplayModePropertiesKHR
vkGetDisplayPlaneCapabilitiesKHR
vkGetDisplayPlaneSupportedDisplaysKHR
vkGetEventStatus
vkGetFenceStatus
vkGetImageMemoryRequirements
vkGetImageSparseMemoryRequirements
vkGetImageSubresourceLayout
vkGetPhysicalDeviceDisplayPlanePropertiesKHR
vkGetPhysicalDeviceDisplayPropertiesKHR
vkGetPhysicalDeviceMirPresentationSupportKHR
vkGetPhysicalDeviceSurfaceCapabilitiesKHR
vkGetPhysicalDeviceSurfaceFormatsKHR
vkGetPhysicalDeviceSurfacePresentModesKHR
vkGetPhysicalDeviceSurfaceSupportKHR
vkGetPhysicalDeviceWaylandPresentationSupportKHR
vkGetPhysicalDeviceWin32PresentationSupportKHR
vkGetPhysicalDeviceXcbPresentationSupportKHR
vkGetPhysicalDeviceXlibPresentationSupportKHR
vkGetPipelineCacheData
vkGetQueryPoolResults
vkGetRenderAreaGranularity
vkGetSwapchainImagesKHR
vkInvalidateMappedMemoryRanges
vkMapMemory
vkMergePipelineCaches
vkQueueBindSparse
vkQueuePresentKHR
vkQueueSubmit
vkQueueWaitIdle
vkResetCommandBuffer
vkResetCommandPool
vkResetDescriptorPool
vkResetEvent
vkResetFences
vkSetEvent
vkUnmapMemory
vkUpdateDescriptorSets
vkWaitForFences
vkCreateFence
vkDestroyFence
vkDestroySurfaceKHR

Documentation

Overview

Package vulkan implementes the API interface for the Vulkan graphics library.

Index

Constants

View Source
const (
	VK_BEGIN_COMMAND_BUFFER   = "vkBeginCommandBuffer"
	VK_CMD_BEGIN_RENDER_PASS  = "vkCmdBeginRenderPass"
	VK_CMD_NEXT_SUBPASS       = "vkCmdNextSubpass"
	VK_COMMAND_BUFFER         = "vkCommandBuffer"
	VK_RENDER_PASS            = "vkRenderPass"
	VK_SUBPASS                = "vkSubpass"
	VK_END_COMMAND_BUFFER     = "vkEndCommandBuffer"
	VK_CMD_END_RENDER_PASS    = "vkCmdEndRenderPass"
	COMMAND_BUFFER            = "commandBuffer"
	VK_CMD_DEBUG_MARKER_BEGIN = "vkCmdDebugMarkerBeginEXT"
	VK_CMD_DEBUG_MARKER_END   = "vkCmdDebugMarkerEndEXT"
	VK_CMD_DEBUG_MARKER       = "vkCmdDebugMarker"
)
View Source
const (
	DebugMarker = iota
	RenderPassMarker
)
View Source
const VK_ATTACHMENT_UNUSED = uint32(0xFFFFFFFF)

Variables

This section is empty.

Functions

func AddCommand

func AddCommand(ctx context.Context,
	cb CommandBuilder,
	commandBuffer VkCommandBuffer,
	r *api.GlobalState,
	s *api.GlobalState,
	rebuildInfo interface{}) (func(), api.Cmd, error)

AddCommand recreates the command defined by recreateInfo and places it into the given command buffer. It returns the commands that it had to create in order to satisfy the command. It also returns a function to clean up the data that was allocated during the creation.

func CallReflectedCommand

func CallReflectedCommand(ctx context.Context, cmd api.Cmd, id api.CmdID, s *api.GlobalState, b *rb.Builder, w api.StateWatcher, sub, data interface{})

CallReflectedCommand unpacks the given subcommand and arguments, and calls the method

func EnterRecreate

func EnterRecreate(ctx context.Context, s *api.GlobalState) func()

func GetCommandArgs

func GetCommandArgs(ctx context.Context,
	cr CommandReferenceʳ,
	s *State) interface{}

GetCommandArgs takes a command reference and returns the command arguments of that recorded command.

func GetCommandFunction

func GetCommandFunction(cr *CommandReference) interface{}

GetCommandFunction takes a command reference (recorded command buffer command) and returns the function which mutates the state as the recorded command get executed.

func IsFullyBound

func IsFullyBound(offset VkDeviceSize, size VkDeviceSize,
	bindings U64ːVkSparseMemoryBindᵐ) bool

IsFullyBound returns true if the resource range from offset with size is fully covered in the bindings. If the size ofd the resource range is 0, returns false.

func NewCommandSplitter

func NewCommandSplitter(ctx context.Context) *commandSplitter

Types

type ExternalBufferData

type ExternalBufferData struct {
	Buffer             VkBuffer
	BufferOffset       VkDeviceSize
	DataOffset         VkDeviceSize
	Size               VkDeviceSize
	SubmitIndex        uint32
	CommandBufferIndex uint32
}

type ExternalImageData

type ExternalImageData struct {
	Image              VkImage
	BarrierRange       VkImageSubresourceRange
	OldLayout          VkImageLayout
	NewLayout          VkImageLayout
	SubmitIndex        uint32
	CommandBufferIndex uint32
	CopyRanges         []ExternalImageDataRange
}

type ExternalImageDataRange

type ExternalImageDataRange struct {
	DataOffset  VkDeviceSize
	Subresource VkImageSubresourceLayers
}

type ExternalMemoryData

type ExternalMemoryData struct {
	ID      id.ID
	Size    VkDeviceSize
	Buffers []ExternalBufferData
	Images  []ExternalImageData
}

func GetExternalMemoryData

func GetExternalMemoryData(e *api.CmdExtras) *ExternalMemoryData

ExternalMemoryData returns a pointer to the ExternalMemoryData structure in the CmdExtras, or nil if there are no observations in the CmdExtras.

type InsertionCommand

type InsertionCommand struct {
	// contains filtered or unexported fields
}

InsertionCommand is a temporary command that is expected to be replaced by a down-stream transform.

func (*InsertionCommand) API

func (s *InsertionCommand) API() api.API

func (*InsertionCommand) Alive

func (s *InsertionCommand) Alive() bool

func (*InsertionCommand) Caller

func (s *InsertionCommand) Caller() api.CmdID

func (*InsertionCommand) Clone

func (s *InsertionCommand) Clone(a arena.Arena) api.Cmd

func (*InsertionCommand) CmdFlags

func (*InsertionCommand) CmdName

func (s *InsertionCommand) CmdName() string

CmdName returns the name of the command.

func (*InsertionCommand) CmdParams

func (s *InsertionCommand) CmdParams() api.Properties

func (*InsertionCommand) CmdResult

func (s *InsertionCommand) CmdResult() *api.Property

func (*InsertionCommand) Extras

func (s *InsertionCommand) Extras() *api.CmdExtras

func (*InsertionCommand) Mutate

func (*InsertionCommand) SetCaller

func (s *InsertionCommand) SetCaller(c api.CmdID)

func (*InsertionCommand) SetTerminated

func (s *InsertionCommand) SetTerminated(bool)

func (*InsertionCommand) SetThread

func (s *InsertionCommand) SetThread(c uint64)

func (*InsertionCommand) Terminated

func (s *InsertionCommand) Terminated() bool

func (*InsertionCommand) Thread

func (s *InsertionCommand) Thread() uint64

type MarkerType

type MarkerType int

type SemaphoreState

type SemaphoreState struct {
	// contains filtered or unexported fields
}

type VulkanContext

type VulkanContext struct{}

func (VulkanContext) API

func (VulkanContext) API() api.API

API returns the vulkan API.

func (VulkanContext) ID

ID returns the context's unique identifier.

func (VulkanContext) Name

func (VulkanContext) Name() string

Name returns the display-name of the context.

type VulkanTerminator

type VulkanTerminator struct {
	// contains filtered or unexported fields
}

VulkanTerminator is very similar to EarlyTerminator. It has 2 additional properties.

  1. If a VkQueueSubmit is found, and it contains an event that will be signaled after the final request, we remove the event from the command-list, and remove any subsequent events
  2. If a request is made to replay until the MIDDLE of a vkQueueSubmit, then it will patch that command-list to remove any commands after the command in question. Furthermore it will continue the replay until that command can be run i.e. it will make sure to continue to mutate the trace until all pending events have been successfully completed. TODO(awoloszyn): Handle #2

This takes advantage of the fact that all commands will be in order.

func NewVulkanTerminator

func NewVulkanTerminator(ctx context.Context, capture *path.Capture) (*VulkanTerminator, error)

func (*VulkanTerminator) Add

func (t *VulkanTerminator) Add(ctx context.Context, id api.CmdID, subcommand api.SubCmdIdx) error

Add adds the command with identifier id to the set of commands that must be seen before the VulkanTerminator will consume all commands (excluding the EOS command).

func (*VulkanTerminator) BuffersCommands

func (t *VulkanTerminator) BuffersCommands() bool

func (*VulkanTerminator) Flush

func (*VulkanTerminator) PostLoop

func (t *VulkanTerminator) PostLoop(ctx context.Context, output transform.Writer)

func (*VulkanTerminator) PreLoop

func (t *VulkanTerminator) PreLoop(ctx context.Context, output transform.Writer)

func (*VulkanTerminator) Transform

func (t *VulkanTerminator) Transform(ctx context.Context, id api.CmdID, cmd api.Cmd, out transform.Writer) error

type WaitForPerfetto

type WaitForPerfetto struct {
	// contains filtered or unexported fields
}

func NewWaitForPerfetto

func NewWaitForPerfetto(traceOptions *service.TraceOptions, h *replay.SignalHandler, buffer *bytes.Buffer, cmdId api.CmdID) *WaitForPerfetto

func (*WaitForPerfetto) BuffersCommands

func (t *WaitForPerfetto) BuffersCommands() bool

func (*WaitForPerfetto) Flush

func (t *WaitForPerfetto) Flush(ctx context.Context, out transform.Writer) error

func (*WaitForPerfetto) PostLoop

func (t *WaitForPerfetto) PostLoop(ctx context.Context, out transform.Writer)

func (*WaitForPerfetto) PreLoop

func (t *WaitForPerfetto) PreLoop(ctx context.Context, out transform.Writer)

func (*WaitForPerfetto) Transform

func (t *WaitForPerfetto) Transform(ctx context.Context, id api.CmdID, cmd api.Cmd, out transform.Writer) error

Directories

Path Synopsis
Package vulkan_pb describes the serialization format for the vulkan api.
Package vulkan_pb describes the serialization format for the vulkan api.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL