Fix lockf(3) cancellation behaviour.
Sponsored by: The FreeBSD Foundation MFC after: 1 week
This commit is contained in:
parent
3bbee5556a
commit
af98578a60
@ -36,6 +36,7 @@ __FBSDID("$FreeBSD$");
|
||||
#include <fcntl.h>
|
||||
#include <unistd.h>
|
||||
#include "un-namespace.h"
|
||||
#include "libc_private.h"
|
||||
|
||||
int
|
||||
lockf(int filedes, int function, off_t size)
|
||||
@ -62,9 +63,12 @@ lockf(int filedes, int function, off_t size)
|
||||
break;
|
||||
case F_TEST:
|
||||
fl.l_type = F_WRLCK;
|
||||
if (_fcntl(filedes, F_GETLK, &fl) == -1)
|
||||
if (((int (*)(int, int, ...))
|
||||
__libc_interposing[INTERPOS_fcntl])(filedes, F_GETLK, &fl)
|
||||
== -1)
|
||||
return (-1);
|
||||
if (fl.l_type == F_UNLCK || (fl.l_sysid == 0 && fl.l_pid == getpid()))
|
||||
if (fl.l_type == F_UNLCK || (fl.l_sysid == 0 &&
|
||||
fl.l_pid == getpid()))
|
||||
return (0);
|
||||
errno = EAGAIN;
|
||||
return (-1);
|
||||
@ -75,5 +79,6 @@ lockf(int filedes, int function, off_t size)
|
||||
/* NOTREACHED */
|
||||
}
|
||||
|
||||
return (_fcntl(filedes, cmd, &fl));
|
||||
return (((int (*)(int, int, ...))
|
||||
__libc_interposing[INTERPOS_fcntl])(filedes, cmd, &fl));
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user