1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-18 14:17:03 +01:00

common: Fix a race condition in creating socketdir.

* common/homedir.c (_gnupg_socketdir_internal): Check return code
of gnupg_mkdir and handle the case of GPG_ERR_EEXIST.

--

GnuPG-bug-id: 7332
Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
(cherry picked from commit 71840b57f48680b7555451a29026d9c6de4fe2bc)
This commit is contained in:
NIIBE Yutaka 2024-10-16 10:04:18 +09:00 committed by Werner Koch
parent 4728d7f0df
commit 2ae017a25f
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B

View File

@ -971,6 +971,7 @@ _gnupg_socketdir_internal (int skip_checks, unsigned *r_info)
{ {
#if defined(HAVE_W32_SYSTEM) #if defined(HAVE_W32_SYSTEM)
char *name; char *name;
gpg_err_code_t ec;
(void)skip_checks; (void)skip_checks;
@ -1048,7 +1049,8 @@ _gnupg_socketdir_internal (int skip_checks, unsigned *r_info)
else if (!skip_checks) else if (!skip_checks)
{ {
/* Try to create the directory and check again. */ /* Try to create the directory and check again. */
if (gnupg_mkdir (name, "-rwx")) ec = gnupg_mkdir (name, "-rwx");
if (ec && ec != GPG_ERR_EEXIST)
*r_info |= 16; /* mkdir failed. */ *r_info |= 16; /* mkdir failed. */
else if (gnupg_stat (name, &sb)) else if (gnupg_stat (name, &sb))
{ {
@ -1105,6 +1107,7 @@ _gnupg_socketdir_internal (int skip_checks, unsigned *r_info)
const char *prefix; const char *prefix;
const char *s; const char *s;
char *name = NULL; char *name = NULL;
gpg_err_code_t ec;
*r_info = 0; *r_info = 0;
@ -1161,8 +1164,14 @@ _gnupg_socketdir_internal (int skip_checks, unsigned *r_info)
goto leave; goto leave;
} }
/* Try to create the directory and check again. */ /* Try to create the directory and check again.
if (gnupg_mkdir (prefix, "-rwx")) * Here comes a possible race condition:
* stat(2) above failed by ENOENT, but another process does
* mkdir(2) before we do mkdir(2)
* So, an error with EEXIST should be handled.
*/
ec = gnupg_mkdir (prefix, "-rwx");
if (ec && ec != GPG_ERR_EEXIST)
{ {
*r_info |= 16; /* mkdir failed. */ *r_info |= 16; /* mkdir failed. */
goto leave; goto leave;
@ -1221,7 +1230,8 @@ _gnupg_socketdir_internal (int skip_checks, unsigned *r_info)
else if (!skip_checks) else if (!skip_checks)
{ {
/* Try to create the directory and check again. */ /* Try to create the directory and check again. */
if (gnupg_mkdir (name, "-rwx")) ec = gnupg_mkdir (name, "-rwx");
if (ec && ec != GPG_ERR_EEXIST)
*r_info |= 16; /* mkdir failed. */ *r_info |= 16; /* mkdir failed. */
else if (stat (prefix, &sb)) else if (stat (prefix, &sb))
{ {