1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-03 12:11:33 +01:00

common: Improve error return for dotlock.

* common/dotlock.c (dotlock_take_unix): Return a ETIMEDOUT insteaad of
EACCESS on timeout.
(dotlock_take_w32): Ditto.
This commit is contained in:
Werner Koch 2023-12-12 16:31:30 +01:00
parent 6b93b92111
commit f57717bf23
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B

View File

@ -1061,6 +1061,7 @@ static int
dotlock_take_unix (dotlock_t h, long timeout) dotlock_take_unix (dotlock_t h, long timeout)
{ {
int wtime = 0; int wtime = 0;
int timedout = 0;
int sumtime = 0; int sumtime = 0;
int pid; int pid;
int lastpid = -1; int lastpid = -1;
@ -1218,6 +1219,8 @@ dotlock_take_unix (dotlock_t h, long timeout)
wtime = 0; /* Reset because owner chnaged. */ wtime = 0; /* Reset because owner chnaged. */
wtimereal = next_wait_interval (&wtime, &timeout); wtimereal = next_wait_interval (&wtime, &timeout);
if (!timeout)
timedout = 1; /* remember. */
sumtime += wtimereal; sumtime += wtimereal;
if (sumtime >= 1500) if (sumtime >= 1500)
@ -1233,7 +1236,7 @@ dotlock_take_unix (dotlock_t h, long timeout)
goto again; goto again;
} }
my_set_errno (EACCES); my_set_errno (timedout? ETIMEDOUT : EACCES);
return -1; return -1;
} }
#endif /*HAVE_POSIX_SYSTEM*/ #endif /*HAVE_POSIX_SYSTEM*/
@ -1246,6 +1249,7 @@ static int
dotlock_take_w32 (dotlock_t h, long timeout) dotlock_take_w32 (dotlock_t h, long timeout)
{ {
int wtime = 0; int wtime = 0;
int timedout = 0;
int w32err; int w32err;
OVERLAPPED ovl; OVERLAPPED ovl;
@ -1273,6 +1277,8 @@ dotlock_take_w32 (dotlock_t h, long timeout)
int wtimereal; int wtimereal;
wtimereal = next_wait_interval (&wtime, &timeout); wtimereal = next_wait_interval (&wtime, &timeout);
if (!timeout)
timedout = 1; /* remember. */
if (wtime >= 800) if (wtime >= 800)
my_info_1 (_("waiting for lock %s...\n"), h->lockname); my_info_1 (_("waiting for lock %s...\n"), h->lockname);
@ -1281,7 +1287,7 @@ dotlock_take_w32 (dotlock_t h, long timeout)
goto again; goto again;
} }
my_set_errno (EACCES); my_set_errno (timedout? ETIMEDOUT : EACCES);
return -1; return -1;
} }
#endif /*HAVE_DOSISH_SYSTEM*/ #endif /*HAVE_DOSISH_SYSTEM*/