diff options
Diffstat (limited to 'indra/newview')
4 files changed, 22 insertions, 11 deletions
diff --git a/indra/newview/app_settings/shaders/class1/deferred/deferredUtil.glsl b/indra/newview/app_settings/shaders/class1/deferred/deferredUtil.glsl index 777021cd53..c4d1e7d1a7 100644 --- a/indra/newview/app_settings/shaders/class1/deferred/deferredUtil.glsl +++ b/indra/newview/app_settings/shaders/class1/deferred/deferredUtil.glsl @@ -158,7 +158,11 @@ float getDepth(vec2 pos_screen)  vec4 getTexture2DLodAmbient(vec2 tc, float lod)  { -    vec4 ret = texture2DLod(projectionMap, tc, lod); +#ifndef FXAA_GLSL_120 +    vec4 ret = textureLod(projectionMap, tc, lod); +#else +    vec4 ret = texture2D(projectionMap, tc); +#endif      ret.rgb = srgb_to_linear(ret.rgb);      vec2 dist = tc-vec2(0.5); @@ -170,7 +174,11 @@ vec4 getTexture2DLodAmbient(vec2 tc, float lod)  vec4 getTexture2DLodDiffuse(vec2 tc, float lod)  { -    vec4 ret = texture2DLod(projectionMap, tc, lod); +#ifndef FXAA_GLSL_120 +    vec4 ret = textureLod(projectionMap, tc, lod); +#else +    vec4 ret = texture2D(projectionMap, tc); +#endif      ret.rgb = srgb_to_linear(ret.rgb);      vec2 dist = vec2(0.5) - abs(tc-vec2(0.5)); @@ -213,7 +221,11 @@ vec3 getProjectedLightDiffuseColor(float light_distance, vec2 projected_uv)  vec4 texture2DLodSpecular(vec2 tc, float lod)  { -    vec4 ret = texture2DLod(projectionMap, tc, lod); +#ifndef FXAA_GLSL_120 +    vec4 ret = textureLod(projectionMap, tc, lod); +#else +    vec4 ret = texture2D(projectionMap, tc); +#endif      ret.rgb = srgb_to_linear(ret.rgb);      vec2 dist = vec2(0.5) - abs(tc-vec2(0.5)); diff --git a/indra/newview/app_settings/shaders/class3/deferred/softenLightF.glsl b/indra/newview/app_settings/shaders/class3/deferred/softenLightF.glsl index d4140a0d92..01ed71d45d 100644 --- a/indra/newview/app_settings/shaders/class3/deferred/softenLightF.glsl +++ b/indra/newview/app_settings/shaders/class3/deferred/softenLightF.glsl @@ -28,8 +28,8 @@  #define PBR_USE_SUN                1  #define DEBUG_PBR_LIGHT_TYPE       0 // Output no global light to make it easier to see pointLight and spotLight -#define DEBUG_PBR_PACKORM0         0 // Rough=0, Metal=0 -#define DEBUG_PBR_PACKORM1         0 // Rough=1, Metal=1 +#define DEBUG_PBR_PACK_ORM0        0 // Rough=0, Metal=0 +#define DEBUG_PBR_PACK_ORM1        0 // Rough=1, Metal=1  #define DEBUG_PBR_TANGENT1         1 // Tangent = 1,0,0  #define DEBUG_PBR_VERT2CAM1        0 // vertex2camera = 0,0,1  #define DEBUG_PBR_SPECLIGHT051     0 // Force specLigh to be 0,0.5,1 @@ -72,6 +72,7 @@  #define DEBUG_PBR_IRRADIANCE       0 // Output: Diffuse Irradiance, NOTE: SSAO is factored in  #define DEBUG_PBR_FSS_ESS_LAMBERT  0 // Output: FssEssLambert  #define DEBUG_PBR_EMS              0 // Output: Ems = (1 - BRDF Scale + BRDF Bias) +#define DEBUG_PBR_EMS_AVG          0 // Output: Avg Ems  #define DEBUG_PBR_AVG              0 // Output: Avg  #define DEBUG_PBR_FMS_EMS          0 // Output: FmsEms  #define DEBUG_PBR_DIFFUSE_K        0 // Output: diffuse FssEssLambert + FmsEms @@ -110,6 +111,7 @@  #define DEBUG_PBR_SUN_SPEC_FV      0 // F() * V()  #define DEBUG_PBR_SUN_SPEC_DFV     0 // D() * F() * V()  #define DEBUG_PBR_SUN_SPEC_NL_DFV  0 // nl * D() * F() * V() +#define DEBUG_PBR_SUN_FINAL        0 // LAMBERT_NL + BRDF()  #define DEBUG_PBR_IOR              0 // Output: grayscale IOR  #define DEBUG_PBR_REFLECT0_BASE    0 // Output: black reflect0 default from ior @@ -323,9 +325,6 @@ void main()          specLight        = vec3(0,0.5,1.0);          irradiance       = specLight;  #endif -#if HAS_IBL -        kSpec          = mix( kSpec, iridescenceFresnel, iridescenceFactor); -#endif          vec3 FssEssGGX = kSpec*vScaleBias.x + vScaleBias.y;  #if DEBUG_PBR_SPEC_IBL          vec3 debug_color_spec = specWeight * specLight * FssEssGGX; diff --git a/indra/newview/app_settings/shaders/class3/deferred/spotLightF.glsl b/indra/newview/app_settings/shaders/class3/deferred/spotLightF.glsl index 41e40a07e7..769589eff1 100644 --- a/indra/newview/app_settings/shaders/class3/deferred/spotLightF.glsl +++ b/indra/newview/app_settings/shaders/class3/deferred/spotLightF.glsl @@ -278,7 +278,7 @@ void main()          }      } -#if DEBUG_SPOT_DIFFUSE +#if DEBUG_PBR_SPOT_DIFFUSE      final_color = vec3(nl * dist_atten);  #endif  #if DEBUG_SPOT_NL diff --git a/indra/newview/llviewershadermgr.cpp b/indra/newview/llviewershadermgr.cpp index 0d9670d9ca..1c6e659aed 100644 --- a/indra/newview/llviewershadermgr.cpp +++ b/indra/newview/llviewershadermgr.cpp @@ -3789,7 +3789,7 @@ BOOL LLViewerShaderMgr::loadShadersInterface()          }      } -    if (success) +    if (success && gGLManager.mHasCubeMapArray)      {          gRadianceGenProgram.mName = "Radiance Gen Shader";          gRadianceGenProgram.mShaderFiles.clear(); @@ -3799,7 +3799,7 @@ BOOL LLViewerShaderMgr::loadShadersInterface()          success = gRadianceGenProgram.createShader(NULL, NULL);      } -    if (success) +    if (success && gGLManager.mHasCubeMapArray)      {          gIrradianceGenProgram.mName = "Irradiance Gen Shader";          gIrradianceGenProgram.mShaderFiles.clear();  | 
