version 1.1.1.2, 2013/07/22 08:44:29
|
version 1.1.1.3, 2016/11/01 09:56:12
|
Line 26
|
Line 26
|
#include "ccp_mppc.h" |
#include "ccp_mppc.h" |
#endif |
#endif |
|
|
|
#ifdef USE_BACKTRACE |
|
#include <execinfo.h> |
|
#endif |
#include <netgraph.h> |
#include <netgraph.h> |
|
|
/* |
/* |
Line 47
|
Line 50
|
}; |
}; |
typedef struct option *Option; |
typedef struct option *Option; |
|
|
static const char *UsageStr = "[options] [system]"; | static const char *UsageStr = "[options] [configuration]"; |
static struct option OptList[] = { |
static struct option OptList[] = { |
{ 0, 'b', "background", "", |
{ 0, 'b', "background", "", |
"Run as a background daemon" }, |
"Run as a background daemon" }, |
Line 173 main(int ac, char *av[])
|
Line 176 main(int ac, char *av[])
|
Context c; |
Context c; |
PhysType pt; |
PhysType pt; |
|
|
gPid=getpid(); | gPid = getpid(); |
|
|
/* enable libpdel typed_mem */ |
/* enable libpdel typed_mem */ |
typed_mem_enable(); |
typed_mem_enable(); |
Line 265 main(int ac, char *av[])
|
Line 268 main(int ac, char *av[])
|
} |
} |
|
|
/* Create signaling pipe */ |
/* Create signaling pipe */ |
if ((ret = pipe(gSignalPipe)) != 0) { | if (pipe(gSignalPipe) < 0) { |
Log(LG_ERR, ("Could not create signal pipe %d", ret)); | Perror("Could not create signal pipe"); |
exit(EX_UNAVAILABLE); |
exit(EX_UNAVAILABLE); |
} |
} |
if (EventRegister(&gSignalEvent, EVENT_READ, gSignalPipe[0], |
if (EventRegister(&gSignalEvent, EVENT_READ, gSignalPipe[0], |
Line 320 static void
|
Line 323 static void
|
ConfigRead(int type, void *arg) |
ConfigRead(int type, void *arg) |
{ |
{ |
Context c = (Context)arg; |
Context c = (Context)arg; |
|
int err; |
|
|
/* Read startup configuration section */ |
/* Read startup configuration section */ |
ReadFile(gConfigFile, STARTUP_CONF, DoCommand, c); | err = ReadFile(gConfigFile, STARTUP_CONF, DoCommand, c); |
|
|
/* Read configuration as specified on the command line, or default */ |
/* Read configuration as specified on the command line, or default */ |
if (!gPeerSystem) | if (!gPeerSystem) { |
ReadFile(gConfigFile, DEFAULT_CONF, DoCommand, c); | if (err != -2) |
else { | ReadFile(gConfigFile, DEFAULT_CONF, DoCommand, c); |
if (ReadFile(gConfigFile, gPeerSystem, DoCommand, c) < 0) { | } else { |
| if (err == -2 || ReadFile(gConfigFile, gPeerSystem, DoCommand, c) < 0) { |
Log(LG_ERR, ("can't read configuration for \"%s\"", gPeerSystem)); |
Log(LG_ERR, ("can't read configuration for \"%s\"", gPeerSystem)); |
DoExit(EX_CONFIG); |
DoExit(EX_CONFIG); |
} |
} |
Line 469 FatalSignal(int sig)
|
Line 474 FatalSignal(int sig)
|
static struct pppTimer gDeathTimer; |
static struct pppTimer gDeathTimer; |
int k; |
int k; |
int upLinkCount; |
int upLinkCount; |
|
#ifdef USE_BACKTRACE |
|
void *buffer[100]; |
|
char **strings; |
|
int n; |
|
#endif |
|
|
/* If a SIGTERM or SIGINT, gracefully shutdown; otherwise shutdown now */ |
/* If a SIGTERM or SIGINT, gracefully shutdown; otherwise shutdown now */ |
Log(LG_ERR, ("caught fatal signal %s", sys_signame[sig])); |
Log(LG_ERR, ("caught fatal signal %s", sys_signame[sig])); |
gShutdownInProgress=1; |
gShutdownInProgress=1; |
|
#ifdef USE_BACKTRACE |
|
if (sig != SIGTERM && sig != SIGINT) { |
|
n = backtrace(buffer, 100); |
|
strings = backtrace_symbols(buffer, n); |
|
if (strings == NULL) { |
|
Log(LG_ERR, ("No backtrace symbols found")); |
|
} else { |
|
for (k = 0; k < n; k++) { |
|
Log(LG_ERR, ("%s", strings[k])); |
|
} |
|
free(strings); |
|
} |
|
} |
|
#endif |
for (k = 0; k < gNumBundles; k++) { |
for (k = 0; k < gNumBundles; k++) { |
if ((b = gBundles[k])) { |
if ((b = gBundles[k])) { |
if (sig != SIGTERM && sig != SIGINT) |
if (sig != SIGTERM && sig != SIGINT) |
Line 688 Usage(int ex)
|
Line 712 Usage(int ex)
|
opt = OptList + k; |
opt = OptList + k; |
snprintf(buf, sizeof(buf), " -%c, --%-s %s", |
snprintf(buf, sizeof(buf), " -%c, --%-s %s", |
opt->sflag, opt->lflag, opt->usage); |
opt->sflag, opt->lflag, opt->usage); |
fprintf(stderr, "%-40s%s\n", buf, opt->desc); | fprintf(stderr, "%-35s%s\n", buf, opt->desc); |
} |
} |
exit(ex); |
exit(ex); |
} |
} |