- Various small fixes.

This commit is contained in:
Guus Sliepen 2000-11-20 22:13:14 +00:00
parent 06afd357b0
commit 3a6200c1e3
8 changed files with 51 additions and 28 deletions

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: list.c,v 1.1.2.2 2000/11/16 22:13:08 zarq Exp $ $Id: list.c,v 1.1.2.3 2000/11/20 22:13:00 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -143,6 +143,7 @@ void list_append(list_t *list, void *data)
n = xmalloc_and_zero(sizeof(list_node_t)); n = xmalloc_and_zero(sizeof(list_node_t));
n->data = data; n->data = data;
n->prev = list->tail; n->prev = list->tail;
if(list->tail)
list->tail->next = n; list->tail->next = n;
list->tail = n; list->tail = n;
} }

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: connection.c,v 1.1.2.2 2000/11/20 19:41:10 guus Exp $ $Id: connection.c,v 1.1.2.3 2000/11/20 22:13:03 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -138,10 +138,14 @@ cp
connection_t *lookup_id(char *name) connection_t *lookup_id(char *name)
{ {
connection_t cl; connection_t cl, *p;
cp cp
cl.name = name; cl.name = name;
return rbl_search(connection_tree, &cl); p = rbl_search(connection_tree, &cl);
if(p && p->status.active)
return p;
else
return NULL;
cp cp
} }

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: connection.h,v 1.1.2.1 2000/11/20 19:12:11 guus Exp $ $Id: connection.h,v 1.1.2.2 2000/11/20 22:13:03 guus Exp $
*/ */
#ifndef __TINC_CONNECTION_H__ #ifndef __TINC_CONNECTION_H__
@ -116,7 +116,7 @@ extern void connection_del(connection_t *);
extern connection_t *lookup_id(char *); extern connection_t *lookup_id(char *);
extern void dump_connection_list(void); extern void dump_connection_list(void);
extern int read_host_config(connection_t *); extern int read_host_config(connection_t *);
extern void destroy_connection(void); extern void destroy_connection_tree(void);
extern void prune_connection_tree(void); extern void prune_connection_tree(void);
#endif /* __TINC_CONNECTION_H__ */ #endif /* __TINC_CONNECTION_H__ */

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: net.c,v 1.35.4.78 2000/11/20 19:41:10 guus Exp $ $Id: net.c,v 1.35.4.79 2000/11/20 22:13:03 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -1113,7 +1113,7 @@ cp
void terminate_connection(connection_t *cl) void terminate_connection(connection_t *cl)
{ {
connection_t *p; connection_t *p;
subnet_t *s; subnet_t *subnet;
rbl_t *rbl; rbl_t *rbl;
cp cp
@ -1155,7 +1155,11 @@ cp
/* Remove the associated subnets */ /* Remove the associated subnets */
rbl_delete_rbltree(cl->subnet_tree); RBL_FOREACH(cl->subnet_tree, rbl)
{
subnet = (subnet_t *)rbl->data;
subnet_del(subnet);
}
/* Check if this was our outgoing connection */ /* Check if this was our outgoing connection */

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: process.c,v 1.1.2.5 2000/11/20 19:12:13 guus Exp $ $Id: process.c,v 1.1.2.6 2000/11/20 22:13:12 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -44,7 +44,7 @@
#include "system.h" #include "system.h"
/* A list containing all our children */ /* A list containing all our children */
list_t *child_pids; list_t *child_pids = NULL;
/* If zero, don't detach from the terminal. */ /* If zero, don't detach from the terminal. */
int do_detach = 1; int do_detach = 1;
@ -55,6 +55,13 @@ extern char *identname;
extern char *pidfilename; extern char *pidfilename;
extern char **g_argv; extern char **g_argv;
void init_processes(void)
{
cp
child_pids = list_new();
cp
}
void memory_full(int size) void memory_full(int size)
{ {
syslog(LOG_ERR, _("Memory exhausted (couldn't allocate %d bytes), exiting."), size); syslog(LOG_ERR, _("Memory exhausted (couldn't allocate %d bytes), exiting."), size);
@ -67,6 +74,7 @@ void memory_full(int size)
*/ */
void cleanup_and_exit(int c) void cleanup_and_exit(int c)
{ {
cp
close_network_connections(); close_network_connections();
if(debug_lvl > DEBUG_NOTHING) if(debug_lvl > DEBUG_NOTHING)
@ -84,7 +92,7 @@ void cleanup_and_exit(int c)
int write_pidfile(void) int write_pidfile(void)
{ {
int pid; int pid;
cp
if((pid = check_pid(pidfilename))) if((pid = check_pid(pidfilename)))
{ {
if(netname) if(netname)
@ -98,7 +106,7 @@ int write_pidfile(void)
/* if it's locked, write-protected, or whatever */ /* if it's locked, write-protected, or whatever */
if(!write_pid(pidfilename)) if(!write_pid(pidfilename))
return 1; return 1;
cp
return 0; return 0;
} }
@ -108,7 +116,7 @@ int write_pidfile(void)
int kill_other(void) int kill_other(void)
{ {
int pid; int pid;
cp
if(!(pid = read_pid(pidfilename))) if(!(pid = read_pid(pidfilename)))
{ {
if(netname) if(netname)
@ -123,7 +131,7 @@ int kill_other(void)
if(kill(pid, SIGTERM) && errno == ESRCH) if(kill(pid, SIGTERM) && errno == ESRCH)
fprintf(stderr, _("Removing stale lock file.\n")); fprintf(stderr, _("Removing stale lock file.\n"));
remove_pid(pidfilename); remove_pid(pidfilename);
cp
return 0; return 0;
} }
@ -134,7 +142,7 @@ int detach(void)
{ {
int fd; int fd;
pid_t pid; pid_t pid;
cp
setup_signals(); setup_signals();
if(write_pidfile()) if(write_pidfile())
@ -152,7 +160,7 @@ int detach(void)
syslog(LOG_NOTICE, _("tincd %s starting"), VERSION); syslog(LOG_NOTICE, _("tincd %s starting"), VERSION);
xalloc_fail_func = memory_full; xalloc_fail_func = memory_full;
cp
return 0; return 0;
} }
@ -166,7 +174,7 @@ void _execute_script(const char *name)
int error = 0; int error = 0;
char *scriptname; char *scriptname;
char *s; char *s;
cp
if(netname) if(netname)
{ {
asprintf(&s, "NETNAME=%s", netname); asprintf(&s, "NETNAME=%s", netname);
@ -237,20 +245,22 @@ void _execute_script(const char *name)
int execute_script(const char *name) int execute_script(const char *name)
{ {
pid_t pid; pid_t pid;
cp
if((pid = fork()) < 0) if((pid = fork()) < 0)
{ {
syslog(LOG_ERR, _("System call `%s' failed: %m"), syslog(LOG_ERR, _("System call `%s' failed: %m"),
"fork"); "fork");
return -1; return -1;
} }
cp
if(pid) if(pid)
{ {
list_append(child_pids, (void*)(int)pid); syslog(LOG_DEBUG, "%p, %d (%p)", child_pids, pid, &pid);
list_append(child_pids, &pid);
cp
return 0; return 0;
} }
cp
/* Child here */ /* Child here */
_execute_script(name); _execute_script(name);
} }
@ -264,7 +274,7 @@ int check_child(void *data)
{ {
pid_t pid; pid_t pid;
int status; int status;
cp
pid = (pid_t) data; pid = (pid_t) data;
pid = waitpid(pid, &status, WNOHANG); pid = waitpid(pid, &status, WNOHANG);
if(WIFEXITED(status)) if(WIFEXITED(status))
@ -282,7 +292,7 @@ int check_child(void *data)
} }
return -1; return -1;
} }
cp
/* Child is still running */ /* Child is still running */
return 0; return 0;
} }

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: process.h,v 1.1.2.2 2000/11/16 22:12:23 zarq Exp $ $Id: process.h,v 1.1.2.3 2000/11/20 22:13:13 guus Exp $
*/ */
#ifndef __TINC_PROCESS_H__ #ifndef __TINC_PROCESS_H__
@ -29,6 +29,7 @@
extern list_t *child_pids; extern list_t *child_pids;
extern RETSIGTYPE parent_exit(int a); extern RETSIGTYPE parent_exit(int a);
extern void init_processes(void);
extern void setup_signals(void); extern void setup_signals(void);
extern int execute_script(const char *); extern int execute_script(const char *);
extern void check_children(void); extern void check_children(void);

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: subnet.c,v 1.1.2.13 2000/11/20 19:41:13 guus Exp $ $Id: subnet.c,v 1.1.2.14 2000/11/20 22:13:13 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -130,6 +130,7 @@ cp
void subnet_add(connection_t *cl, subnet_t *subnet) void subnet_add(connection_t *cl, subnet_t *subnet)
{ {
cp cp
subnet->owner = cl;
rbl_insert(subnet_tree, subnet); rbl_insert(subnet_tree, subnet);
rbl_insert(cl->subnet_tree, subnet); rbl_insert(cl->subnet_tree, subnet);
cp cp

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: tincd.c,v 1.10.4.31 2000/11/20 18:06:17 zarq Exp $ $Id: tincd.c,v 1.10.4.32 2000/11/20 22:13:14 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -321,6 +321,8 @@ main(int argc, char **argv, char **envp)
if(read_server_config()) if(read_server_config())
return 1; return 1;
init_processes();
if(detach()) if(detach())
exit(0); exit(0);