NetBSD/dist/ipf/lib/rwlock_emul.c
darrenr abd0900a99 Import IPFilter 4.1.34 into NetBSD
4.1.34 - Release 11 March 2010
2964907 uninitialised use compile error
2959506 ipfstat does not display rules with compat
2949139 FR_T_BUILTIN masked out incorrectly
2937422 packets filtered with pools should not be cached
2935529 use of rules with tags leads to deadlock
2917501 whitespace cleanup required
2881514 in/out object functions not wired for compatibility
2841771 ipf/ippool rule maintenace bugs: memory leak, ref-counter bug
2839698 H.323 proxy does not clear fin_state/fin_nat
2010-04-17 20:44:16 +00:00

134 lines
2.9 KiB
C

/* $NetBSD: rwlock_emul.c,v 1.1.1.3 2010/04/17 20:45:56 darrenr Exp $ */
/*
* Copyright (C) 2003 by Darren Reed.
*
* See the IPFILTER.LICENCE file for details on licencing.
*
* Id: rwlock_emul.c,v 1.1.4.2 2009/12/27 06:58:07 darrenr Exp
*/
#include "ipf.h"
#define EMM_MAGIC 0x97dd8b3a
void eMrwlock_read_enter(rw, file, line)
eMrwlock_t *rw;
char *file;
int line;
{
if (rw->eMrw_magic != EMM_MAGIC) {
fprintf(stderr, "%s:eMrwlock_read_enter(%p): bad magic: %#x\n",
rw->eMrw_owner, rw, rw->eMrw_magic);
abort();
}
if (rw->eMrw_read != 0 || rw->eMrw_write != 0) {
fprintf(stderr,
"%s:eMrwlock_read_enter(%p): already locked: %d/%d\n",
rw->eMrw_owner, rw, rw->eMrw_read, rw->eMrw_write);
abort();
}
rw->eMrw_read++;
rw->eMrw_heldin = file;
rw->eMrw_heldat = line;
}
void eMrwlock_write_enter(rw, file, line)
eMrwlock_t *rw;
char *file;
int line;
{
if (rw->eMrw_magic != EMM_MAGIC) {
fprintf(stderr, "%s:eMrwlock_write_enter(%p): bad magic: %#x\n",
rw->eMrw_owner, rw, rw->eMrw_magic);
abort();
}
if (rw->eMrw_read != 0 || rw->eMrw_write != 0) {
fprintf(stderr,
"%s:eMrwlock_write_enter(%p): already locked: %d/%d\n",
rw->eMrw_owner, rw, rw->eMrw_read, rw->eMrw_write);
abort();
}
rw->eMrw_write++;
rw->eMrw_heldin = file;
rw->eMrw_heldat = line;
}
void eMrwlock_downgrade(rw, file, line)
eMrwlock_t *rw;
char *file;
int line;
{
if (rw->eMrw_magic != EMM_MAGIC) {
fprintf(stderr, "%s:eMrwlock_write_enter(%p): bad magic: %#x\n",
rw->eMrw_owner, rw, rw->eMrw_magic);
abort();
}
if (rw->eMrw_read != 0 || rw->eMrw_write != 1) {
fprintf(stderr,
"%s:eMrwlock_write_enter(%p): already locked: %d/%d\n",
rw->eMrw_owner, rw, rw->eMrw_read, rw->eMrw_write);
abort();
}
rw->eMrw_write--;
rw->eMrw_read++;
rw->eMrw_heldin = file;
rw->eMrw_heldat = line;
}
void eMrwlock_exit(rw)
eMrwlock_t *rw;
{
if (rw->eMrw_magic != EMM_MAGIC) {
fprintf(stderr, "%s:eMrwlock_exit(%p): bad magic: %#x\n",
rw->eMrw_owner, rw, rw->eMrw_magic);
abort();
}
if (rw->eMrw_read != 1 && rw->eMrw_write != 1) {
fprintf(stderr, "%s:eMrwlock_exit(%p): not locked: %d/%d\n",
rw->eMrw_owner, rw, rw->eMrw_read, rw->eMrw_write);
abort();
}
if (rw->eMrw_read == 1)
rw->eMrw_read--;
else if (rw->eMrw_write == 1)
rw->eMrw_write--;
rw->eMrw_heldin = NULL;
rw->eMrw_heldat = 0;
}
void eMrwlock_init(rw, who)
eMrwlock_t *rw;
char *who;
{
if (rw->eMrw_magic == EMM_MAGIC) { /* safe bet ? */
fprintf(stderr,
"%s:eMrwlock_init(%p): already initialised?: %#x\n",
rw->eMrw_owner, rw, rw->eMrw_magic);
abort();
}
rw->eMrw_magic = EMM_MAGIC;
rw->eMrw_read = 0;
rw->eMrw_write = 0;
if (who != NULL)
rw->eMrw_owner = strdup(who);
else
rw->eMrw_owner = NULL;
}
void eMrwlock_destroy(rw)
eMrwlock_t *rw;
{
if (rw->eMrw_magic != EMM_MAGIC) {
fprintf(stderr, "%s:eMrwlock_destroy(%p): bad magic: %#x\n",
rw->eMrw_owner, rw, rw->eMrw_magic);
abort();
}
memset(rw, 0xa5, sizeof(*rw));
}