Merge pull request #879 from KhronosGroup/fix-878
MSL: Emit proper name for optimized UBO/SSBO arrays.
This commit is contained in:
commit
6f50806698
@ -0,0 +1,48 @@
|
|||||||
|
#include <metal_stdlib>
|
||||||
|
#include <simd/simd.h>
|
||||||
|
|
||||||
|
using namespace metal;
|
||||||
|
|
||||||
|
struct _4
|
||||||
|
{
|
||||||
|
float4 _m0;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _6
|
||||||
|
{
|
||||||
|
int _m0;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _7
|
||||||
|
{
|
||||||
|
float4 _m0;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct main0_out
|
||||||
|
{
|
||||||
|
float4 m_3 [[color(0)]];
|
||||||
|
};
|
||||||
|
|
||||||
|
fragment main0_out main0(constant _6& _20 [[buffer(0)]], constant _7* _8_0 [[buffer(1)]], constant _7* _8_1 [[buffer(2)]], constant _7* _8_2 [[buffer(3)]], constant _7* _8_3 [[buffer(4)]], const device _4* _5_0 [[buffer(5)]], const device _4* _5_1 [[buffer(6)]], const device _4* _5_2 [[buffer(7)]], const device _4* _5_3 [[buffer(8)]])
|
||||||
|
{
|
||||||
|
constant _7* _8[] =
|
||||||
|
{
|
||||||
|
_8_0,
|
||||||
|
_8_1,
|
||||||
|
_8_2,
|
||||||
|
_8_3,
|
||||||
|
};
|
||||||
|
|
||||||
|
const device _4* _5[] =
|
||||||
|
{
|
||||||
|
_5_0,
|
||||||
|
_5_1,
|
||||||
|
_5_2,
|
||||||
|
_5_3,
|
||||||
|
};
|
||||||
|
|
||||||
|
main0_out out = {};
|
||||||
|
out.m_3 = _5[_20._m0]->_m0 + (_8[_20._m0]->_m0 * float4(0.20000000298023223876953125));
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,48 @@
|
|||||||
|
#include <metal_stdlib>
|
||||||
|
#include <simd/simd.h>
|
||||||
|
|
||||||
|
using namespace metal;
|
||||||
|
|
||||||
|
struct _4
|
||||||
|
{
|
||||||
|
float4 _m0;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _6
|
||||||
|
{
|
||||||
|
int _m0;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _7
|
||||||
|
{
|
||||||
|
float4 _m0;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct main0_out
|
||||||
|
{
|
||||||
|
float4 m_3 [[color(0)]];
|
||||||
|
};
|
||||||
|
|
||||||
|
fragment main0_out main0(constant _6& _20 [[buffer(0)]], constant _7* _8_0 [[buffer(1)]], constant _7* _8_1 [[buffer(2)]], constant _7* _8_2 [[buffer(3)]], constant _7* _8_3 [[buffer(4)]], const device _4* _5_0 [[buffer(5)]], const device _4* _5_1 [[buffer(6)]], const device _4* _5_2 [[buffer(7)]], const device _4* _5_3 [[buffer(8)]])
|
||||||
|
{
|
||||||
|
constant _7* _8[] =
|
||||||
|
{
|
||||||
|
_8_0,
|
||||||
|
_8_1,
|
||||||
|
_8_2,
|
||||||
|
_8_3,
|
||||||
|
};
|
||||||
|
|
||||||
|
const device _4* _5[] =
|
||||||
|
{
|
||||||
|
_5_0,
|
||||||
|
_5_1,
|
||||||
|
_5_2,
|
||||||
|
_5_3,
|
||||||
|
};
|
||||||
|
|
||||||
|
main0_out out = {};
|
||||||
|
out.m_3 = _5[_20._m0]->_m0 + (_8[_20._m0]->_m0 * float4(0.20000000298023223876953125));
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
63
shaders-msl/asm/frag/descriptor-array-unnamed.asm.frag
Normal file
63
shaders-msl/asm/frag/descriptor-array-unnamed.asm.frag
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
; SPIR-V
|
||||||
|
; Version: 1.0
|
||||||
|
; Generator: Khronos Glslang Reference Front End; 7
|
||||||
|
; Bound: 39
|
||||||
|
; Schema: 0
|
||||||
|
OpCapability Shader
|
||||||
|
%1 = OpExtInstImport "GLSL.std.450"
|
||||||
|
OpMemoryModel Logical GLSL450
|
||||||
|
OpEntryPoint Fragment %main "main" %FragColor
|
||||||
|
OpExecutionMode %main OriginUpperLeft
|
||||||
|
OpSource GLSL 450
|
||||||
|
OpDecorate %FragColor Location 0
|
||||||
|
OpMemberDecorate %SSBO 0 NonWritable
|
||||||
|
OpMemberDecorate %SSBO 0 Offset 0
|
||||||
|
OpDecorate %SSBO BufferBlock
|
||||||
|
OpDecorate %ssbos DescriptorSet 0
|
||||||
|
OpDecorate %ssbos Binding 5
|
||||||
|
OpMemberDecorate %Registers 0 Offset 0
|
||||||
|
OpDecorate %Registers Block
|
||||||
|
OpMemberDecorate %UBO 0 Offset 0
|
||||||
|
OpDecorate %UBO Block
|
||||||
|
OpDecorate %ubos DescriptorSet 0
|
||||||
|
OpDecorate %ubos Binding 1
|
||||||
|
%void = OpTypeVoid
|
||||||
|
%3 = OpTypeFunction %void
|
||||||
|
%float = OpTypeFloat 32
|
||||||
|
%v4float = OpTypeVector %float 4
|
||||||
|
%_ptr_Output_v4float = OpTypePointer Output %v4float
|
||||||
|
%FragColor = OpVariable %_ptr_Output_v4float Output
|
||||||
|
%SSBO = OpTypeStruct %v4float
|
||||||
|
%uint = OpTypeInt 32 0
|
||||||
|
%uint_4 = OpConstant %uint 4
|
||||||
|
%_arr_SSBO_uint_4 = OpTypeArray %SSBO %uint_4
|
||||||
|
%_ptr_Uniform__arr_SSBO_uint_4 = OpTypePointer Uniform %_arr_SSBO_uint_4
|
||||||
|
%ssbos = OpVariable %_ptr_Uniform__arr_SSBO_uint_4 Uniform
|
||||||
|
%int = OpTypeInt 32 1
|
||||||
|
%Registers = OpTypeStruct %int
|
||||||
|
%_ptr_PushConstant_Registers = OpTypePointer PushConstant %Registers
|
||||||
|
%registers = OpVariable %_ptr_PushConstant_Registers PushConstant
|
||||||
|
%int_0 = OpConstant %int 0
|
||||||
|
%_ptr_PushConstant_int = OpTypePointer PushConstant %int
|
||||||
|
%_ptr_Uniform_v4float = OpTypePointer Uniform %v4float
|
||||||
|
%UBO = OpTypeStruct %v4float
|
||||||
|
%_arr_UBO_uint_4 = OpTypeArray %UBO %uint_4
|
||||||
|
%_ptr_Uniform__arr_UBO_uint_4 = OpTypePointer Uniform %_arr_UBO_uint_4
|
||||||
|
%ubos = OpVariable %_ptr_Uniform__arr_UBO_uint_4 Uniform
|
||||||
|
%float_0_200000003 = OpConstant %float 0.200000003
|
||||||
|
%36 = OpConstantComposite %v4float %float_0_200000003 %float_0_200000003 %float_0_200000003 %float_0_200000003
|
||||||
|
%main = OpFunction %void None %3
|
||||||
|
%5 = OpLabel
|
||||||
|
%22 = OpAccessChain %_ptr_PushConstant_int %registers %int_0
|
||||||
|
%23 = OpLoad %int %22
|
||||||
|
%25 = OpAccessChain %_ptr_Uniform_v4float %ssbos %23 %int_0
|
||||||
|
%26 = OpLoad %v4float %25
|
||||||
|
%31 = OpAccessChain %_ptr_PushConstant_int %registers %int_0
|
||||||
|
%32 = OpLoad %int %31
|
||||||
|
%33 = OpAccessChain %_ptr_Uniform_v4float %ubos %32 %int_0
|
||||||
|
%34 = OpLoad %v4float %33
|
||||||
|
%37 = OpFMul %v4float %34 %36
|
||||||
|
%38 = OpFAdd %v4float %26 %37
|
||||||
|
OpStore %FragColor %38
|
||||||
|
OpReturn
|
||||||
|
OpFunctionEnd
|
@ -560,7 +560,7 @@ void CompilerMSL::emit_entry_point_declarations()
|
|||||||
{
|
{
|
||||||
const auto &var = get<SPIRVariable>(array_id);
|
const auto &var = get<SPIRVariable>(array_id);
|
||||||
const auto &type = get_variable_data_type(var);
|
const auto &type = get_variable_data_type(var);
|
||||||
string name = get_name(array_id);
|
string name = to_name(array_id);
|
||||||
statement(get_argument_address_space(var) + " " + type_to_glsl(type) + "* " + name + "[] =");
|
statement(get_argument_address_space(var) + " " + type_to_glsl(type) + "* " + name + "[] =");
|
||||||
begin_scope();
|
begin_scope();
|
||||||
for (uint32_t i = 0; i < type.array[0]; ++i)
|
for (uint32_t i = 0; i < type.array[0]; ++i)
|
||||||
|
Loading…
Reference in New Issue
Block a user