Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSergey Sharybin <sergey.vfx@gmail.com>2015-11-03 12:25:42 +0300
committerSergey Sharybin <sergey.vfx@gmail.com>2015-11-03 12:26:56 +0300
commit606379073281c63d13e646308703f53b180790b1 (patch)
tree1d84f3ba96a431ef1a9f55ce537f501e12663f1a /source/blender/blenkernel/intern/scene.c
parent0d0fa446b71ec8f808262311870aa1929ad715f6 (diff)
Fix T46677: OpenSubdiv crashes when witching from simple and CC subdivisions
Crash was happening due to OpenGL free from the non-main thread. Ideally we need to implement somewhat delayed unused buffer free for OpenSubdiv similar to what we are doing in GPU module.
Diffstat (limited to 'source/blender/blenkernel/intern/scene.c')
-rw-r--r--source/blender/blenkernel/intern/scene.c23
1 files changed, 16 insertions, 7 deletions
diff --git a/source/blender/blenkernel/intern/scene.c b/source/blender/blenkernel/intern/scene.c
index bb61ecd63cb..b3fa6018517 100644
--- a/source/blender/blenkernel/intern/scene.c
+++ b/source/blender/blenkernel/intern/scene.c
@@ -1598,7 +1598,8 @@ static void scene_free_unused_opensubdiv_cache(Scene *scene)
ModifierData *md = object->modifiers.last;
if (md != NULL && md->type == eModifierType_Subsurf) {
SubsurfModifierData *smd = (SubsurfModifierData *) md;
- bool object_in_editmode = object->mode == OB_MODE_EDIT;
+ const bool object_in_editmode = (object->mode == OB_MODE_EDIT);
+ const bool use_simple = (smd->subdivType == ME_SIMPLE_SUBSURF);
if (!smd->use_opensubdiv ||
DAG_get_eval_flags_for_object(scene, object) & DAG_EVAL_NEED_CPU)
{
@@ -1609,13 +1610,21 @@ static void scene_free_unused_opensubdiv_cache(Scene *scene)
ccgSubSurf_free_osd_mesh(smd->emCache);
}
}
- if (object_in_editmode && smd->mCache != NULL) {
- ccgSubSurf_free(smd->mCache);
- smd->mCache = NULL;
+ if (smd->mCache != NULL) {
+ if (object_in_editmode ||
+ ccgSubSurf_getSimpleSubdiv(smd->mCache) != use_simple)
+ {
+ ccgSubSurf_free(smd->mCache);
+ smd->mCache = NULL;
+ }
}
- if (!object_in_editmode && smd->emCache != NULL) {
- ccgSubSurf_free(smd->emCache);
- smd->emCache = NULL;
+ if (smd->emCache != NULL) {
+ if (!object_in_editmode ||
+ ccgSubSurf_getSimpleSubdiv(smd->emCache) != use_simple)
+ {
+ ccgSubSurf_free(smd->emCache);
+ smd->emCache = NULL;
+ }
}
}
}