struct GammaTransferParams { float G; float A; float B; float C; float D; float E; float F; uint padding; }; struct ExternalTextureParams { uint numPlanes; uint doYuvToRgbConversionOnly; float3x4 yuvToRgbConversionMatrix; GammaTransferParams gammaDecodeParams; GammaTransferParams gammaEncodeParams; float3x3 gamutConversionMatrix; float3x2 coordTransformationMatrix; }; Texture2D ext_tex_plane_1 : register(t2, space1); cbuffer cbuffer_ext_tex_params : register(b3, space1) { uint4 ext_tex_params[13]; }; Texture2D arg_0 : register(t0, space1); SamplerState arg_1 : register(s1, space1); float3 gammaCorrection(float3 v, GammaTransferParams params) { const bool3 cond = (abs(v) < float3((params.D).xxx)); const float3 t = (float3(sign(v)) * ((params.C * abs(v)) + params.F)); const float3 f = (float3(sign(v)) * (pow(((params.A * abs(v)) + params.B), float3((params.G).xxx)) + params.E)); return (cond ? t : f); } float4 textureSampleExternal(Texture2D plane0, Texture2D plane1, SamplerState smp, float2 coord, ExternalTextureParams params) { const float2 modifiedCoords = mul(float3(coord, 1.0f), params.coordTransformationMatrix); int3 tint_tmp; plane0.GetDimensions(0, tint_tmp.x, tint_tmp.y, tint_tmp.z); const float2 plane0_dims = float2(tint_tmp.xy); const float2 plane0_half_texel = ((0.5f).xx / plane0_dims); const float2 plane0_clamped = clamp(modifiedCoords, plane0_half_texel, (1.0f - plane0_half_texel)); int3 tint_tmp_1; plane1.GetDimensions(0, tint_tmp_1.x, tint_tmp_1.y, tint_tmp_1.z); const float2 plane1_dims = float2(tint_tmp_1.xy); const float2 plane1_half_texel = ((0.5f).xx / plane1_dims); const float2 plane1_clamped = clamp(modifiedCoords, plane1_half_texel, (1.0f - plane1_half_texel)); float3 color = float3(0.0f, 0.0f, 0.0f); if ((params.numPlanes == 1u)) { color = plane0.SampleLevel(smp, plane0_clamped, 0.0f).rgb; } else { color = mul(params.yuvToRgbConversionMatrix, float4(plane0.SampleLevel(smp, plane0_clamped, 0.0f).r, plane1.SampleLevel(smp, plane1_clamped, 0.0f).rg, 1.0f)); } if ((params.doYuvToRgbConversionOnly == 0u)) { color = gammaCorrection(color, params.gammaDecodeParams); color = mul(color, params.gamutConversionMatrix); color = gammaCorrection(color, params.gammaEncodeParams); } return float4(color, 1.0f); } float3x4 ext_tex_params_load_2(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(ext_tex_params[scalar_offset / 4]), asfloat(ext_tex_params[scalar_offset_1 / 4]), asfloat(ext_tex_params[scalar_offset_2 / 4])); } GammaTransferParams ext_tex_params_load_4(uint offset) { const uint scalar_offset_3 = ((offset + 0u)) / 4; const uint scalar_offset_4 = ((offset + 4u)) / 4; const uint scalar_offset_5 = ((offset + 8u)) / 4; const uint scalar_offset_6 = ((offset + 12u)) / 4; const uint scalar_offset_7 = ((offset + 16u)) / 4; const uint scalar_offset_8 = ((offset + 20u)) / 4; const uint scalar_offset_9 = ((offset + 24u)) / 4; const uint scalar_offset_10 = ((offset + 28u)) / 4; const GammaTransferParams tint_symbol_1 = {asfloat(ext_tex_params[scalar_offset_3 / 4][scalar_offset_3 % 4]), asfloat(ext_tex_params[scalar_offset_4 / 4][scalar_offset_4 % 4]), asfloat(ext_tex_params[scalar_offset_5 / 4][scalar_offset_5 % 4]), asfloat(ext_tex_params[scalar_offset_6 / 4][scalar_offset_6 % 4]), asfloat(ext_tex_params[scalar_offset_7 / 4][scalar_offset_7 % 4]), asfloat(ext_tex_params[scalar_offset_8 / 4][scalar_offset_8 % 4]), asfloat(ext_tex_params[scalar_offset_9 / 4][scalar_offset_9 % 4]), ext_tex_params[scalar_offset_10 / 4][scalar_offset_10 % 4]}; return tint_symbol_1; } float3x3 ext_tex_params_load_6(uint offset) { const uint scalar_offset_11 = ((offset + 0u)) / 4; const uint scalar_offset_12 = ((offset + 16u)) / 4; const uint scalar_offset_13 = ((offset + 32u)) / 4; return float3x3(asfloat(ext_tex_params[scalar_offset_11 / 4].xyz), asfloat(ext_tex_params[scalar_offset_12 / 4].xyz), asfloat(ext_tex_params[scalar_offset_13 / 4].xyz)); } float3x2 ext_tex_params_load_8(uint offset) { const uint scalar_offset_14 = ((offset + 0u)) / 4; uint4 ubo_load = ext_tex_params[scalar_offset_14 / 4]; const uint scalar_offset_15 = ((offset + 8u)) / 4; uint4 ubo_load_1 = ext_tex_params[scalar_offset_15 / 4]; const uint scalar_offset_16 = ((offset + 16u)) / 4; uint4 ubo_load_2 = ext_tex_params[scalar_offset_16 / 4]; return float3x2(asfloat(((scalar_offset_14 & 2) ? ubo_load.zw : ubo_load.xy)), asfloat(((scalar_offset_15 & 2) ? ubo_load_1.zw : ubo_load_1.xy)), asfloat(((scalar_offset_16 & 2) ? ubo_load_2.zw : ubo_load_2.xy))); } ExternalTextureParams ext_tex_params_load(uint offset) { const uint scalar_offset_17 = ((offset + 0u)) / 4; const uint scalar_offset_18 = ((offset + 4u)) / 4; const ExternalTextureParams tint_symbol_2 = {ext_tex_params[scalar_offset_17 / 4][scalar_offset_17 % 4], ext_tex_params[scalar_offset_18 / 4][scalar_offset_18 % 4], ext_tex_params_load_2((offset + 16u)), ext_tex_params_load_4((offset + 64u)), ext_tex_params_load_4((offset + 96u)), ext_tex_params_load_6((offset + 128u)), ext_tex_params_load_8((offset + 176u))}; return tint_symbol_2; } void textureSampleBaseClampToEdge_7c04e6() { float4 res = textureSampleExternal(arg_0, ext_tex_plane_1, arg_1, (1.0f).xx, ext_tex_params_load(0u)); } struct tint_symbol { float4 value : SV_Position; }; float4 vertex_main_inner() { textureSampleBaseClampToEdge_7c04e6(); return (0.0f).xxxx; } tint_symbol vertex_main() { const float4 inner_result = vertex_main_inner(); tint_symbol wrapper_result = (tint_symbol)0; wrapper_result.value = inner_result; return wrapper_result; } void fragment_main() { textureSampleBaseClampToEdge_7c04e6(); return; } [numthreads(1, 1, 1)] void compute_main() { textureSampleBaseClampToEdge_7c04e6(); return; }