Revert "[Tizen] Do not call gl functions during shutdown"
authorDaekwang Ryu <dkdk.ryu@samsung.com>
Tue, 26 Apr 2022 01:46:36 +0000 (10:46 +0900)
committerDaekwang Ryu <dkdk.ryu@samsung.com>
Tue, 26 Apr 2022 01:46:36 +0000 (10:46 +0900)
This reverts commit c1b85eb0beee3408d79d1eeebebc25b28d71c9c1.

dali/internal/graphics/gles-impl/egl-graphics-controller.h

index ec6c894c34857ab682f5ff68c7ea92a04399b72f..6af738393bb13a509f8ed72b2d1ee16ea32c4ba1 100644 (file)
@@ -136,16 +136,6 @@ public:
     // Final flush
     Flush();
 
-    ClearTextureUpdateQueue();
-
-    // Remove all create queue and command queue.
-    // Note that all memory are already deallocated at Final flush.
-    mCreateTextureQueue              = {};
-    mCreateBufferQueue               = {};
-    mCreateFramebufferQueue          = {};
-    mTextureMipmapGenerationRequests = {};
-    mCommandQueue                    = {};
-
     if(mContext)
     {
       mContext->GlContextDestroyed();
@@ -473,26 +463,6 @@ public:
     mDiscardPipelineQueue.push(pipeline);
   }
 
-  /**
-   * @brief Clears the texture update queue
-   */
-  void ClearTextureUpdateQueue()
-  {
-    // Remove remained CPU-allocated texture memory
-    while(!mTextureUpdateRequests.empty())
-    {
-      auto& request = mTextureUpdateRequests.front();
-      auto& source  = request.second;
-
-      if(source.sourceType == Graphics::TextureUpdateSourceInfo::Type::MEMORY)
-      {
-        // free staging memory
-        free(source.memorySource.memory);
-      }
-      mTextureUpdateRequests.pop();
-    }
-  }
-
   /**
    * @brief Flushes all pending updates
    *
@@ -501,29 +471,26 @@ public:
    */
   void Flush()
   {
-    if(DALI_LIKELY(!mIsShuttingDown))
+    if(!mCreateTextureQueue.empty() ||
+       !mCreateBufferQueue.empty() ||
+       !mCreateFramebufferQueue.empty() ||
+       !mTextureUpdateRequests.empty() ||
+       !mTextureMipmapGenerationRequests.empty())
     {
-      if(!mCreateTextureQueue.empty() ||
-         !mCreateBufferQueue.empty() ||
-         !mCreateFramebufferQueue.empty() ||
-         !mTextureUpdateRequests.empty() ||
-         !mTextureMipmapGenerationRequests.empty())
-      {
-        mGraphics->ActivateResourceContext();
-      }
+      mGraphics->ActivateResourceContext();
+    }
 
-      // Process creations
-      ProcessCreateQueues();
+    // Process creations
+    ProcessCreateQueues();
 
-      // Process updates
-      ProcessTextureUpdateQueue();
+    // Process updates
+    ProcessTextureUpdateQueue();
 
-      // Process texture mipmap generation requests
-      ProcessTextureMipmapGenerationQueue();
+    // Process texture mipmap generation requests
+    ProcessTextureMipmapGenerationQueue();
 
-      // Process main command queue
-      ProcessCommandQueues();
-    }
+    // Process main command queue
+    ProcessCommandQueues();
 
     // Reset texture cache in the contexts while destroying textures
     ResetTextureCache();