Remove global variable "now".
This commit is contained in:
		
							parent
							
								
									7e1117197c
								
							
						
					
					
						commit
						ddc6a81a85
					
				
					 10 changed files with 18 additions and 38 deletions
				
			
		|  | @ -104,7 +104,6 @@ typedef struct connection_t { | |||
| 	struct event outev;			/* events on this metadata connection */ | ||||
| 
 | ||||
| 	time_t last_ping_time;		/* last time we saw some activity from the other end or pinged them */ | ||||
| 	time_t last_flushed_time;	/* last time buffer was empty. Only meaningful if outbuflen > 0 */ | ||||
| 
 | ||||
| 	avl_tree_t *config_tree;	/* Pointer to configuration tree belonging to him */ | ||||
| } connection_t; | ||||
|  |  | |||
|  | @ -45,7 +45,6 @@ bool send_meta(connection_t *c, const char *buffer, int length) | |||
| 			   c->name, c->hostname); | ||||
| 
 | ||||
| 	if(!c->outbuflen) { | ||||
| 		c->last_flushed_time = now; | ||||
| 		if(event_add(&c->outev, NULL) < 0) { | ||||
| 			logger(LOG_EMERG, _("event_add failed: %s"), strerror(errno)); | ||||
| 			abort(); | ||||
|  | @ -239,7 +238,7 @@ bool receive_meta(connection_t *c) | |||
| 		return false; | ||||
| 	} | ||||
| 
 | ||||
| 	c->last_ping_time = now; | ||||
| 	c->last_ping_time = time(NULL); | ||||
| 
 | ||||
| 	return true; | ||||
| } | ||||
|  |  | |||
							
								
								
									
										25
									
								
								src/net.c
									
										
									
									
									
								
							
							
						
						
									
										25
									
								
								src/net.c
									
										
									
									
									
								
							|  | @ -41,8 +41,6 @@ | |||
| 
 | ||||
| volatile bool running = false; | ||||
| 
 | ||||
| time_t now = 0; | ||||
| 
 | ||||
| /* Purge edges and subnets of unreachable nodes. Use carefully. */ | ||||
| 
 | ||||
| static void purge(void) | ||||
|  | @ -208,6 +206,7 @@ static void check_dead_connections(void) | |||
| { | ||||
| 	avl_node_t *node, *next; | ||||
| 	connection_t *c; | ||||
| 	time_t now = time(NULL); | ||||
| 
 | ||||
| 	cp(); | ||||
| 
 | ||||
|  | @ -243,16 +242,6 @@ static void check_dead_connections(void) | |||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if(c->outbuflen > 0 && c->last_flushed_time + pingtimeout < now) { | ||||
| 			if(c->status.active) { | ||||
| 				ifdebug(CONNECTIONS) logger(LOG_INFO, | ||||
| 						_("%s (%s) could not flush for %ld seconds (%d bytes remaining)"), | ||||
| 						c->name, c->hostname, now - c->last_flushed_time, c->outbuflen); | ||||
| 				c->status.timeout = true; | ||||
| 				terminate_connection(c, true); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | @ -437,16 +426,13 @@ int main_loop(void) | |||
| 	signal_set(&sigalrm_event, SIGALRM, sigalrm_handler, NULL); | ||||
| 	signal_add(&sigalrm_event, NULL); | ||||
| 
 | ||||
| 	last_ping_check = now; | ||||
| 	last_ping_check = time(NULL); | ||||
| 	 | ||||
| 	srand(now); | ||||
| 	srand(time(NULL)); | ||||
| 
 | ||||
| 	running = true; | ||||
| 
 | ||||
| 	while(running) { | ||||
| 		now = time(NULL); | ||||
| 
 | ||||
| 	//	tv.tv_sec = 1 + (rand() & 7);	/* Approx. 5 seconds, randomized to prevent global synchronisation effects */
 | ||||
| 		tv.tv_sec = 1; | ||||
| 		tv.tv_usec = 0; | ||||
| 
 | ||||
|  | @ -463,7 +449,6 @@ int main_loop(void) | |||
| 		} | ||||
| 
 | ||||
| 		r = event_loop(EVLOOP_ONCE); | ||||
| 		now = time(NULL); | ||||
| 		if(r < 0) { | ||||
| 			logger(LOG_ERR, _("Error while waiting for input: %s"), | ||||
| 				   strerror(errno)); | ||||
|  | @ -477,9 +462,9 @@ int main_loop(void) | |||
| 
 | ||||
| 		/* Let's check if everybody is still alive */ | ||||
| 
 | ||||
| 		if(last_ping_check + pingtimeout < now) { | ||||
| 		if(last_ping_check + pingtimeout < time(NULL)) { | ||||
| 			check_dead_connections(); | ||||
| 			last_ping_check = now; | ||||
| 			last_ping_check = time(NULL); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -128,7 +128,6 @@ extern int keylifetime; | |||
| extern bool do_prune; | ||||
| extern bool do_purge; | ||||
| extern char *myport; | ||||
| extern time_t now; | ||||
| extern EVP_CIPHER_CTX packet_ctx; | ||||
| 
 | ||||
| /* Yes, very strange placement indeed, but otherwise the typedefs get all tangled up */ | ||||
|  |  | |||
|  | @ -263,9 +263,6 @@ static void receive_udppacket(node_t *n, vpn_packet_t *inpkt) | |||
| 		inpkt = outpkt; | ||||
| 	} | ||||
| 
 | ||||
| 	if(n->connection) | ||||
| 		n->connection->last_ping_time = now; | ||||
| 
 | ||||
| 	if(!inpkt->data[12] && !inpkt->data[13]) | ||||
| 		mtu_probe_h(n, inpkt); | ||||
| 	else | ||||
|  |  | |||
|  | @ -580,8 +580,6 @@ bool setup_network_connections(void) | |||
| { | ||||
| 	cp(); | ||||
| 
 | ||||
| 	now = time(NULL); | ||||
| 
 | ||||
| 	init_connections(); | ||||
| 	init_subnets(); | ||||
| 	init_nodes(); | ||||
|  |  | |||
|  | @ -261,7 +261,7 @@ void finish_connecting(connection_t *c) | |||
| 
 | ||||
| 	configure_tcp(c); | ||||
| 
 | ||||
| 	c->last_ping_time = now; | ||||
| 	c->last_ping_time = time(NULL); | ||||
| 	c->status.connecting = false; | ||||
| 
 | ||||
| 	send_id(c); | ||||
|  | @ -391,7 +391,7 @@ void setup_outgoing_connection(outgoing_t *outgoing) | |||
| 	} | ||||
| 
 | ||||
| 	c->outgoing = outgoing; | ||||
| 	c->last_ping_time = now; | ||||
| 	c->last_ping_time = time(NULL); | ||||
| 
 | ||||
| 	connection_add(c); | ||||
| 
 | ||||
|  | @ -437,7 +437,7 @@ void handle_new_meta_connection(int sock, short events, void *data) | |||
| 	c->address = sa; | ||||
| 	c->hostname = sockaddr2hostname(&sa); | ||||
| 	c->socket = fd; | ||||
| 	c->last_ping_time = now; | ||||
| 	c->last_ping_time = time(NULL); | ||||
| 
 | ||||
| 	ifdebug(CONNECTIONS) logger(LOG_NOTICE, _("Connection from %s"), c->hostname); | ||||
| 
 | ||||
|  |  | |||
|  | @ -211,7 +211,7 @@ bool seen_request(char *request) | |||
| 	} else { | ||||
| 		new = xmalloc(sizeof(*new)); | ||||
| 		new->request = xstrdup(request); | ||||
| 		new->firstseen = now; | ||||
| 		new->firstseen = time(NULL); | ||||
| 		avl_insert(past_request_tree, new); | ||||
| 		event_add(&past_request_event, &(struct timeval){10, 0}); | ||||
| 		return false; | ||||
|  | @ -223,6 +223,7 @@ void age_past_requests(int fd, short events, void *data) | |||
| 	avl_node_t *node, *next; | ||||
| 	past_request_t *p; | ||||
| 	int left = 0, deleted = 0; | ||||
| 	time_t now = time(NULL); | ||||
| 
 | ||||
| 	cp(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -116,7 +116,7 @@ bool send_ping(connection_t *c) | |||
| 	cp(); | ||||
| 
 | ||||
| 	c->status.pinged = true; | ||||
| 	c->last_ping_time = now; | ||||
| 	c->last_ping_time = time(NULL); | ||||
| 
 | ||||
| 	return send_request(c, "%d", PING); | ||||
| } | ||||
|  |  | |||
							
								
								
									
										10
									
								
								src/route.c
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								src/route.c
									
										
									
									
									
								
							|  | @ -77,6 +77,7 @@ static uint16_t inet_checksum(void *data, int len, uint16_t prevsum) | |||
| static bool ratelimit(int frequency) { | ||||
| 	static time_t lasttime = 0; | ||||
| 	static int count = 0; | ||||
| 	time_t now = time(NULL); | ||||
| 	 | ||||
| 	if(lasttime == now) { | ||||
| 		if(++count > frequency) | ||||
|  | @ -103,6 +104,7 @@ static void age_subnets(int fd, short events, void *data) | |||
| 	connection_t *c; | ||||
| 	avl_node_t *node, *next, *node2; | ||||
| 	bool left = false; | ||||
| 	time_t now = time(NULL); | ||||
| 
 | ||||
| 	cp(); | ||||
| 
 | ||||
|  | @ -152,7 +154,7 @@ static void learn_mac(mac_t *address) | |||
| 
 | ||||
| 		subnet = new_subnet(); | ||||
| 		subnet->type = SUBNET_MAC; | ||||
| 		subnet->expires = now + macexpire; | ||||
| 		subnet->expires = time(NULL) + macexpire; | ||||
| 		subnet->net.mac.address = *address; | ||||
| 		subnet_add(myself, subnet); | ||||
| 
 | ||||
|  | @ -167,10 +169,10 @@ static void learn_mac(mac_t *address) | |||
| 		if(!timeout_initialized(&age_subnets_event)) | ||||
| 			timeout_set(&age_subnets_event, age_subnets, NULL); | ||||
| 		event_add(&age_subnets_event, &(struct timeval){10, 0}); | ||||
| 	} | ||||
| 
 | ||||
| 	} else { | ||||
| 		if(subnet->expires) | ||||
| 		subnet->expires = now + macexpire; | ||||
| 			subnet->expires = time(NULL) + macexpire; | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void route_mac(node_t *source, vpn_packet_t *packet) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue