Commit afa49b18 authored by Georg Lehmann's avatar Georg Lehmann Committed by Alexandre Julliard

winevulkan: Fix bit field struct members.

parent 2aeab85c
...@@ -1078,7 +1078,7 @@ class VkHandle(object): ...@@ -1078,7 +1078,7 @@ class VkHandle(object):
class VkMember(object): class VkMember(object):
def __init__(self, const=False, struct_fwd_decl=False,_type=None, pointer=None, name=None, array_len=None, def __init__(self, const=False, struct_fwd_decl=False,_type=None, pointer=None, name=None, array_len=None,
dyn_array_len=None, optional=False, values=None, object_type=None): dyn_array_len=None, optional=False, values=None, object_type=None, bit_width=None):
self.const = const self.const = const
self.struct_fwd_decl = struct_fwd_decl self.struct_fwd_decl = struct_fwd_decl
self.name = name self.name = name
...@@ -1090,6 +1090,7 @@ class VkMember(object): ...@@ -1090,6 +1090,7 @@ class VkMember(object):
self.optional = optional self.optional = optional
self.values = values self.values = values
self.object_type = object_type self.object_type = object_type
self.bit_width = bit_width
def __eq__(self, other): def __eq__(self, other):
""" Compare member based on name against a string. """ Compare member based on name against a string.
...@@ -1116,6 +1117,7 @@ class VkMember(object): ...@@ -1116,6 +1117,7 @@ class VkMember(object):
member_type = None member_type = None
pointer = None pointer = None
array_len = None array_len = None
bit_width = None
values = member.get("values") values = member.get("values")
...@@ -1161,8 +1163,14 @@ class VkMember(object): ...@@ -1161,8 +1163,14 @@ class VkMember(object):
object_type = member.get("objecttype", None) object_type = member.get("objecttype", None)
# Some members are bit field values:
# <member><type>uint32_t</type> <name>mask</name>:8</member>
if name_elem.tail and name_elem.tail[0] == ':':
LOGGER.debug("Found bit field")
bit_width = int(name_elem.tail[1:])
return VkMember(const=const, struct_fwd_decl=struct_fwd_decl, _type=member_type, pointer=pointer, name=name_elem.text, return VkMember(const=const, struct_fwd_decl=struct_fwd_decl, _type=member_type, pointer=pointer, name=name_elem.text,
array_len=array_len, dyn_array_len=dyn_array_len, optional=optional, values=values, object_type=object_type) array_len=array_len, dyn_array_len=dyn_array_len, optional=optional, values=values, object_type=object_type, bit_width=bit_width)
def copy(self, input, output, direction, conv): def copy(self, input, output, direction, conv):
""" Helper method for use by conversion logic to generate a C-code statement to copy this member. """ Helper method for use by conversion logic to generate a C-code statement to copy this member.
...@@ -1267,6 +1275,9 @@ class VkMember(object): ...@@ -1267,6 +1275,9 @@ class VkMember(object):
if self.is_static_array(): if self.is_static_array():
text += "[{0}]".format(self.array_len) text += "[{0}]".format(self.array_len)
if self.is_bit_field():
text += ":{}".format(self.bit_width)
return text return text
def get_conversions(self): def get_conversions(self):
...@@ -1344,6 +1355,9 @@ class VkMember(object): ...@@ -1344,6 +1355,9 @@ class VkMember(object):
return self.object_type != None and self.type == "uint64_t" return self.object_type != None and self.type == "uint64_t"
def is_bit_field(self):
return self.bit_width is not None
def needs_alignment(self): def needs_alignment(self):
""" Check if this member needs alignment for 64-bit data. """ Check if this member needs alignment for 64-bit data.
Various structures need alignment on 64-bit variables due Various structures need alignment on 64-bit variables due
......
...@@ -5752,10 +5752,10 @@ typedef struct VkAccelerationStructureGeometryMotionTrianglesDataNV ...@@ -5752,10 +5752,10 @@ typedef struct VkAccelerationStructureGeometryMotionTrianglesDataNV
typedef struct VkAccelerationStructureInstanceKHR typedef struct VkAccelerationStructureInstanceKHR
{ {
VkTransformMatrixKHR transform; VkTransformMatrixKHR transform;
uint32_t instanceCustomIndex; uint32_t instanceCustomIndex:24;
uint32_t mask; uint32_t mask:8;
uint32_t instanceShaderBindingTableRecordOffset; uint32_t instanceShaderBindingTableRecordOffset:24;
VkGeometryInstanceFlagsKHR flags; VkGeometryInstanceFlagsKHR flags:8;
uint64_t WINE_VK_ALIGN(8) accelerationStructureReference; uint64_t WINE_VK_ALIGN(8) accelerationStructureReference;
} VkAccelerationStructureInstanceKHR; } VkAccelerationStructureInstanceKHR;
typedef VkAccelerationStructureInstanceKHR VkAccelerationStructureInstanceNV; typedef VkAccelerationStructureInstanceKHR VkAccelerationStructureInstanceNV;
...@@ -5772,10 +5772,10 @@ typedef struct VkAccelerationStructureSRTMotionInstanceNV ...@@ -5772,10 +5772,10 @@ typedef struct VkAccelerationStructureSRTMotionInstanceNV
{ {
VkSRTDataNV transformT0; VkSRTDataNV transformT0;
VkSRTDataNV transformT1; VkSRTDataNV transformT1;
uint32_t instanceCustomIndex; uint32_t instanceCustomIndex:24;
uint32_t mask; uint32_t mask:8;
uint32_t instanceShaderBindingTableRecordOffset; uint32_t instanceShaderBindingTableRecordOffset:24;
VkGeometryInstanceFlagsKHR flags; VkGeometryInstanceFlagsKHR flags:8;
uint64_t WINE_VK_ALIGN(8) accelerationStructureReference; uint64_t WINE_VK_ALIGN(8) accelerationStructureReference;
} VkAccelerationStructureSRTMotionInstanceNV; } VkAccelerationStructureSRTMotionInstanceNV;
...@@ -7033,10 +7033,10 @@ typedef struct VkAccelerationStructureMatrixMotionInstanceNV ...@@ -7033,10 +7033,10 @@ typedef struct VkAccelerationStructureMatrixMotionInstanceNV
{ {
VkTransformMatrixKHR transformT0; VkTransformMatrixKHR transformT0;
VkTransformMatrixKHR transformT1; VkTransformMatrixKHR transformT1;
uint32_t instanceCustomIndex; uint32_t instanceCustomIndex:24;
uint32_t mask; uint32_t mask:8;
uint32_t instanceShaderBindingTableRecordOffset; uint32_t instanceShaderBindingTableRecordOffset:24;
VkGeometryInstanceFlagsKHR flags; VkGeometryInstanceFlagsKHR flags:8;
uint64_t WINE_VK_ALIGN(8) accelerationStructureReference; uint64_t WINE_VK_ALIGN(8) accelerationStructureReference;
} VkAccelerationStructureMatrixMotionInstanceNV; } VkAccelerationStructureMatrixMotionInstanceNV;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment