struct ExternalTextureParams { uint numPlanes; float3x4 yuvToRgbConversionMatrix; }; Texture2D ext_tex_plane_1 : register(t1, space1); cbuffer cbuffer_ext_tex_params : register(b2, space1) { uint4 ext_tex_params[4]; }; Texture2D arg_0 : register(t0, space1); float4 textureLoadExternal(Texture2D plane0, Texture2D plane1, int2 coord, ExternalTextureParams params) { float3 color = float3(0.0f, 0.0f, 0.0f); if ((params.numPlanes == 1u)) { color = plane0.Load(int3(coord, 0)).rgb; } else { color = mul(params.yuvToRgbConversionMatrix, float4(plane0.Load(int3(coord, 0)).r, plane1.Load(int3(coord, 0)).rg, 1.0f)); } return float4(color, 1.0f); } float4 textureLoad2d(Texture2D tint_symbol, Texture2D ext_tex_plane_1_1, ExternalTextureParams ext_tex_params_1, int2 coords) { return textureLoadExternal(tint_symbol, ext_tex_plane_1_1, coords, ext_tex_params_1); } float3x4 tint_symbol_4(uint4 buffer[4], uint offset) { const uint scalar_offset = ((offset + 0u)) / 4; const uint scalar_offset_1 = ((offset + 16u)) / 4; const uint scalar_offset_2 = ((offset + 32u)) / 4; return float3x4(asfloat(buffer[scalar_offset / 4]), asfloat(buffer[scalar_offset_1 / 4]), asfloat(buffer[scalar_offset_2 / 4])); } ExternalTextureParams tint_symbol_2(uint4 buffer[4], uint offset) { const uint scalar_offset_3 = ((offset + 0u)) / 4; const ExternalTextureParams tint_symbol_6 = {buffer[scalar_offset_3 / 4][scalar_offset_3 % 4], tint_symbol_4(buffer, (offset + 16u))}; return tint_symbol_6; } void doTextureLoad() { float4 res = textureLoad2d(arg_0, ext_tex_plane_1, tint_symbol_2(ext_tex_params, 0u), int2(0, 0)); } struct tint_symbol_1 { float4 value : SV_Position; }; float4 vertex_main_inner() { doTextureLoad(); return float4(0.0f, 0.0f, 0.0f, 0.0f); } tint_symbol_1 vertex_main() { const float4 inner_result = vertex_main_inner(); tint_symbol_1 wrapper_result = (tint_symbol_1)0; wrapper_result.value = inner_result; return wrapper_result; } void fragment_main() { doTextureLoad(); return; } [numthreads(1, 1, 1)] void compute_main() { doTextureLoad(); return; }