From e64c51b7c3325707a701192666491641eb0f0fca Mon Sep 17 00:00:00 2001 From: Adrian Muzyka Date: Fri, 27 Oct 2023 09:43:15 +0200 Subject: [PATCH] RDKShell: checkpoint native apps on each suspend state change --- RDKShell/RDKShell.cpp | 26 +------------------------- 1 file changed, 1 insertion(+), 25 deletions(-) diff --git a/RDKShell/RDKShell.cpp b/RDKShell/RDKShell.cpp index 4bfabf8270..6bb572483f 100755 --- a/RDKShell/RDKShell.cpp +++ b/RDKShell/RDKShell.cpp @@ -197,11 +197,6 @@ bool sForceResidentAppLaunch = false; static bool sRunning = true; bool needsScreenshot = false; -#ifdef HIBERNATE_NATIVE_APPS_ON_SUSPENDED -std::mutex nativeAppWasResumedMutex; -map nativeAppWasResumed; -#endif - #define ANY_KEY 65536 #define RDKSHELL_THUNDER_TIMEOUT 20000 #define RDKSHELL_POWER_TIME_WAIT 2.5 @@ -622,10 +617,7 @@ namespace WPEFramework { if (Utils::getRFCConfig("Device.DeviceInfo.X_RDKCENTRAL-COM_RFC.Feature.AppHibernate.Enable", param) && strncasecmp(param.value, "true", 4) == 0) { - nativeAppWasResumedMutex.lock(); - if ((mCallSign.find("Netflix") != std::string::npos || mCallSign.find("Cobalt") != std::string::npos) - && nativeAppWasResumed.find(mCallSign) != nativeAppWasResumed.end() - && nativeAppWasResumed[mCallSign]) + if ((mCallSign.find("Netflix") != std::string::npos || mCallSign.find("Cobalt") != std::string::npos)) { // call RDKShell.hibernate std::thread requestsThread = @@ -638,15 +630,9 @@ namespace WPEFramework { requestsThread.detach(); } - nativeAppWasResumedMutex.unlock(); } #endif } -#ifdef HIBERNATE_NATIVE_APPS_ON_SUSPENDED - nativeAppWasResumedMutex.lock(); - nativeAppWasResumed[mCallSign] = (state == PluginHost::IStateControl::RESUMED); - nativeAppWasResumedMutex.unlock(); -#endif } @@ -1049,11 +1035,6 @@ namespace WPEFramework { } gExitReasonMutex.lock(); gApplicationsExitReason[service->Callsign()] = AppLastExitReason::DEACTIVATED; -#ifdef HIBERNATE_NATIVE_APPS_ON_SUSPENDED - nativeAppWasResumedMutex.lock(); - nativeAppWasResumed[service->Callsign()] = false; - nativeAppWasResumedMutex.unlock(); -#endif if(service->Reason() == PluginHost::IShell::FAILURE) { gApplicationsExitReason[service->Callsign()] = AppLastExitReason::CRASH; @@ -1124,11 +1105,6 @@ namespace WPEFramework { if ((currentState == PluginHost::IShell::DEACTIVATED) || (currentState == PluginHost::IShell::DESTROYED)) { gApplicationsExitReason[service->Callsign()] = AppLastExitReason::DEACTIVATED; -#ifdef HIBERNATE_NATIVE_APPS_ON_SUSPENDED - nativeAppWasResumedMutex.lock(); - nativeAppWasResumed[service->Callsign()] = false; - nativeAppWasResumedMutex.unlock(); -#endif } if(service->Reason() == PluginHost::IShell::FAILURE) {