From: Stefan Metzmacher Date: Wed, 14 Mar 2012 09:50:34 +0000 (+0100) Subject: lib/util: cope with races between lstat and mkdir in directory_create_or_exist() X-Git-Tag: tdb-1.2.10~197 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=bfe990af89ebd870625c0740f1c6073a5349771e;p=thirdparty%2Fsamba.git lib/util: cope with races between lstat and mkdir in directory_create_or_exist() metze --- diff --git a/lib/util/util.c b/lib/util/util.c index 54a8c88245e..e3d22f36144 100644 --- a/lib/util/util.c +++ b/lib/util/util.c @@ -161,7 +161,7 @@ _PUBLIC_ bool directory_create_or_exist(const char *dname, uid_t uid, /* Create directory */ ret = mkdir(dname, dir_perms); - if (ret == -1) { + if (ret == -1 && errno != EEXIST) { DEBUG(0, ("mkdir failed on directory " "%s: %s\n", dname, strerror(errno))); @@ -169,7 +169,13 @@ _PUBLIC_ bool directory_create_or_exist(const char *dname, uid_t uid, return false; } - return true; + ret = lstat(dname, &st); + if (ret == -1) { + DEBUG(0, ("lstat failed on created directory %s: %s\n", + dname, strerror(errno))); + umask(old_umask); + return false; + } } /* Check ownership and permission on existing directory */