From: ntfreak at B. <nt...@ma...> - 2008-12-10 18:47:49
|
Author: ntfreak Date: 2008-12-10 18:47:16 +0100 (Wed, 10 Dec 2008) New Revision: 1224 Modified: trunk/src/helper/command.c Log: - fix illegal memory access in unregister_command function Modified: trunk/src/helper/command.c =================================================================== --- trunk/src/helper/command.c 2008-12-10 11:44:45 UTC (rev 1223) +++ trunk/src/helper/command.c 2008-12-10 17:47:16 UTC (rev 1224) @@ -289,8 +289,10 @@ return ERROR_INVALID_ARGUMENTS; /* find command */ - for (c = context->commands; c; c = c->next) - { + c = context->commands; + + while(NULL != c) + { if (strcmp(name, c->name) == 0) { /* unlink command */ @@ -300,26 +302,32 @@ } else { + /* first element in command list */ context->commands = c->next; } - + /* unregister children */ - if (c->children) + while(NULL != c->children) { - for (c2 = c->children; c2; c2 = c2->next) - { - free(c2->name); - free(c2); - } + c2 = c->children; + c->children = c->children->next; + free(c2->name); + c2->name = NULL; + free(c2); + c2 = NULL; } - + /* delete command */ free(c->name); + c->name = NULL; free(c); + c = NULL; + return ERROR_OK; } - + /* remember the last command for unlinking */ p = c; + c = c->next; } return ERROR_OK; |