Use static memory for DB file path 22/295622/1
authorSuyeon Hwang <stom.hwang@samsung.com>
Tue, 11 Jul 2023 02:32:03 +0000 (11:32 +0900)
committerTizen AI <ai.tzn.sec@samsung.com>
Wed, 12 Jul 2023 02:02:11 +0000 (11:02 +0900)
- Issue:
In some code, g_path and g_backup_path can be deallocated even if it
would be referenced.

- Solution:
g_path and g_backup_path should not be allocated the memory dynamically
because the life cycle of those variables are the same as the program.
So this patch changes the variables to use static memory. Through this
patch, unintended memory deallocation will be removed.

Change-Id: Idc64bc76e4cfc884770d83576923d2670e61c364
Signed-off-by: Suyeon Hwang <stom.hwang@samsung.com>
common/vc_cmd_db.c

index 9a308489b5fea0aabef717123f8c6ca1d661e13c..6626bd5fa955e462a35ec38d6632151cea32ee02 100644 (file)
@@ -58,8 +58,8 @@ const char* vc_db_tag()
 //#define DB_PATH tzplatform_mkpath(TZ_USER_DB, ".vc_info.db")
 static sqlite3* g_db_handle = NULL;
 static sqlite3* g_db_backup_handle = NULL;
-static char* g_path = NULL;
-static char* g_backup_path = NULL;
+static char g_path[256] = {0, };
+static char g_backup_path[256] = {0, };
 static int g_ref_cnt = 0;
 
 int g_fpid = -1;
@@ -1493,32 +1493,28 @@ static int __vc_db_create_table(sqlite3* db_handle, const char* table)
        return VC_DB_ERROR_NONE;
 }
 
-int __vc_db_open_db_for_daemon(char** path, sqlite3** db_handle)
+static int __vc_db_open_db_for_daemon(const char* path, sqlite3** db_handle)
 {
        struct stat stat;
-       int ret = db_util_open(*path, db_handle, DB_UTIL_REGISTER_HOOK_METHOD);
+       int ret = db_util_open(path, db_handle, DB_UTIL_REGISTER_HOOK_METHOD);
        if (ret != SQLITE_OK) {
-               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to open db, path = %s, ret(%d)", *path, ret);
+               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to open db, path = %s, ret(%d)", path, ret);
                if (db_handle && *db_handle) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Error msg (%s)", sqlite3_errmsg(*db_handle));
                        db_util_close(*db_handle);
                        *db_handle = NULL;
                }
 
-               free(*path);
-               *path = NULL;
                return VC_DB_ERROR_OPERATION_FAILED;
        }
 
-       if (lstat(*path, &stat) < 0) {
+       if (lstat(path, &stat) < 0) {
                char buf_err[256];
                SLOG(LOG_ERROR, vc_db_tag(), "%d", strerror_r(errno, buf_err, sizeof(buf_err)));
                if (*db_handle)
                        db_util_close(*db_handle);
                *db_handle = NULL;
 
-               free(*path);
-               *path = NULL;
                return VC_DB_ERROR_OPERATION_FAILED;
        }
 
@@ -1528,8 +1524,6 @@ int __vc_db_open_db_for_daemon(char** path, sqlite3** db_handle)
                        db_util_close(*db_handle);
                *db_handle = NULL;
 
-               free(*path);
-               *path = NULL;
                return VC_DB_ERROR_OPERATION_FAILED;
        }
 
@@ -1584,7 +1578,7 @@ static int __vc_db_restore_table(sqlite3* db_handle, const char* table)
        return VC_DB_ERROR_NONE;
 }
 
