From f35e3040fc5290267f7bb20cfc1637b0b4ac29e1 Mon Sep 17 00:00:00 2001 From: Tvisha Andharia Date: Mon, 2 Dec 2024 08:09:47 -0500 Subject: [PATCH] Fix #2615, Unloading module after failed app start --- modules/es/fsw/src/cfe_es_apps.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/modules/es/fsw/src/cfe_es_apps.c b/modules/es/fsw/src/cfe_es_apps.c index f4f2101ff..9aa971b0a 100644 --- a/modules/es/fsw/src/cfe_es_apps.c +++ b/modules/es/fsw/src/cfe_es_apps.c @@ -656,6 +656,7 @@ int32 CFE_ES_StartAppTask(CFE_ES_TaskId_t *TaskIdPtr, const char *TaskName, CFE_ int32 CFE_ES_AppCreate(CFE_ES_AppId_t *ApplicationIdPtr, const char *AppName, const CFE_ES_AppStartParams_t *Params) { CFE_Status_t Status; + CFE_Status_t CleanupStatus; CFE_ES_AppRecord_t *AppRecPtr; CFE_ResourceId_t PendingResourceId = CFE_RESOURCEID_UNDEFINED; @@ -799,6 +800,16 @@ int32 CFE_ES_AppCreate(CFE_ES_AppId_t *ApplicationIdPtr, const char *AppName, co /* * Set the table entry back to free */ + if (OS_ObjectIdDefined(AppRecPtr->LoadStatus.ModuleId)) + { + CleanupStatus = OS_ModuleUnload(AppRecPtr->LoadStatus.ModuleId); + if (CleanupStatus != OS_SUCCESS) + { + CFE_ES_WriteToSysLog("%s: Module (ID:0x%08lX) Unload failed. RC=%ld\n", __func__, + OS_ObjectIdToInteger(AppRecPtr->LoadStatus.ModuleId), (long)CleanupStatus); + } + } + CFE_ES_AppRecordSetFree(AppRecPtr); PendingResourceId = CFE_RESOURCEID_UNDEFINED; }