blob: a883e836504c8fb45a88481551d8e9080e66bb77 (
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
/*++
/* 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>
/* Utility library. */
#include <msg.h>
#include <vstream.h>
/* Global library. */
#include "mail_params.h"
#include "timed_ipc.h"
/* 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,
CA_VSTREAM_CTL_TIMEOUT(var_ipc_timeout),
CA_VSTREAM_CTL_END);
}
|