Changeset: 8e66f1150ddc for MonetDB URL: http://dev.monetdb.org/hg/MonetDB?cmd=changeset;node=8e66f1150ddc Modified Files: tools/merovingian/daemon/controlrunner.c Branch: Jun2016 Log Message:
Avoid race condition: don't dereference pointer outside lock. diffs (35 lines): diff --git a/tools/merovingian/daemon/controlrunner.c b/tools/merovingian/daemon/controlrunner.c --- a/tools/merovingian/daemon/controlrunner.c +++ b/tools/merovingian/daemon/controlrunner.c @@ -338,13 +338,17 @@ static void ctl_handle_client( dp = _mero_topdp->next; /* don't need the console/log */ while (dp != NULL) { if (dp->type == MERODB && strcmp(dp->dbname, q) == 0) { - pthread_mutex_unlock(&_mero_topdp_lock); if (strcmp(p, "stop") == 0) { - terminateProcess(dp->pid, strdup(dp->dbname), dp->type, 1); + pid_t pid = dp->pid; + char *dbname = strdup(dp->dbname); + mtype type = dp->type; + pthread_mutex_unlock(&_mero_topdp_lock); + terminateProcess(pid, dbname, type, 1); Mfprintf(_mero_ctlout, "%s: stopped " "database '%s'\n", origin, q); } else { kill(dp->pid, SIGKILL); + pthread_mutex_unlock(&_mero_topdp_lock); Mfprintf(_mero_ctlout, "%s: killed " "database '%s'\n", origin, q); } @@ -353,8 +357,10 @@ static void ctl_handle_client( break; } else if (dp->type == MEROFUN && strcmp(dp->dbname, q) == 0) { /* multiplexDestroy needs topdp lock to remove itself */ + char *dbname = strdup(dp->dbname); pthread_mutex_unlock(&_mero_topdp_lock); - multiplexDestroy(dp->dbname); + multiplexDestroy(dbname); + free(dbname); len = snprintf(buf2, sizeof(buf2), "OK\n"); send_client("="); break; _______________________________________________ checkin-list mailing list checkin-list@monetdb.org https://www.monetdb.org/mailman/listinfo/checkin-list