f1b411c9e8
This is somewhat awkward to support, but the best effort we can do here is to analyze various Load/Store opcodes and deduce the ideal overall alignment based on this. This is not a 100% perfect solution, but should be correct for any reasonable use case. Also fix various nitpicks with BDA support while I'm at it.
27 lines
524 B
Plaintext
27 lines
524 B
Plaintext
#version 450
|
|
#extension GL_EXT_buffer_reference : require
|
|
layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
|
|
|
|
layout(buffer_reference) buffer PtrUint;
|
|
layout(buffer_reference) buffer PtrInt;
|
|
layout(buffer_reference, buffer_reference_align = 4, std430) buffer PtrUint
|
|
{
|
|
uint value;
|
|
};
|
|
|
|
layout(buffer_reference, buffer_reference_align = 16, std430) buffer PtrInt
|
|
{
|
|
int value;
|
|
};
|
|
|
|
layout(set = 0, binding = 0, std430) buffer Buf
|
|
{
|
|
PtrUint ptr;
|
|
} _11;
|
|
|
|
void main()
|
|
{
|
|
PtrInt(_11.ptr).value = 10;
|
|
}
|
|
|