diff options
Diffstat (limited to 'src/gpu/GrDrawingManager.cpp')
-rw-r--r-- | src/gpu/GrDrawingManager.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/gpu/GrDrawingManager.cpp b/src/gpu/GrDrawingManager.cpp index 458bd20571..75ee0db7c8 100644 --- a/src/gpu/GrDrawingManager.cpp +++ b/src/gpu/GrDrawingManager.cpp @@ -13,9 +13,13 @@ #include "GrSoftwarePathRenderer.h" #include "SkTTopoSort.h" +#include "instanced/InstancedRendering.h" + #include "text/GrAtlasTextContext.h" #include "text/GrStencilAndCoverTextContext.h" +using gr_instanced::InstancedRendering; + void GrDrawingManager::cleanup() { for (int i = 0; i < fDrawTargets.count(); ++i) { fDrawTargets[i]->makeClosed(); // no drawTarget should receive a new command after this @@ -40,6 +44,11 @@ GrDrawingManager::~GrDrawingManager() { void GrDrawingManager::abandon() { fAbandoned = true; + for (int i = 0; i < fDrawTargets.count(); ++i) { + if (InstancedRendering* ir = fDrawTargets[i]->instancedRendering()) { + ir->resetGpuResources(InstancedRendering::ResetType::kAbandon); + } + } this->cleanup(); } @@ -48,6 +57,11 @@ void GrDrawingManager::freeGpuResources() { delete fPathRendererChain; fPathRendererChain = nullptr; SkSafeSetNull(fSoftwarePathRenderer); + for (int i = 0; i < fDrawTargets.count(); ++i) { + if (InstancedRendering* ir = fDrawTargets[i]->instancedRendering()) { + ir->resetGpuResources(InstancedRendering::ResetType::kDestroy); + } + } } void GrDrawingManager::reset() { |