From: Russell Bryant Date: Thu, 1 Jul 2010 22:17:57 +0000 (+0000) Subject: Merged revisions 273566 via svnmerge from X-Git-Tag: 1.6.2.11-rc1~59 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=120aab65a5a72da618aa64c486973ff3ea58a3af;p=thirdparty%2Fasterisk.git Merged revisions 273566 via svnmerge from https://origsvn.digium.com/svn/asterisk/trunk ................ r273566 | russell | 2010-07-01 17:16:23 -0500 (Thu, 01 Jul 2010) | 14 lines Merged revisions 273565 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r273565 | russell | 2010-07-01 17:09:19 -0500 (Thu, 01 Jul 2010) | 7 lines Don't return a partially initialized datastore. If memory allocation fails in ast_strdup(), don't return a partially initialized datastore. Bad things may happen. (related to ABE-2415) ........ ................ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.6.2@273571 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/main/datastore.c b/main/datastore.c index 3d097860fc..ee471551d1 100644 --- a/main/datastore.c +++ b/main/datastore.c @@ -50,7 +50,10 @@ struct ast_datastore *__ast_datastore_alloc(const struct ast_datastore_info *inf datastore->info = info; - datastore->uid = ast_strdup(uid); + if (!ast_strlen_zero(uid) && !(datastore->uid = ast_strdup(uid))) { + ast_free(datastore); + datastore = NULL; + } return datastore; }