diff options
-rw-r--r-- | module.h | 81 | ||||
-rw-r--r-- | plugins/imklog/imklog.c | 82 | ||||
-rw-r--r-- | plugins/imklog/ksym_mod.c | 48 |
3 files changed, 22 insertions, 189 deletions
diff --git a/module.h b/module.h deleted file mode 100644 index 71eac2c4..00000000 --- a/module.h +++ /dev/null @@ -1,81 +0,0 @@ -/* Module definitions for klogd's module support - * - * Copyright 2007 by Rainer Gerhards and others - * - * This file is part of rsyslog. - * - * Rsyslog is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * Rsyslog is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with Rsyslog. If not, see <http://www.gnu.org/licenses/>. - * - * A copy of the GPL can be found in the file "COPYING" in this distribution. - */ -struct kernel_sym -{ - unsigned long value; - char name[60]; -}; - -struct module_symbol -{ - unsigned long value; - const char *name; -}; - -struct module_ref -{ - struct module *dep; /* "parent" pointer */ - struct module *ref; /* "child" pointer */ - struct module_ref *next_ref; -}; - -struct module_info -{ - unsigned long addr; - unsigned long size; - unsigned long flags; - long usecount; -}; - - -typedef struct { volatile int counter; } atomic_t; - -struct module -{ - unsigned long size_of_struct; /* == sizeof(module) */ - struct module *next; - const char *name; - unsigned long size; - - union - { - atomic_t usecount; - long pad; - } uc; /* Needs to keep its size - so says rth */ - - unsigned long flags; /* AUTOCLEAN et al */ - - unsigned nsyms; - unsigned ndeps; - - struct module_symbol *syms; - struct module_ref *deps; - struct module_ref *refs; - int (*init)(void); - void (*cleanup)(void); - const struct exception_table_entry *ex_table_start; - const struct exception_table_entry *ex_table_end; -#ifdef __alpha__ - unsigned long gp; -#endif -}; - diff --git a/plugins/imklog/imklog.c b/plugins/imklog/imklog.c index 3479a290..376d337f 100644 --- a/plugins/imklog/imklog.c +++ b/plugins/imklog/imklog.c @@ -92,7 +92,6 @@ static char *symfile = (char *) 0, static enum LOGSRC {none, proc, kernel} logsrc; -int debugging = 0; int symbols_twice = 0; @@ -284,10 +283,11 @@ static enum LOGSRC GetKernelLogSrc(void) if ( (kmsg = open(_PATH_KLOG, O_RDONLY)) < 0 ) { - fprintf(stderr, "rklogd: Cannot open proc file system, " \ - "%d - %s.\n", errno, strerror(errno)); - ksyslog(7, NULL, 0); - exit(1); + char sz[512]; + snprintf(sz, sizeof(sz), "rklogd: Cannot open proc file system, %d - %s.\n", errno, strerror(errno)); + logmsgInternal(LOG_SYSLOG|LOG_ERR, sz, ADDDATE); + ksyslog(7, NULL, 0); /* TODO: check this, implement more */ + return(none); } Syslog(LOG_INFO, "imklog %s, log source = %s started.", \ @@ -369,11 +369,8 @@ static void LogLine(char *ptr, int len) */ *line = 0; /* force null terminator */ - if ( debugging ) - { - fputs("Line buffer full:\n", stderr); - fprintf(stderr, "\tLine: %s\n", line); - } + dbgprintf("Line buffer full:\n"); + dbgprintf("\tLine: %s\n", line); Syslog( LOG_INFO, "%s", line_buff ); line = line_buff; @@ -567,10 +564,11 @@ static void LogKernelLine(void) memset(log_buffer, '\0', sizeof(log_buffer)); if ( (rdcnt = ksyslog(2, log_buffer, sizeof(log_buffer)-1)) < 0 ) { - if ( errno == EINTR ) + char sz[512]; + if(errno == EINTR) return; - fprintf(stderr, "rklogd: Error return from sys_sycall: " \ - "%d - %s\n", errno, strerror(errno)); + snprintf(sz, sizeof(sz), "rklogd: Error return from sys_sycall: %d - %s\n", errno, strerror(errno)); + logmsgInternal(LOG_SYSLOG|LOG_ERR, sz, ADDDATE); } else LogLine(log_buffer, rdcnt); @@ -603,62 +601,6 @@ static void LogProcLine(void) } -#if 0 -int main(int argc, char *argv[]) -{ - int ch, - use_output = 0; - - char *log_level = (char *) 0, - *output = (char *) 0; - - /* Parse the command-line. */ - while ((ch = getopt(argc, argv, "c:df:iIk:nopsvx2")) != EOF) - switch((char)ch) - { - case '2': /* Print lines with symbols twice. */ - symbols_twice = 1; - break; - case 'c': /* Set console message level. */ - log_level = optarg; - break; - case 'd': /* Activity debug mode. */ - debugging = 1; - break; - case 'f': /* Define an output file. */ - output = optarg; - use_output++; - break; - case 'k': /* Kernel symbol file. */ - symfile = optarg; - break; - case 'p': - SetParanoiaLevel(1); /* Load symbols on oops. */ - break; - case 's': /* Use syscall interface. */ - use_syscall = 1; - break; - case 'x': - symbol_lookup = 0; - break; - } - - - /* Set console logging level. */ - if ( log_level != (char *) 0 ) - { - if ( (strlen(log_level) > 1) || \ - (strchr("12345678", *log_level) == (char *) 0) ) - { - fprintf(stderr, "rklogd: Invalid console logging " - "level <%s> specified.\n", log_level); - return(1); - } - console_log_level = *log_level - '0'; - } -} -#endif - BEGINrunInput CODESTARTrunInput /* Determine where kernel logging information is to come from. */ @@ -690,10 +632,10 @@ CODESTARTrunInput LogProcLine(); break; case none: + /* TODO: We need to handle this case here somewhat more intelligent */ pause(); break; } -// CHKiRet(thrdSleep(pThrd, iMarkMessagePeriod, 0)); /* seconds, micro seconds */ } finalize_it: /* cleanup here */ diff --git a/plugins/imklog/ksym_mod.c b/plugins/imklog/ksym_mod.c index 2cf559ce..a8f4790e 100644 --- a/plugins/imklog/ksym_mod.c +++ b/plugins/imklog/ksym_mod.c @@ -150,12 +150,6 @@ struct Module *sym_array_modules = (struct Module *) 0; static int have_modules = 0; -#if defined(TEST) -static int debugging = 1; -#else -extern int debugging; -#endif - /* Function prototypes. */ static void FreeModules(void); @@ -179,9 +173,7 @@ static int symsort(const void *, const void *); * * True if loading is successful. **************************************************************************/ - -extern int InitMsyms() - +extern int InitMsyms(void) { auto int rtn, tmp; @@ -220,22 +212,17 @@ extern int InitMsyms() "- %s\n", strerror(errno)); return(0); } - if ( debugging ) - fprintf(stderr, "Loading kernel module symbols - " - "Size of table: %d\n", rtn); + dbgprintf("Loading kernel module symbols - Size of table: %d\n", rtn); - ksym_table = (struct kernel_sym *) malloc(rtn * \ - sizeof(struct kernel_sym)); + ksym_table = (struct kernel_sym *) malloc(rtn * sizeof(struct kernel_sym)); if ( ksym_table == (struct kernel_sym *) 0 ) { - Syslog(LOG_WARNING, " Failed memory allocation for kernel " \ - "symbol table.\n"); + Syslog(LOG_WARNING, " Failed memory allocation for kernel symbol table.\n"); return(0); } if ( (rtn = getsyms(ksym_table)) < 0 ) { - Syslog(LOG_WARNING, "Error reading kernel symbols - %s\n", \ - strerror(errno)); + Syslog(LOG_WARNING, "Error reading kernel symbols - %s\n", strerror(errno)); return(0); } @@ -279,12 +266,7 @@ extern int InitMsyms() } -static int symsort(p1, p2) - - const void *p1; - - const void *p2; - +static int symsort(const void *p1, const void *p2) { auto const struct sym_table *sym1 = p1, *sym2 = p2; @@ -307,9 +289,7 @@ static int symsort(p1, p2) * * Return: void **************************************************************************/ - -static void FreeModules() - +static void FreeModules(void) { auto int nmods, nsyms; @@ -436,7 +416,6 @@ static int AddModule(unsigned long address, char *symbol) AddSymbol(mp, address, symbol); } - return(1); } @@ -461,11 +440,7 @@ static int AddModule(unsigned long address, char *symbol) * A boolean value is assumed. True if the addition is * successful. False if not. **************************************************************************/ - -static int AddSymbol(mp, address, symbol) - struct Module *mp; - unsigned long address; - char *symbol; +static int AddSymbol(struct Module *mp, unsigned long address, char *symbol) { auto int tmp; @@ -513,10 +488,7 @@ static int AddSymbol(mp, address, symbol) * If a match is found the pointer to the symbolic name most * closely matching the address is returned. **************************************************************************/ - -extern char * LookupModuleSymbol(value, sym) - unsigned long value; - struct symbol *sym; +extern char * LookupModuleSymbol(unsigned long value, struct symbol *sym) { auto int nmod, nsym; @@ -614,5 +586,5 @@ extern char * LookupModuleSymbol(value, sym) } /* It has been a hopeless exercise. */ - return((char *) 0); + return(NULL); } |