blob: 0e53aa3aaf50dc45acc65df1318a0f96e5cd2df2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
/*
** Copyright 1998 - 1999 Double Precision, Inc. See COPYING for
** distribution information.
*/
#if HAVE_CONFIG_H
#include "config.h"
#endif
#include <sys/types.h>
#if HAVE_FCNTL_H
#include <fcntl.h>
#endif
#if HAVE_SYS_FCNTL_H
#include <sys/fcntl.h>
#endif
#if HAVE_SYS_FILE_H
#include <sys/file.h>
#endif
#include <errno.h>
#include "liblock.h"
int ll_lockfd(int fd, int ltype, LL_OFFSET_TYPE start, LL_OFFSET_TYPE len)
{
if (start || len
|| (ltype & ll_whence_curpos)
|| (ltype & ll_whence_end))
{
errno=EINVAL;
return (-1);
}
return (flock(fd, ltype & ll_unlock ? LOCK_UN:
(ltype & ll_writelock ? LOCK_EX:LOCK_SH) |
(ltype & ll_wait ? 0:LOCK_NB)));
}
|