aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llglslshader.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llglslshader.cpp')
-rw-r--r--linden/indra/newview/llglslshader.cpp61
1 files changed, 48 insertions, 13 deletions
diff --git a/linden/indra/newview/llglslshader.cpp b/linden/indra/newview/llglslshader.cpp
index 2a688e4..f0ad565 100644
--- a/linden/indra/newview/llglslshader.cpp
+++ b/linden/indra/newview/llglslshader.cpp
@@ -114,6 +114,9 @@ LLGLSLShader gGlowExtractProgram;
114LLGLSLShader gPostColorFilterProgram; 114LLGLSLShader gPostColorFilterProgram;
115LLGLSLShader gPostNightVisionProgram; 115LLGLSLShader gPostNightVisionProgram;
116 116
117// Deferred rendering shaders
118LLGLSLShader gDeferredDiffuseProgram;
119
117//current avatar shader parameter pointer 120//current avatar shader parameter pointer
118GLint gAvatarMatrixParam; 121GLint gAvatarMatrixParam;
119 122
@@ -732,7 +735,7 @@ void LLShaderMgr::setShaders()
732 if (gGLManager.mHasFramebufferObject && 735 if (gGLManager.mHasFramebufferObject &&
733 gSavedSettings.getBOOL("VertexShaderEnable")) 736 gSavedSettings.getBOOL("VertexShaderEnable"))
734 { 737 {
735 LLPipeline::sDynamicReflections = gSavedSettings.getBOOL("RenderDynamicReflections") && gGLManager.mHasCubeMap && gFeatureManagerp->isFeatureAvailable("RenderCubeMap"); 738 LLPipeline::sDynamicReflections = gSavedSettings.getBOOL("RenderDynamicReflections") && gGLManager.mHasCubeMap && LLFeatureManager::getInstance()->isFeatureAvailable("RenderCubeMap");
736 LLPipeline::sWaterReflections = gGLManager.mHasCubeMap; 739 LLPipeline::sWaterReflections = gGLManager.mHasCubeMap;
737 LLPipeline::sRenderGlow = gSavedSettings.getBOOL("RenderGlow"); 740 LLPipeline::sRenderGlow = gSavedSettings.getBOOL("RenderGlow");
738 } 741 }
@@ -762,7 +765,7 @@ void LLShaderMgr::setShaders()
762 } 765 }
763 sMaxAvatarShaderLevel = 0; 766 sMaxAvatarShaderLevel = 0;
764 767
765 if (gFeatureManagerp->isFeatureAvailable("VertexShaderEnable") 768 if (LLFeatureManager::getInstance()->isFeatureAvailable("VertexShaderEnable")
766 && gSavedSettings.getBOOL("VertexShaderEnable")) 769 && gSavedSettings.getBOOL("VertexShaderEnable"))
767 { 770 {
768 S32 light_class = 2; 771 S32 light_class = 2;
@@ -771,7 +774,7 @@ void LLShaderMgr::setShaders()
771 S32 effect_class = 2; 774 S32 effect_class = 2;
772 S32 wl_class = 2; 775 S32 wl_class = 2;
773 S32 water_class = 2; 776 S32 water_class = 2;
774 777 S32 deferred_class = 0;
775 if (!gSavedSettings.getBOOL("WindLightUseAtmosShaders")) 778 if (!gSavedSettings.getBOOL("WindLightUseAtmosShaders"))
776 { 779 {
777 // user has disabled WindLight in their settings, downgrade 780 // user has disabled WindLight in their settings, downgrade
@@ -784,7 +787,7 @@ void LLShaderMgr::setShaders()
784 // but class one would 787 // but class one would
785 // TODO: Make water on class one cards color things 788 // TODO: Make water on class one cards color things
786 // beneath it properly 789 // beneath it properly
787 if(gFeatureManagerp->getGPUClass() < GPU_CLASS_2) 790 if(LLFeatureManager::getInstance()->getGPUClass() < GPU_CLASS_2)
788 { 791 {
789 // use lesser water and other stuff 792 // use lesser water and other stuff
790 light_class = 2; 793 light_class = 2;
@@ -795,6 +798,16 @@ void LLShaderMgr::setShaders()
795 } 798 }
796 } 799 }
797 800
801 if (gSavedSettings.getBOOL("RenderDeferred"))
802 {
803 light_class = 1;
804 env_class = 0;
805 obj_class = 0;
806 water_class = 1;
807 effect_class = 1;
808 deferred_class = 1;
809 }
810
798 if(!gSavedSettings.getBOOL("EnableRippleWater")) 811 if(!gSavedSettings.getBOOL("EnableRippleWater"))
799 { 812 {
800 water_class = 0; 813 water_class = 0;
@@ -814,6 +827,7 @@ void LLShaderMgr::setShaders()
814 sVertexShaderLevel[SHADER_OBJECT] = obj_class; 827 sVertexShaderLevel[SHADER_OBJECT] = obj_class;
815 sVertexShaderLevel[SHADER_EFFECT] = effect_class; 828 sVertexShaderLevel[SHADER_EFFECT] = effect_class;
816 sVertexShaderLevel[SHADER_WINDLIGHT] = wl_class; 829 sVertexShaderLevel[SHADER_WINDLIGHT] = wl_class;
830 sVertexShaderLevel[SHADER_DEFERRED] = deferred_class;
817 831
818 BOOL loaded = loadBasicShaders(); 832 BOOL loaded = loadBasicShaders();
819 833
@@ -829,6 +843,7 @@ void LLShaderMgr::setShaders()
829 loadShadersWindLight(); 843 loadShadersWindLight();
830 loadShadersEffects(); 844 loadShadersEffects();
831 loadShadersInterface(); 845 loadShadersInterface();
846 loadShadersDeferred();
832 847
833 // Load max avatar shaders to set the max level 848 // Load max avatar shaders to set the max level
834 sVertexShaderLevel[SHADER_AVATAR] = 3; 849 sVertexShaderLevel[SHADER_AVATAR] = 3;
@@ -939,6 +954,8 @@ void LLShaderMgr::unloadShaders()
939 gPostColorFilterProgram.unload(); 954 gPostColorFilterProgram.unload();
940 gPostNightVisionProgram.unload(); 955 gPostNightVisionProgram.unload();
941 956
957 gDeferredDiffuseProgram.unload();
958
942 sVertexShaderLevel[SHADER_LIGHTING] = 0; 959 sVertexShaderLevel[SHADER_LIGHTING] = 0;
943 sVertexShaderLevel[SHADER_OBJECT] = 0; 960 sVertexShaderLevel[SHADER_OBJECT] = 0;
944 sVertexShaderLevel[SHADER_AVATAR] = 0; 961 sVertexShaderLevel[SHADER_AVATAR] = 0;
@@ -963,7 +980,7 @@ BOOL LLShaderMgr::loadBasicShaders()
963 // class zero we're not going to think about 980 // class zero we're not going to think about
964 // since a class zero card COULD be a ridiculous new card 981 // since a class zero card COULD be a ridiculous new card
965 // and old cards should have the features masked 982 // and old cards should have the features masked
966 if(gFeatureManagerp->getGPUClass() == GPU_CLASS_1) 983 if(LLFeatureManager::getInstance()->getGPUClass() == GPU_CLASS_1)
967 { 984 {
968 sum_lights_class = 2; 985 sum_lights_class = 2;
969 } 986 }
@@ -1061,10 +1078,7 @@ BOOL LLShaderMgr::loadShadersEnvironment()
1061 return FALSE; 1078 return FALSE;
1062 } 1079 }
1063 1080
1064 if (gWorldPointer) 1081 LLWorld::getInstance()->updateWaterObjects();
1065 {
1066 gWorldPointer->updateWaterObjects();
1067 }
1068 1082
1069 return TRUE; 1083 return TRUE;
1070} 1084}
@@ -1147,10 +1161,8 @@ BOOL LLShaderMgr::loadShadersWater()
1147 return loadShadersWater(); 1161 return loadShadersWater();
1148 } 1162 }
1149 1163
1150 if (gWorldPointer) 1164 LLWorld::getInstance()->updateWaterObjects();
1151 { 1165
1152 gWorldPointer->updateWaterObjects();
1153 }
1154 return TRUE; 1166 return TRUE;
1155} 1167}
1156 1168
@@ -1244,6 +1256,29 @@ BOOL LLShaderMgr::loadShadersEffects()
1244 1256
1245} 1257}
1246 1258
1259BOOL LLShaderMgr::loadShadersDeferred()
1260{
1261 if (sVertexShaderLevel[SHADER_DEFERRED] == 0)
1262 {
1263 gDeferredDiffuseProgram.unload();
1264 return FALSE;
1265 }
1266
1267 BOOL success = TRUE;
1268
1269 if (success)
1270 {
1271 gDeferredDiffuseProgram.mName = "Deffered Diffuse Shader";
1272 gDeferredDiffuseProgram.mShaderFiles.clear();
1273 gDeferredDiffuseProgram.mShaderFiles.push_back(make_pair("deferred/diffuseV.glsl", GL_VERTEX_SHADER_ARB));
1274 gDeferredDiffuseProgram.mShaderFiles.push_back(make_pair("deferred/diffuseF.glsl", GL_FRAGMENT_SHADER_ARB));
1275 gDeferredDiffuseProgram.mShaderLevel = sVertexShaderLevel[SHADER_DEFERRED];
1276 success = gDeferredDiffuseProgram.createShader(NULL, NULL);
1277 }
1278
1279 return success;
1280}
1281
1247BOOL LLShaderMgr::loadShadersObject() 1282BOOL LLShaderMgr::loadShadersObject()
1248{ 1283{
1249 BOOL success = TRUE; 1284 BOOL success = TRUE;