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:
parent
4728d7f0df
commit
2ae017a25f
@ -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))
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user