syslogd: Integrate new timer API
Signed-off-by: Joachim Nilsson <troglobit@gmail.com>
This commit is contained in:
parent
5ac6c39687
commit
6e6c0ddfaa
@ -39,11 +39,10 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/socket.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
#include "queue.h"
|
#include "queue.h"
|
||||||
|
#include "socket.h"
|
||||||
#include "syslogd.h"
|
#include "syslogd.h"
|
||||||
|
|
||||||
struct sock {
|
struct sock {
|
||||||
|
@ -31,9 +31,12 @@
|
|||||||
#ifndef SYSKLOGD_SOCKET_H_
|
#ifndef SYSKLOGD_SOCKET_H_
|
||||||
#define SYSKLOGD_SOCKET_H_
|
#define SYSKLOGD_SOCKET_H_
|
||||||
|
|
||||||
|
#include <netdb.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
int socket_register(int sd, struct addrinfo *ai, void (*cb)(int, void *), void *arg);
|
int socket_register(int sd, struct addrinfo *ai, void (*cb)(int, void *), void *arg);
|
||||||
int socket_create (struct addrinfo *ai, void (*cb)(int, void *), void *arg);
|
int socket_create (struct addrinfo *ai, void (*cb)(int, void *), void *arg);
|
||||||
|
141
src/syslogd.c
141
src/syslogd.c
@ -91,6 +91,7 @@ static char sccsid[] __attribute__((unused)) =
|
|||||||
#define SYSLOG_NAMES
|
#define SYSLOG_NAMES
|
||||||
#include "syslogd.h"
|
#include "syslogd.h"
|
||||||
#include "socket.h"
|
#include "socket.h"
|
||||||
|
#include "timer.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
|
|
||||||
char *ConfFile = _PATH_LOGCONF;
|
char *ConfFile = _PATH_LOGCONF;
|
||||||
@ -128,7 +129,6 @@ static int MarkInterval = 20 * 60; /* interval between marks in seconds */
|
|||||||
static int family = PF_UNSPEC; /* protocol family (IPv4, IPv6 or both) */
|
static int family = PF_UNSPEC; /* protocol family (IPv4, IPv6 or both) */
|
||||||
static int mask_C1 = 1; /* mask characters from 0x80 - 0x9F */
|
static int mask_C1 = 1; /* mask characters from 0x80 - 0x9F */
|
||||||
static int send_to_all; /* send message to all IPv4/IPv6 addresses */
|
static int send_to_all; /* send message to all IPv4/IPv6 addresses */
|
||||||
static int MarkSeq = 0; /* mark sequence number */
|
|
||||||
static int SecureMode; /* when true, receive only unix domain socks */
|
static int SecureMode; /* when true, receive only unix domain socks */
|
||||||
|
|
||||||
static int RemoteAddDate; /* Always set the date on remote messages */
|
static int RemoteAddDate; /* Always set the date on remote messages */
|
||||||
@ -165,7 +165,8 @@ void wallmsg(struct filed *f, struct iovec *iov, int iovcnt);
|
|||||||
void reapchild();
|
void reapchild();
|
||||||
const char *cvtaddr(struct sockaddr_storage *f, int len);
|
const char *cvtaddr(struct sockaddr_storage *f, int len);
|
||||||
const char *cvthname(struct sockaddr *f, socklen_t len);
|
const char *cvthname(struct sockaddr *f, socklen_t len);
|
||||||
void domark();
|
void domark(void *arg);
|
||||||
|
void doflush(void *arg);
|
||||||
void debug_switch();
|
void debug_switch();
|
||||||
void die(int sig);
|
void die(int sig);
|
||||||
void doexit(int sig);
|
void doexit(int sig);
|
||||||
@ -422,15 +423,23 @@ int main(int argc, char *argv[])
|
|||||||
(void)signal(SIGINT, Debug ? die : SIG_IGN);
|
(void)signal(SIGINT, Debug ? die : SIG_IGN);
|
||||||
(void)signal(SIGQUIT, Debug ? die : SIG_IGN);
|
(void)signal(SIGQUIT, Debug ? die : SIG_IGN);
|
||||||
(void)signal(SIGCHLD, reapchild);
|
(void)signal(SIGCHLD, reapchild);
|
||||||
(void)signal(SIGALRM, domark);
|
|
||||||
(void)signal(SIGUSR1, Debug ? debug_switch : SIG_IGN);
|
(void)signal(SIGUSR1, Debug ? debug_switch : SIG_IGN);
|
||||||
(void)signal(SIGXFSZ, SIG_IGN);
|
(void)signal(SIGXFSZ, SIG_IGN);
|
||||||
(void)signal(SIGHUP, sighup_handler);
|
(void)signal(SIGHUP, sighup_handler);
|
||||||
alarm(TIMERINTVL);
|
|
||||||
|
|
||||||
logit("Starting.\n");
|
logit("Starting.\n");
|
||||||
init();
|
init();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Set up timer callbacks for -- MARK -- et al
|
||||||
|
*/
|
||||||
|
if (MarkInterval > 0)
|
||||||
|
timer_add(TIMERINTVL, domark, NULL);
|
||||||
|
timer_add(FLUSHINTVL, doflush, NULL);
|
||||||
|
|
||||||
|
/* Start 'em */
|
||||||
|
timer_start();
|
||||||
|
|
||||||
if (Debug) {
|
if (Debug) {
|
||||||
logit("Debugging disabled, SIGUSR1 to turn on debugging.\n");
|
logit("Debugging disabled, SIGUSR1 to turn on debugging.\n");
|
||||||
debugging_on = 0;
|
debugging_on = 0;
|
||||||
@ -464,16 +473,8 @@ int main(int argc, char *argv[])
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rc == 0) {
|
if (rc < 0 && errno != EINTR)
|
||||||
logit("No select activity.\n");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (rc < 0) {
|
|
||||||
if (errno != EINTR)
|
|
||||||
ERR("select()");
|
ERR("select()");
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -989,7 +990,7 @@ parsemsg_rfc3164(const char *from, int pri, char *msg)
|
|||||||
* This loop can only run for at most three
|
* This loop can only run for at most three
|
||||||
* iterations before terminating.
|
* iterations before terminating.
|
||||||
*/
|
*/
|
||||||
t_now = time(NULL);
|
t_now = timer_now();
|
||||||
localtime_r(&t_now, &tm_now);
|
localtime_r(&t_now, &tm_now);
|
||||||
for (year = tm_now.tm_year + 1;; --year) {
|
for (year = tm_now.tm_year + 1;; --year) {
|
||||||
assert(year >= tm_now.tm_year - 1);
|
assert(year >= tm_now.tm_year - 1);
|
||||||
@ -1089,6 +1090,11 @@ parsemsg(const char *from, char *msg)
|
|||||||
if ((pri & LOG_FACMASK) == LOG_KERN && !KeepKernFac)
|
if ((pri & LOG_FACMASK) == LOG_KERN && !KeepKernFac)
|
||||||
pri = LOG_MAKEPRI(LOG_USER, LOG_PRI(pri));
|
pri = LOG_MAKEPRI(LOG_USER, LOG_PRI(pri));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Message looks OK, update current time and log it
|
||||||
|
*/
|
||||||
|
timer_update();
|
||||||
|
|
||||||
/* Parse VERSION. */
|
/* Parse VERSION. */
|
||||||
msg += i + 1;
|
msg += i + 1;
|
||||||
if (msg[0] == '1' && msg[1] == ' ')
|
if (msg[0] == '1' && msg[1] == ' ')
|
||||||
@ -1156,7 +1162,22 @@ char *textpri(int pri)
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
time_t now;
|
static void check_timestamp(struct buf_msg *buffer)
|
||||||
|
{
|
||||||
|
struct logtime zero = { 0 };
|
||||||
|
struct logtime now;
|
||||||
|
struct timeval tv;
|
||||||
|
|
||||||
|
if (memcmp(&buffer->timestamp, &zero, sizeof(zero)))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (gettimeofday(&tv, NULL) == -1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
localtime_r(&tv.tv_sec, &now.tm);
|
||||||
|
now.usec = tv.tv_usec;
|
||||||
|
buffer->timestamp = now;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Logs a message to the appropriate log files, users, etc. based on the
|
* Logs a message to the appropriate log files, users, etc. based on the
|
||||||
@ -1166,9 +1187,6 @@ time_t now;
|
|||||||
*/
|
*/
|
||||||
static void logmsg(struct buf_msg *buffer)
|
static void logmsg(struct buf_msg *buffer)
|
||||||
{
|
{
|
||||||
struct logtime timestamp_now;
|
|
||||||
struct logtime zero = { 0 };
|
|
||||||
struct timeval tv;
|
|
||||||
struct filed *f;
|
struct filed *f;
|
||||||
sigset_t mask;
|
sigset_t mask;
|
||||||
size_t savedlen;
|
size_t savedlen;
|
||||||
@ -1179,13 +1197,8 @@ static void logmsg(struct buf_msg *buffer)
|
|||||||
textpri(buffer->pri), buffer->flags, buffer->hostname, buffer->app_name,
|
textpri(buffer->pri), buffer->flags, buffer->hostname, buffer->app_name,
|
||||||
buffer->proc_id, buffer->msgid, buffer->sd, buffer->msg);
|
buffer->proc_id, buffer->msgid, buffer->sd, buffer->msg);
|
||||||
|
|
||||||
(void)gettimeofday(&tv, NULL);
|
/* Messages generated by syslogd itself may not have a timestamp */
|
||||||
now = tv.tv_sec;
|
check_timestamp(buffer);
|
||||||
if (!memcmp(&buffer->timestamp, &zero, sizeof(zero))) {
|
|
||||||
localtime_r(&now, ×tamp_now.tm);
|
|
||||||
timestamp_now.usec = tv.tv_usec;
|
|
||||||
buffer->timestamp = timestamp_now;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* extract facility and priority level */
|
/* extract facility and priority level */
|
||||||
if (buffer->flags & MARK)
|
if (buffer->flags & MARK)
|
||||||
@ -1245,8 +1258,19 @@ static void logmsg(struct buf_msg *buffer)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* don't output marks to recently written files */
|
/* don't output marks to recently written files */
|
||||||
if ((buffer->flags & MARK) && (now - f->f_time) < MarkInterval / 2)
|
if (buffer->flags & MARK) {
|
||||||
|
time_t t_now = timer_now();
|
||||||
|
|
||||||
|
fprintf(stderr, "1) f_time: %zd + MarkInterval: %d => %ld, t_now: %zd\n",
|
||||||
|
f->f_time, MarkInterval, f->f_time + MarkInterval, t_now);
|
||||||
|
if (f->f_time + MarkInterval > t_now)
|
||||||
continue;
|
continue;
|
||||||
|
fprintf(stderr, "2) t_now: %zd - f_time: %zd => %ld < MarkInterval/2 : %d\n",
|
||||||
|
t_now, f->f_time, t_now - f->f_time, MarkInterval / 2);
|
||||||
|
if (t_now - f->f_time < MarkInterval / 2)
|
||||||
|
continue;
|
||||||
|
fprintf(stderr, "3) f_time: %zd, MarkInterval: %d, t_now: %zd\n", f->f_time, MarkInterval, t_now);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* suppress duplicate lines to this file
|
* suppress duplicate lines to this file
|
||||||
@ -1256,7 +1280,7 @@ static void logmsg(struct buf_msg *buffer)
|
|||||||
f->f_lasttime = buffer->timestamp;
|
f->f_lasttime = buffer->timestamp;
|
||||||
f->f_prevcount++;
|
f->f_prevcount++;
|
||||||
logit("msg repeated %d times, %ld sec of %d.\n",
|
logit("msg repeated %d times, %ld sec of %d.\n",
|
||||||
f->f_prevcount, now - f->f_time,
|
f->f_prevcount, timer_now() - f->f_time,
|
||||||
repeatinterval[f->f_repeatcount]);
|
repeatinterval[f->f_repeatcount]);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1265,7 +1289,7 @@ static void logmsg(struct buf_msg *buffer)
|
|||||||
* but back off so we'll flush less often
|
* but back off so we'll flush less often
|
||||||
* in the future.
|
* in the future.
|
||||||
*/
|
*/
|
||||||
if (now > REPEATTIME(f)) {
|
if (timer_now() > REPEATTIME(f)) {
|
||||||
fprintlog_successive(f, buffer->flags);
|
fprintlog_successive(f, buffer->flags);
|
||||||
BACKOFF(f);
|
BACKOFF(f);
|
||||||
}
|
}
|
||||||
@ -1366,12 +1390,12 @@ void fprintlog_write(struct filed *f, struct iovec *iov, int iovcnt, int flags)
|
|||||||
|
|
||||||
switch (f->f_type) {
|
switch (f->f_type) {
|
||||||
case F_UNUSED:
|
case F_UNUSED:
|
||||||
f->f_time = now;
|
f->f_time = timer_now();
|
||||||
logit("\n");
|
logit("\n");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case F_FORW_SUSP:
|
case F_FORW_SUSP:
|
||||||
fwd_suspend = time(NULL) - f->f_time;
|
fwd_suspend = timer_now() - f->f_time;
|
||||||
if (fwd_suspend >= INET_SUSPEND_TIME) {
|
if (fwd_suspend >= INET_SUSPEND_TIME) {
|
||||||
logit("\nForwarding suspension over, retrying FORW ");
|
logit("\nForwarding suspension over, retrying FORW ");
|
||||||
f->f_type = F_FORW;
|
f->f_type = F_FORW;
|
||||||
@ -1390,7 +1414,7 @@ void fprintlog_write(struct filed *f, struct iovec *iov, int iovcnt, int flags)
|
|||||||
case F_FORW:
|
case F_FORW:
|
||||||
f_forw:
|
f_forw:
|
||||||
logit(" %s:%s\n", f->f_un.f_forw.f_hname, f->f_un.f_forw.f_serv);
|
logit(" %s:%s\n", f->f_un.f_forw.f_hname, f->f_un.f_forw.f_serv);
|
||||||
f->f_time = now;
|
f->f_time = timer_now();
|
||||||
|
|
||||||
memset(&msg, 0, sizeof(msg));
|
memset(&msg, 0, sizeof(msg));
|
||||||
msg.msg_iov = iov;
|
msg.msg_iov = iov;
|
||||||
@ -1444,7 +1468,7 @@ void fprintlog_write(struct filed *f, struct iovec *iov, int iovcnt, int flags)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case F_CONSOLE:
|
case F_CONSOLE:
|
||||||
f->f_time = now;
|
f->f_time = timer_now();
|
||||||
if (flags & IGN_CONS) {
|
if (flags & IGN_CONS) {
|
||||||
logit(" (ignored).\n");
|
logit(" (ignored).\n");
|
||||||
break;
|
break;
|
||||||
@ -1454,7 +1478,7 @@ void fprintlog_write(struct filed *f, struct iovec *iov, int iovcnt, int flags)
|
|||||||
case F_TTY:
|
case F_TTY:
|
||||||
case F_FILE:
|
case F_FILE:
|
||||||
case F_PIPE:
|
case F_PIPE:
|
||||||
f->f_time = now;
|
f->f_time = timer_now();
|
||||||
logit(" %s\n", f->f_un.f_fname);
|
logit(" %s\n", f->f_un.f_fname);
|
||||||
if (f->f_type == F_TTY || f->f_type == F_CONSOLE) {
|
if (f->f_type == F_TTY || f->f_type == F_CONSOLE) {
|
||||||
pushiov(iov, iovcnt, "\r\n");
|
pushiov(iov, iovcnt, "\r\n");
|
||||||
@ -1514,7 +1538,7 @@ void fprintlog_write(struct filed *f, struct iovec *iov, int iovcnt, int flags)
|
|||||||
|
|
||||||
case F_USERS:
|
case F_USERS:
|
||||||
case F_WALL:
|
case F_WALL:
|
||||||
f->f_time = now;
|
f->f_time = timer_now();
|
||||||
logit("\n");
|
logit("\n");
|
||||||
pushiov(iov, iovcnt, "\r\n");
|
pushiov(iov, iovcnt, "\r\n");
|
||||||
wallmsg(f, &iov[1], iovcnt - 1);
|
wallmsg(f, &iov[1], iovcnt - 1);
|
||||||
@ -1619,25 +1643,15 @@ static int fmt5424(struct buf_msg *buffer, char *fmt, struct iovec *iov, size_t
|
|||||||
|
|
||||||
static void fprintlog_first(struct filed *f, struct buf_msg *buffer)
|
static void fprintlog_first(struct filed *f, struct buf_msg *buffer)
|
||||||
{
|
{
|
||||||
struct logtime zero = { 0 };
|
|
||||||
struct iovec iov[20];
|
struct iovec iov[20];
|
||||||
int iovcnt;
|
int iovcnt;
|
||||||
|
|
||||||
logit("Called fprintlog_first(), ");
|
logit("Called fprintlog_first(), ");
|
||||||
|
|
||||||
if (!memcmp(&buffer->timestamp, &zero, sizeof(zero))) {
|
/* Messages generated by syslogd itself may not have a timestamp */
|
||||||
struct logtime timestamp_now;
|
check_timestamp(buffer);
|
||||||
struct timeval tv;
|
|
||||||
|
|
||||||
(void)gettimeofday(&tv, NULL);
|
f->f_time = timer_now();
|
||||||
now = tv.tv_sec;
|
|
||||||
|
|
||||||
localtime_r(&now, ×tamp_now.tm);
|
|
||||||
timestamp_now.usec = tv.tv_usec;
|
|
||||||
buffer->timestamp = timestamp_now;
|
|
||||||
}
|
|
||||||
|
|
||||||
f->f_time = now;
|
|
||||||
f->f_prevcount = 0;
|
f->f_prevcount = 0;
|
||||||
|
|
||||||
if (f->f_flags & RFC5424)
|
if (f->f_flags & RFC5424)
|
||||||
@ -1706,12 +1720,14 @@ void wallmsg(struct filed *f, struct iovec *iov, int iovcnt)
|
|||||||
* and doing notty().
|
* and doing notty().
|
||||||
*/
|
*/
|
||||||
if (fork() == 0) {
|
if (fork() == 0) {
|
||||||
|
time_t t_now = timer_now();
|
||||||
|
|
||||||
(void)signal(SIGTERM, SIG_DFL);
|
(void)signal(SIGTERM, SIG_DFL);
|
||||||
(void)alarm(0);
|
(void)alarm(0);
|
||||||
|
|
||||||
(void)snprintf(greetings, sizeof(greetings),
|
(void)snprintf(greetings, sizeof(greetings),
|
||||||
"\r\n\7Message from syslogd@%s at %.24s ...\r\n",
|
"\r\n\7Message from syslogd@%s at %.24s ...\r\n",
|
||||||
(char *)iov[3].iov_base, ctime(&now));
|
(char *)iov[3].iov_base, ctime(&t_now));
|
||||||
len = strlen(greetings);
|
len = strlen(greetings);
|
||||||
|
|
||||||
/* scan the user login file */
|
/* scan the user login file */
|
||||||
@ -1893,7 +1909,7 @@ static void forw_lookup(struct filed *f)
|
|||||||
/* Called from cfline() for initial lookup? */
|
/* Called from cfline() for initial lookup? */
|
||||||
init = f->f_type == F_UNUSED ? 1 : 0;
|
init = f->f_type == F_UNUSED ? 1 : 0;
|
||||||
|
|
||||||
diff = now - f->f_time;
|
diff = timer_now() - f->f_time;
|
||||||
if (!init && diff < INET_SUSPEND_TIME) {
|
if (!init && diff < INET_SUSPEND_TIME) {
|
||||||
logit("Forwarding suspension not over, time left: %d\n",
|
logit("Forwarding suspension not over, time left: %d\n",
|
||||||
(int)(INET_SUSPEND_TIME - diff));
|
(int)(INET_SUSPEND_TIME - diff));
|
||||||
@ -1907,7 +1923,7 @@ static void forw_lookup(struct filed *f)
|
|||||||
if (err) {
|
if (err) {
|
||||||
WARN("Failed resolving '%s:%s': %s", host, serv, gai_strerror(err));
|
WARN("Failed resolving '%s:%s': %s", host, serv, gai_strerror(err));
|
||||||
f->f_type = F_FORW_UNKN;
|
f->f_type = F_FORW_UNKN;
|
||||||
f->f_time = now;
|
f->f_time = timer_now();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1919,27 +1935,22 @@ static void forw_lookup(struct filed *f)
|
|||||||
f->f_prevcount = 0;
|
f->f_prevcount = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void domark(int signo)
|
void domark(void *arg)
|
||||||
|
{
|
||||||
|
flog(INTERNAL_MARK | LOG_INFO, "-- MARK --");
|
||||||
|
}
|
||||||
|
|
||||||
|
void doflush(void *arg)
|
||||||
{
|
{
|
||||||
struct filed *f;
|
struct filed *f;
|
||||||
|
|
||||||
now = time(NULL);
|
|
||||||
|
|
||||||
if (MarkInterval > 0) {
|
|
||||||
MarkSeq += TIMERINTVL;
|
|
||||||
if (MarkSeq >= MarkInterval) {
|
|
||||||
flog(INTERNAL_MARK | LOG_INFO, "-- MARK --");
|
|
||||||
MarkSeq = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
SIMPLEQ_FOREACH(f, &fhead, f_link) {
|
SIMPLEQ_FOREACH(f, &fhead, f_link) {
|
||||||
if (f->f_type == F_FORW_UNKN) {
|
if (f->f_type == F_FORW_UNKN) {
|
||||||
forw_lookup(f);
|
forw_lookup(f);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (f->f_prevcount && now >= REPEATTIME(f)) {
|
if (f->f_prevcount && timer_now() >= REPEATTIME(f)) {
|
||||||
logit("flush %s: repeated %d times, %d sec.\n",
|
logit("flush %s: repeated %d times, %d sec.\n",
|
||||||
TypeNames[f->f_type], f->f_prevcount,
|
TypeNames[f->f_type], f->f_prevcount,
|
||||||
repeatinterval[f->f_repeatcount]);
|
repeatinterval[f->f_repeatcount]);
|
||||||
@ -1947,8 +1958,6 @@ void domark(int signo)
|
|||||||
BACKOFF(f);
|
BACKOFF(f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
(void)alarm(TIMERINTVL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void debug_switch(int signo)
|
void debug_switch(int signo)
|
||||||
@ -2059,6 +2068,10 @@ void init(void)
|
|||||||
char *p;
|
char *p;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* Set up timer framework */
|
||||||
|
if (timer_init())
|
||||||
|
err(1, "Failed initializing internal timers");
|
||||||
|
|
||||||
/* Get hostname */
|
/* Get hostname */
|
||||||
(void)gethostname(LocalHostName, sizeof(LocalHostName));
|
(void)gethostname(LocalHostName, sizeof(LocalHostName));
|
||||||
LocalDomain = emptystring;
|
LocalDomain = emptystring;
|
||||||
|
@ -43,7 +43,8 @@
|
|||||||
#define MAXSVLINE MAXLINE /* maximum saved line length */
|
#define MAXSVLINE MAXLINE /* maximum saved line length */
|
||||||
#define DEFUPRI (LOG_USER | LOG_NOTICE)
|
#define DEFUPRI (LOG_USER | LOG_NOTICE)
|
||||||
#define DEFSPRI (LOG_KERN | LOG_CRIT)
|
#define DEFSPRI (LOG_KERN | LOG_CRIT)
|
||||||
#define TIMERINTVL 15 /* interval for checking flush, mark */
|
#define TIMERINTVL 30 /* interval for checking flush, mark */
|
||||||
|
#define FLUSHINTVL 10 /* interval for checking flush, mark */
|
||||||
#define RCVBUF_MINSIZE (80 * MAXLINE) /* minimum size of dgram rcv buffer */
|
#define RCVBUF_MINSIZE (80 * MAXLINE) /* minimum size of dgram rcv buffer */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user