- Don't use LOG() macro in initdata() until the config struct has been

allocated (uses config->debug).
- Initialise log_stream to stderr to catch errors before the config file
  is read.
This commit is contained in:
Brendan O'Dea 2005-05-05 02:39:54 +00:00
parent a24e3186ff
commit 07db0c42ba
3 changed files with 47 additions and 38 deletions

View file

@ -1,4 +1,4 @@
* Tue May 3 2005 Brendan O'Dea <bod@optusnet.com.au> 2.1.0 * Thu May 5 2005 Brendan O'Dea <bod@optusnet.com.au> 2.1.0
- Add IPv6 support from Jonathan McDowell. - Add IPv6 support from Jonathan McDowell.
- Add CHAP support from Jordan Hrycaj (work in progress). - Add CHAP support from Jordan Hrycaj (work in progress).
- Sanity check that cluster_send_session is not called from a child - Sanity check that cluster_send_session is not called from a child
@ -48,6 +48,10 @@
- Use cli_error() for error messages and help. - Use cli_error() for error messages and help.
- Add a Cisco-Avpair with intercept details to RADIUS Start/Stop - Add a Cisco-Avpair with intercept details to RADIUS Start/Stop
records. records.
- Don't use LOG() macro in initdata() until the config struct has been
allocated (uses config->debug).
- Initialise log_stream to stderr to catch errors before the config file
is read.
* Fri Dec 17 2004 Brendan O'Dea <bod@optusnet.com.au> 2.0.13 * Fri Dec 17 2004 Brendan O'Dea <bod@optusnet.com.au> 2.0.13
- Better cluster master collision resolution: keep a counter of state - Better cluster master collision resolution: keep a counter of state

View file

@ -4,7 +4,7 @@
// Copyright (c) 2002 FireBrick (Andrews & Arnold Ltd / Watchfront Ltd) - GPL licenced // Copyright (c) 2002 FireBrick (Andrews & Arnold Ltd / Watchfront Ltd) - GPL licenced
// vim: sw=8 ts=8 // vim: sw=8 ts=8
char const *cvs_id_l2tpns = "$Id: l2tpns.c,v 1.91 2005-04-27 13:53:15 bodea Exp $"; char const *cvs_id_l2tpns = "$Id: l2tpns.c,v 1.92 2005-05-05 02:39:54 bodea Exp $";
#include <arpa/inet.h> #include <arpa/inet.h>
#include <assert.h> #include <assert.h>
@ -69,7 +69,7 @@ time_t basetime = 0; // base clock
char hostname[1000] = ""; // us. char hostname[1000] = ""; // us.
static int tunidx; // ifr_ifindex of tun device static int tunidx; // ifr_ifindex of tun device
static int syslog_log = 0; // are we logging to syslog static int syslog_log = 0; // are we logging to syslog
static FILE *log_stream = NULL; // file handle for direct logging (i.e. direct into file, not via syslog). static FILE *log_stream = stderr; // file handle for direct logging (i.e. direct into file, not via syslog).
extern int cluster_sockfd; // Intra-cluster communications socket. extern int cluster_sockfd; // Intra-cluster communications socket.
uint32_t last_id = 0; // Unique ID for radius accounting uint32_t last_id = 0; // Unique ID for radius accounting
@ -3141,16 +3141,12 @@ static void initdata(int optdebug, char *optconfig)
{ {
int i; int i;
if (!(_statistics = shared_malloc(sizeof(struct Tstats))))
{
LOG(0, 0, 0, "Error doing malloc for _statistics: %s\n", strerror(errno));
exit(1);
}
if (!(config = shared_malloc(sizeof(configt)))) if (!(config = shared_malloc(sizeof(configt))))
{ {
LOG(0, 0, 0, "Error doing malloc for configuration: %s\n", strerror(errno)); fprintf(stderr, "Error doing malloc for configuration: %s\n", strerror(errno));
exit(1); exit(1);
} }
memset(config, 0, sizeof(configt)); memset(config, 0, sizeof(configt));
time(&config->start_time); time(&config->start_time);
strncpy(config->config_file, optconfig, strlen(optconfig)); strncpy(config->config_file, optconfig, strlen(optconfig));
@ -3159,6 +3155,20 @@ static void initdata(int optdebug, char *optconfig)
config->rl_rate = 28; // 28kbps config->rl_rate = 28; // 28kbps
strcpy(config->random_device, RANDOMDEVICE); strcpy(config->random_device, RANDOMDEVICE);
#ifdef RINGBUFFER
if (!(ringbuffer = shared_malloc(sizeof(struct Tringbuffer))))
{
LOG(0, 0, 0, "Error doing malloc for ringbuffer: %s\n", strerror(errno));
exit(1);
}
memset(ringbuffer, 0, sizeof(struct Tringbuffer));
#endif
if (!(_statistics = shared_malloc(sizeof(struct Tstats))))
{
LOG(0, 0, 0, "Error doing malloc for _statistics: %s\n", strerror(errno));
exit(1);
}
if (!(tunnel = shared_malloc(sizeof(tunnelt) * MAXTUNNEL))) if (!(tunnel = shared_malloc(sizeof(tunnelt) * MAXTUNNEL)))
{ {
LOG(0, 0, 0, "Error doing malloc for tunnels: %s\n", strerror(errno)); LOG(0, 0, 0, "Error doing malloc for tunnels: %s\n", strerror(errno));
@ -3195,15 +3205,6 @@ static void initdata(int optdebug, char *optconfig)
} }
memset(ip_filters, 0, sizeof(ip_filtert) * MAXFILTER); memset(ip_filters, 0, sizeof(ip_filtert) * MAXFILTER);
#ifdef RINGBUFFER
if (!(ringbuffer = shared_malloc(sizeof(struct Tringbuffer))))
{
LOG(0, 0, 0, "Error doing malloc for ringbuffer: %s\n", strerror(errno));
exit(1);
}
memset(ringbuffer, 0, sizeof(struct Tringbuffer));
#endif
if (!(cli_session_actions = shared_malloc(sizeof(struct cli_session_actions) * MAXSESSION))) if (!(cli_session_actions = shared_malloc(sizeof(struct cli_session_actions) * MAXSESSION)))
{ {
LOG(0, 0, 0, "Error doing malloc for cli session actions: %s\n", strerror(errno)); LOG(0, 0, 0, "Error doing malloc for cli session actions: %s\n", strerror(errno));
@ -3771,9 +3772,11 @@ int main(int argc, char *argv[])
static void sighup_handler(int sig) static void sighup_handler(int sig)
{ {
if (log_stream && log_stream != stderr) if (log_stream)
{ {
if (log_stream != stderr)
fclose(log_stream); fclose(log_stream);
log_stream = NULL; log_stream = NULL;
} }
@ -3895,7 +3898,9 @@ static void update_config()
syslog_log = 0; syslog_log = 0;
if (log_stream) if (log_stream)
{ {
if (log_stream != stderr)
fclose(log_stream); fclose(log_stream);
log_stream = NULL; log_stream = NULL;
} }

View file

@ -43,5 +43,5 @@ rm -rf %{buildroot}
%attr(644,root,root) /usr/share/man/man[58]/* %attr(644,root,root) /usr/share/man/man[58]/*
%changelog %changelog
* Tue May 3 2005 Brendan O'Dea <bod@optusnet.com.au> 2.1.0-1 * Thu May 5 2005 Brendan O'Dea <bod@optusnet.com.au> 2.1.0-1
- 2.1.0 release, see /usr/share/doc/l2tpns-2.1.0/Changes - 2.1.0 release, see /usr/share/doc/l2tpns-2.1.0/Changes