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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
|
/*++
/* NAME
/* timed_ipc 3
/* SUMMARY
/* enforce IPC timeout on stream
/* SYNOPSIS
/* #include <time_ipc.h>
/*
/* void timed_ipc_setup(stream)
/* VSTREAM *stream;
/* DESCRIPTION
/* timed_ipc() enforces on the specified stream the timeout as
/* specified via the \fIipc_timeout\fR configuration parameter:
/* a read or write operation fails if it does not succeed within
/* \fIipc_timeout\fR seconds. This deadline exists as a safety
/* measure for communication between mail subsystem programs,
/* and should never be exceeded.
/* DIAGNOSTICS
/* Panic: sanity check failed. Fatal error: deadline exceeded.
/* LICENSE
/* .ad
/* .fi
/* The Secure Mailer license must be distributed with this software.
/* AUTHOR(S)
/* Wietse Venema
/* IBM T.J. Watson Research
/* P.O. Box 704
/* Yorktown Heights, NY 10598, USA
/*--*/
/* System library. */
#include <sys_defs.h>
#include <unistd.h>
/* Utility library. */
#include <msg.h>
#include <vstream.h>
#include <iostuff.h>
/* Global library. */
#include "mail_params.h"
#include "timed_ipc.h"
/* timed_ipc_read - read with timeout */
static int timed_ipc_read(int fd, void *buf, unsigned len)
{
if (read_wait(fd, var_ipc_timeout) < 0)
msg_fatal("timed_ipc_read: command read timeout");
return (read(fd, buf, len));
}
/* timed_ipc_write - read with timeout */
static int timed_ipc_write(int fd, void *buf, unsigned len)
{
if (write_wait(fd, var_ipc_timeout) < 0)
msg_fatal("timed_ipc_write: command write timeout");
return (write(fd, buf, len));
}
/* timed_ipc_setup - enable ipc with timeout */
void timed_ipc_setup(VSTREAM *stream)
{
if (var_ipc_timeout <= 0)
msg_panic("timed_ipc_setup: bad ipc_timeout %d", var_ipc_timeout);
vstream_control(stream,
VSTREAM_CTL_READ_FN, timed_ipc_read,
VSTREAM_CTL_WRITE_FN, timed_ipc_write,
VSTREAM_CTL_END);
}
|