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