* $Author$
* $Header$
*
- * Copyright (C) 1987 by the Massachusetts Institute of Technology
*
* Utility functions used by the DCM.
+ *
+ * (c) Copyright 1987, 1988 by the Massachusetts Institute of Technology.
+ * For copying and distribution information, please see the file
+ * <mit-copyright.h>.
*/
#ifndef lint
static char *rcsid_utils_c = "$Header$";
#endif lint
+#include <mit-copyright.h>
#include <stdio.h>
-#include <strings.h>
+#include <string.h>
+#include <errno.h>
#include <varargs.h>
#include <sys/types.h>
#include <sys/time.h>
#include <sys/file.h>
-#include <zephyr/zephyr.h>
-#include <sms.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <moira.h>
+#include <moira_site.h>
#include "dcm.h"
}
-int maybe_lock_update(dir, host, service, exclusive)
-char *dir, *host, *service;
+int maybe_lock_update(host, service, exclusive)
+char *host, *service;
int exclusive;
{
char lock[BUFSIZ];
int fd;
+ flock_t fl;
- sprintf(lock, "%s/dcm/locks/%s.%s", dir, host, service);
- if ((fd = open(lock, O_TRUNC | O_CREAT, 0)) < 0)
+ sprintf(lock, "%s/%s.%s", LOCK_DIR, host, service);
+ fl.l_type = exclusive ? F_WRLCK : F_RDLCK;
+ fl.l_whence = fl.l_start = fl.l_len = 0;
+ if ((fd = open(lock, O_TRUNC | O_CREAT | O_RDWR, 0)) < 0)
com_err(whoami, errno, ": maybe_lock_update: opening %s", lock);
- else if (flock(fd, (exclusive ? LOCK_EX : LOCK_SH) | LOCK_NB) != 0) {
- if (errno != EWOULDBLOCK)
+ else if (fcntl(fd, F_SETLK, &fl) != 0) {
+ if (errno != EAGAIN)
com_err(whoami, errno, ": maybe_lock_update: flock");
else if (dbg & DBG_VERBOSE)
com_err(whoami, 0, "%s already locked\n", lock);
com_err(whoami, 0, "%s now locked\n", lock);
return fd;
}
-