Package org.lwjgl.vulkan
Class VkPhysicalDeviceBufferDeviceAddressFeatures
java.lang.Object
org.lwjgl.system.Pointer.Default
org.lwjgl.system.Struct<VkPhysicalDeviceBufferDeviceAddressFeatures>
org.lwjgl.vulkan.VkPhysicalDeviceBufferDeviceAddressFeatures
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkPhysicalDeviceBufferDeviceAddressFeaturesKHR
public class VkPhysicalDeviceBufferDeviceAddressFeatures
extends org.lwjgl.system.Struct<VkPhysicalDeviceBufferDeviceAddressFeatures>
implements org.lwjgl.system.NativeResource
Structure describing buffer address features that can be supported by an implementation.
Description
Note
bufferDeviceAddressMultiDevice exists to allow certain legacy platforms to be able to support bufferDeviceAddress without needing to support shared GPU virtual addresses for multi-device configurations.
See GetBufferDeviceAddress for more information.
If the VkPhysicalDeviceBufferDeviceAddressFeatures structure is included in the pNext chain of the VkPhysicalDeviceFeatures2 structure passed to GetPhysicalDeviceFeatures2, it is filled in to indicate whether each corresponding feature is supported. VkPhysicalDeviceBufferDeviceAddressFeatures can also be used in the pNext chain of VkDeviceCreateInfo to selectively enable these features.
Valid Usage (Implicit)
Layout
struct VkPhysicalDeviceBufferDeviceAddressFeatures {
VkStructureType sType();
void * pNext();
VkBool32 bufferDeviceAddress();
VkBool32 bufferDeviceAddressCaptureReplay();
VkBool32 bufferDeviceAddressMultiDevice();
}-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn array ofVkPhysicalDeviceBufferDeviceAddressFeaturesstructs.Nested classes/interfaces inherited from class org.lwjgl.system.Struct
org.lwjgl.system.Struct.StructValidationNested classes/interfaces inherited from interface org.lwjgl.system.Pointer
org.lwjgl.system.Pointer.Default -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intThe struct alignment in bytes.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct size in bytes.static final intThe struct member offsets.Fields inherited from interface org.lwjgl.system.Pointer
BITS32, BITS64, CLONG_SHIFT, CLONG_SIZE, POINTER_SHIFT, POINTER_SIZE -
Constructor Summary
ConstructorsConstructorDescriptionCreates aVkPhysicalDeviceBufferDeviceAddressFeaturesinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptionbooleanindicates that the implementation supports accessing buffer memory in shaders as storage buffers via an address queried fromGetBufferDeviceAddress.bufferDeviceAddress(boolean value) Sets the specified value to thebufferDeviceAddress()field.booleanindicates that the implementation supports saving and reusing buffer and device addresses, e.g.bufferDeviceAddressCaptureReplay(boolean value) Sets the specified value to thebufferDeviceAddressCaptureReplay()field.booleanindicates that the implementation supports thebufferDeviceAddress,rayTracingPipelineandrayQueryfeatures for logical devices created with multiple physical devices.bufferDeviceAddressMultiDevice(boolean value) Sets the specified value to thebufferDeviceAddressMultiDevice()field.calloc()Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.create()Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated withBufferUtils.create(int capacity) Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance for the specified memory address.create(long address, int capacity) Create aVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance at the specified memory.static @Nullable VkPhysicalDeviceBufferDeviceAddressFeaturescreateSafe(long address) static @Nullable VkPhysicalDeviceBufferDeviceAddressFeatures.BuffercreateSafe(long address, int capacity) malloc()Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated on the specifiedMemoryStack.static intnbufferDeviceAddress(long struct) Unsafe version ofbufferDeviceAddress().static voidnbufferDeviceAddress(long struct, int value) Unsafe version ofbufferDeviceAddress.static intnbufferDeviceAddressCaptureReplay(long struct) Unsafe version ofbufferDeviceAddressCaptureReplay().static voidnbufferDeviceAddressCaptureReplay(long struct, int value) Unsafe version ofbufferDeviceAddressCaptureReplay.static intnbufferDeviceAddressMultiDevice(long struct) Unsafe version ofbufferDeviceAddressMultiDevice().static voidnbufferDeviceAddressMultiDevice(long struct, int value) Unsafe version ofbufferDeviceAddressMultiDevice.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.set(int sType, long pNext, boolean bufferDeviceAddress, boolean bufferDeviceAddressCaptureReplay, boolean bufferDeviceAddressMultiDevice) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_PHYSICAL_DEVICE_BUFFER_DEVICE_ADDRESS_FEATURESvalue to thesType()field.Methods inherited from class org.lwjgl.system.Struct
clear, free, isNull, validate, validateMethods inherited from class org.lwjgl.system.Pointer.Default
address, equals, hashCode, toStringMethods inherited from interface org.lwjgl.system.NativeResource
close, free
-
Field Details
-
SIZEOF
public static final int SIZEOFThe struct size in bytes. -
ALIGNOF
public static final int ALIGNOFThe struct alignment in bytes. -
STYPE
public static final int STYPEThe struct member offsets. -
PNEXT
public static final int PNEXTThe struct member offsets. -
BUFFERDEVICEADDRESS
public static final int BUFFERDEVICEADDRESSThe struct member offsets. -
BUFFERDEVICEADDRESSCAPTUREREPLAY
public static final int BUFFERDEVICEADDRESSCAPTUREREPLAYThe struct member offsets. -
BUFFERDEVICEADDRESSMULTIDEVICE
public static final int BUFFERDEVICEADDRESSMULTIDEVICEThe struct member offsets.
-
-
Constructor Details
-
VkPhysicalDeviceBufferDeviceAddressFeatures
Creates aVkPhysicalDeviceBufferDeviceAddressFeaturesinstance at the current position of the specifiedByteBuffercontainer. Changes to the buffer's content will be visible to the struct instance and vice versa.The created instance holds a strong reference to the container object.
-
-
Method Details
-
sizeof
public int sizeof()- Specified by:
sizeofin classorg.lwjgl.system.Struct<VkPhysicalDeviceBufferDeviceAddressFeatures>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
bufferDeviceAddress
public boolean bufferDeviceAddress()indicates that the implementation supports accessing buffer memory in shaders as storage buffers via an address queried fromGetBufferDeviceAddress. -
bufferDeviceAddressCaptureReplay
public boolean bufferDeviceAddressCaptureReplay()indicates that the implementation supports saving and reusing buffer and device addresses, e.g. for trace capture and replay. -
bufferDeviceAddressMultiDevice
public boolean bufferDeviceAddressMultiDevice()indicates that the implementation supports thebufferDeviceAddress,rayTracingPipelineandrayQueryfeatures for logical devices created with multiple physical devices. If this feature is not supported, buffer and acceleration structure addresses must not be queried on a logical device created with more than one physical device. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_PHYSICAL_DEVICE_BUFFER_DEVICE_ADDRESS_FEATURESvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
bufferDeviceAddress
Sets the specified value to thebufferDeviceAddress()field. -
bufferDeviceAddressCaptureReplay
Sets the specified value to thebufferDeviceAddressCaptureReplay()field. -
bufferDeviceAddressMultiDevice
Sets the specified value to thebufferDeviceAddressMultiDevice()field. -
set
public VkPhysicalDeviceBufferDeviceAddressFeatures set(int sType, long pNext, boolean bufferDeviceAddress, boolean bufferDeviceAddressCaptureReplay, boolean bufferDeviceAddressMultiDevice) Initializes this struct with the specified values. -
set
public VkPhysicalDeviceBufferDeviceAddressFeatures set(VkPhysicalDeviceBufferDeviceAddressFeatures src) Copies the specified struct data to this struct.- Parameters:
src- the source struct- Returns:
- this struct
-
malloc
Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated withBufferUtils. -
create
Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
public static @Nullable VkPhysicalDeviceBufferDeviceAddressFeatures.Buffer createSafe(long address, int capacity) -
malloc
public static VkPhysicalDeviceBufferDeviceAddressFeatures malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
public static VkPhysicalDeviceBufferDeviceAddressFeatures calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeaturesinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkPhysicalDeviceBufferDeviceAddressFeatures.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkPhysicalDeviceBufferDeviceAddressFeatures.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPhysicalDeviceBufferDeviceAddressFeatures.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
nsType
public static int nsType(long struct) Unsafe version ofsType(). -
npNext
public static long npNext(long struct) Unsafe version ofpNext(). -
nbufferDeviceAddress
public static int nbufferDeviceAddress(long struct) Unsafe version ofbufferDeviceAddress(). -
nbufferDeviceAddressCaptureReplay
public static int nbufferDeviceAddressCaptureReplay(long struct) Unsafe version ofbufferDeviceAddressCaptureReplay(). -
nbufferDeviceAddressMultiDevice
public static int nbufferDeviceAddressMultiDevice(long struct) Unsafe version ofbufferDeviceAddressMultiDevice(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
nbufferDeviceAddress
public static void nbufferDeviceAddress(long struct, int value) Unsafe version ofbufferDeviceAddress. -
nbufferDeviceAddressCaptureReplay
public static void nbufferDeviceAddressCaptureReplay(long struct, int value) Unsafe version ofbufferDeviceAddressCaptureReplay. -
nbufferDeviceAddressMultiDevice
public static void nbufferDeviceAddressMultiDevice(long struct, int value) Unsafe version ofbufferDeviceAddressMultiDevice.
-