-bool __vc_db_connect_db_for_daemon(char** path, sqlite3** db_handle)
+static bool __vc_db_connect_db_for_daemon(const char* path, sqlite3** db_handle)
 {
        bool is_connect = false;
        int ret = __vc_db_open_db_for_daemon(path, db_handle);
@@ -1621,7 +1615,7 @@ static int __vc_db_integrity_check_cb(void *NotUsed, int argc, char **argv, char
                        g_db_cnt = (g_db_cnt + 1) % 1000;
                        snprintf(g_path, 256, "%s/.vc_info_%d.db", VC_RUNTIME_INFO_ROOT, g_db_cnt);
                }
-               bool is_connect = __vc_db_connect_db_for_daemon(&g_path, &g_db_handle);
+               bool is_connect = __vc_db_connect_db_for_daemon(g_path, &g_db_handle);
                if (true == is_connect) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect main DB for daemon");
                        ret = __vc_db_restore_table(g_db_handle, VC_INFO_TABLE);
@@ -1632,7 +1626,7 @@ static int __vc_db_integrity_check_cb(void *NotUsed, int argc, char **argv, char
                        if (0 != ret) {
                                SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to create table (%s)", VC_RESULT_TABLE);
                        }
-                       is_connect = __vc_db_connect_db_for_daemon(&g_backup_path, &g_db_backup_handle);
+                       is_connect = __vc_db_connect_db_for_daemon(g_backup_path, &g_db_backup_handle);
                        if (true == is_connect) {
                                SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect backup DB for daemon");
                                if (0 != vc_db_restore_command()) {
@@ -1659,23 +1653,13 @@ int vc_db_initialize_for_daemon(void)
        }
 
        /* For voice control DB */
-       g_path = (char*)calloc(256, sizeof(char));
-       if (NULL == g_path) {
-               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to allocate memory");
-               return VC_DB_ERROR_OUT_OF_MEMORY;
-       }
        /* This should be changed to general DB space - TZ_USER_DB */
        snprintf(g_path, 256, "%s/.vc_info.db", VC_RUNTIME_INFO_ROOT);
 
        /* For Backup DB */
-       g_backup_path = (char*)calloc(256, sizeof(char));
-       if (NULL == g_backup_path) {
-               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to allocate memory");
-               return VC_DB_ERROR_OUT_OF_MEMORY;
-       }
        snprintf(g_backup_path, 256, "%s/.vc_backup.db", VC_RUNTIME_INFO_ROOT);
 
-       bool is_connect = __vc_db_connect_db_for_daemon(&g_path, &g_db_handle);
+       bool is_connect = __vc_db_connect_db_for_daemon(g_path, &g_db_handle);
        if (false == is_connect) {
                SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to connect main DB, retry to connect after removing");
                if (0 != remove(g_path)) {
@@ -1683,10 +1667,10 @@ int vc_db_initialize_for_daemon(void)
                        g_db_cnt = (g_db_cnt + 1) % 1000;
                        snprintf(g_path, 256, "%s/.vc_info_%d.db", VC_RUNTIME_INFO_ROOT, g_db_cnt);
                }
-               is_connect = __vc_db_connect_db_for_daemon(&g_path, &g_db_handle);
+               is_connect = __vc_db_connect_db_for_daemon(g_path, &g_db_handle);
                if (true == is_connect) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect main DB for daemon");
-                       is_connect = __vc_db_connect_db_for_daemon(&g_backup_path, &g_db_backup_handle);
+                       is_connect = __vc_db_connect_db_for_daemon(g_backup_path, &g_db_backup_handle);
                        if (true == is_connect) {
                                SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect backup DB for daemon");
                                if (0 != vc_db_restore_command()) {
@@ -1714,10 +1698,10 @@ int vc_db_initialize_for_daemon(void)
                        g_db_cnt = (g_db_cnt + 1) % 1000;
                        snprintf(g_path, 256, "%s/.vc_info_%d.db", VC_RUNTIME_INFO_ROOT, g_db_cnt);
                }
-               is_connect = __vc_db_connect_db_for_daemon(&g_path, &g_db_handle);
+               is_connect = __vc_db_connect_db_for_daemon(g_path, &g_db_handle);
                if (true == is_connect) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect main DB for daemon");
-                       is_connect = __vc_db_connect_db_for_daemon(&g_backup_path, &g_db_backup_handle);
+                       is_connect = __vc_db_connect_db_for_daemon(g_backup_path, &g_db_backup_handle);
                        if (true == is_connect) {
                                SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect backup DB for daemon");
                                if (0 != vc_db_restore_command()) {
@@ -1734,7 +1718,7 @@ int vc_db_initialize_for_daemon(void)
                return VC_DB_ERROR_NONE;
        }
 
-       is_connect = __vc_db_connect_db_for_daemon(&g_backup_path, &g_db_backup_handle);
+       is_connect = __vc_db_connect_db_for_daemon(g_backup_path, &g_db_backup_handle);
        if (false == is_connect) {
                SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to open backup DB, retry to connect after removing file for daemon");
                if (0 != remove(g_backup_path)) {
@@ -1742,7 +1726,7 @@ int vc_db_initialize_for_daemon(void)
                        SLOG(LOG_ERROR, vc_db_tag(), "[Error] remove file(%s) is failed", g_backup_path);
                        snprintf(g_backup_path, 256, "%s/.vc_backup_%d.db", VC_RUNTIME_INFO_ROOT, g_backup_db_cnt);
                }
-               is_connect = __vc_db_connect_db_for_daemon(&g_path, &g_db_backup_handle);
+               is_connect = __vc_db_connect_db_for_daemon(g_path, &g_db_backup_handle);
                if (true == is_connect) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect backup DB for daemon");
                        if (0 != vc_db_restore_command()) {
@@ -1757,25 +1741,23 @@ int vc_db_initialize_for_daemon(void)
        return VC_DB_ERROR_NONE;
 }
 
-int __vc_db_open_db(char** path, sqlite3** db_handle)
+static int __vc_db_open_db(const char* path, sqlite3** db_handle)
 {
-       int ret = db_util_open(*path, db_handle, DB_UTIL_REGISTER_HOOK_METHOD);
+       int ret = db_util_open(path, db_handle, DB_UTIL_REGISTER_HOOK_METHOD);
        if (ret != SQLITE_OK) {
-               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to open db for daemon, path = %s, ret(%d)", *path, ret);
+               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to open db for daemon, path = %s, ret(%d)", path, ret);
                if (db_handle && *db_handle) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Error msg (%s)", sqlite3_errmsg(*db_handle));
                        db_util_close(*db_handle);
                        *db_handle = NULL;
                }
 
-               free(*path);
-               *path = NULL;
                return VC_DB_ERROR_OPERATION_FAILED;
        }
        return VC_DB_ERROR_NONE;
 }
 
-bool __vc_db_connect_db(char** path, sqlite3** db_handle)
+static bool __vc_db_connect_db(const char* path, sqlite3** db_handle)
 {
        bool is_connect = false;
        int ret = __vc_db_open_db(path, db_handle);
@@ -1809,23 +1791,13 @@ int vc_db_initialize(void)
        }
 
        /* For voice control DB */
-       g_path = (char*)calloc(256, sizeof(char));
-       if (NULL == g_path) {
-               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to allocate memory");
-               return VC_DB_ERROR_OUT_OF_MEMORY;
-       }
        /* This should be changed to general DB space - TZ_USER_DB */
        snprintf(g_path, 256, "%s/.vc_info.db", VC_RUNTIME_INFO_ROOT);
 
        /* For Backup DB */
-       g_backup_path = (char*)calloc(256, sizeof(char));
-       if (NULL == g_backup_path) {
-               SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to allocate memory");
-               return VC_DB_ERROR_OUT_OF_MEMORY;
-       }
        snprintf(g_backup_path, 256, "%s/.vc_backup.db", VC_RUNTIME_INFO_ROOT);
 
-       bool is_connect = __vc_db_connect_db(&g_path, &g_db_handle);
+       bool is_connect = __vc_db_connect_db(g_path, &g_db_handle);
        if (false == is_connect) {
                SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to connect main DB, retry to connect after removing");
                if (0 != remove(g_path)) {
@@ -1833,10 +1805,10 @@ int vc_db_initialize(void)
                        g_db_cnt = (g_db_cnt + 1) % 1000;
                        snprintf(g_path, 256, "%s/.vc_info_%d.db", VC_RUNTIME_INFO_ROOT, g_db_cnt);
                }
-               is_connect = __vc_db_connect_db(&g_path, &g_db_handle);
+               is_connect = __vc_db_connect_db(g_path, &g_db_handle);
                if (true == is_connect) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect main DB");
-                       is_connect = __vc_db_connect_db(&g_backup_path, &g_db_backup_handle);
+                       is_connect = __vc_db_connect_db(g_backup_path, &g_db_backup_handle);
                        if (true == is_connect) {
                                SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect backup DB");
                                if (0 != vc_db_restore_command()) {
@@ -1849,7 +1821,7 @@ int vc_db_initialize(void)
                }
        }
 
-       is_connect = __vc_db_connect_db(&g_backup_path, &g_db_backup_handle);
+       is_connect = __vc_db_connect_db(g_backup_path, &g_db_backup_handle);
        if (false == is_connect) {
                SLOG(LOG_ERROR, vc_db_tag(), "[ERROR] Fail to open backup DB, retry to connect after removing file");
                if (0 != remove(g_backup_path)) {
@@ -1857,7 +1829,7 @@ int vc_db_initialize(void)
                        SLOG(LOG_ERROR, vc_db_tag(), "[Error] remove file(%s) is failed", g_backup_path);
                        snprintf(g_backup_path, 256, "%s/.vc_backup_%d.db", VC_RUNTIME_INFO_ROOT, g_backup_db_cnt);
                }
-               is_connect = __vc_db_connect_db(&g_path, &g_db_backup_handle);
+               is_connect = __vc_db_connect_db(g_path, &g_db_backup_handle);
                if (true == is_connect) {
                        SLOG(LOG_ERROR, vc_db_tag(), "[INFO] Success to connect backup");
                        if (0 != vc_db_restore_command()) {
@@ -1878,15 +1850,9 @@ int vc_db_finalize(void)
        if (0 != --g_ref_cnt)
                return VC_DB_ERROR_NONE;
 
-       if (NULL != g_path) {
-               free(g_path);
-               g_path = NULL;
-       }
+       memset(g_path, 0, 256);
 
-       if (NULL != g_backup_path) {
-               free(g_backup_path);
-               g_backup_path = NULL;
-       }
+       memset(g_backup_path, 0, 256);
 
        if (!g_db_handle)
                return VC_DB_ERROR_NONE;