Small performance increases.

This commit is contained in:
irungentoo 2014-01-17 15:46:09 -05:00
parent 608330efef
commit d11cf9c5a8
4 changed files with 33 additions and 8 deletions

View File

@ -28,7 +28,11 @@
#endif #endif
#include "DHT.h" #include "DHT.h"
#ifdef ENABLE_ASSOC_DHT
#include "assoc.h" #include "assoc.h"
#endif
#include "ping.h" #include "ping.h"
#include "network.h" #include "network.h"
@ -304,7 +308,7 @@ static void get_close_nodes_inner(DHT *dht, uint8_t *client_id, Node_format *nod
if (LAN_ip(ipptp->ip_port.ip) == 0 && !is_LAN) if (LAN_ip(ipptp->ip_port.ip) == 0 && !is_LAN)
continue; continue;
if (want_good && hardening_correct(&ipptp->hardening) != HARDENING_ALL_OK && !id_equal(client_id, client->client_id)) if (LAN_ip(ipptp->ip_port.ip) != 0 && want_good && hardening_correct(&ipptp->hardening) != HARDENING_ALL_OK && !id_equal(client_id, client->client_id))
continue; continue;
if (num_nodes < MAX_SENT_NODES) { if (num_nodes < MAX_SENT_NODES) {
@ -366,9 +370,13 @@ static int get_somewhat_close_nodes(DHT *dht, uint8_t *client_id, Node_format *n
int get_close_nodes(DHT *dht, uint8_t *client_id, Node_format *nodes_list, sa_family_t sa_family, uint8_t is_LAN, int get_close_nodes(DHT *dht, uint8_t *client_id, Node_format *nodes_list, sa_family_t sa_family, uint8_t is_LAN,
uint8_t want_good) uint8_t want_good)
{ {
#ifdef ENABLE_ASSOC_DHT
if (!dht->assoc) if (!dht->assoc)
#endif
return get_somewhat_close_nodes(dht, client_id, nodes_list, sa_family, is_LAN, want_good); return get_somewhat_close_nodes(dht, client_id, nodes_list, sa_family, is_LAN, want_good);
#ifdef ENABLE_ASSOC_DHT
Client_data *result[MAX_SENT_NODES]; Client_data *result[MAX_SENT_NODES];
Assoc_close_entries request; Assoc_close_entries request;
@ -420,6 +428,7 @@ int get_close_nodes(DHT *dht, uint8_t *client_id, Node_format *nodes_list, sa_fa
} }
return num_returned; return num_returned;
#endif
} }
/* Replace first bad (or empty) node with this one. /* Replace first bad (or empty) node with this one.
@ -566,7 +575,7 @@ static int replace_good( Client_data *list,
if ((ip_port.ip.family != AF_INET) && (ip_port.ip.family != AF_INET6)) if ((ip_port.ip.family != AF_INET) && (ip_port.ip.family != AF_INET6))
return 1; return 1;
sort_list(list, length, comp_client_id); //sort_list(list, length, comp_client_id);
int8_t replace = -1; int8_t replace = -1;
@ -669,6 +678,8 @@ int addto_lists(DHT *dht, IP_Port ip_port, uint8_t *client_id)
used++; used++;
} }
#ifdef ENABLE_ASSOC_DHT
if (dht->assoc) { if (dht->assoc) {
IPPTs ippts; IPPTs ippts;
@ -678,6 +689,7 @@ int addto_lists(DHT *dht, IP_Port ip_port, uint8_t *client_id)
Assoc_add_entry(dht->assoc, client_id, &ippts, NULL, used ? 1 : 0); Assoc_add_entry(dht->assoc, client_id, &ippts, NULL, used ? 1 : 0);
} }
#endif
return used; return used;
} }
@ -734,6 +746,7 @@ static int returnedip_ports(DHT *dht, IP_Port ip_port, uint8_t *client_id, uint8
} }
end: end:
#ifdef ENABLE_ASSOC_DHT
if (dht->assoc) { if (dht->assoc) {
IPPTs ippts; IPPTs ippts;
@ -744,6 +757,7 @@ end:
Assoc_add_entry(dht->assoc, client_id, &ippts, NULL, used ? 1 : 0); Assoc_add_entry(dht->assoc, client_id, &ippts, NULL, used ? 1 : 0);
} }
#endif
return 0; return 0;
} }
@ -1177,6 +1191,7 @@ int DHT_addfriend(DHT *dht, uint8_t *client_id)
dht->friends_list[dht->num_friends].nat.NATping_id = random_64b(); dht->friends_list[dht->num_friends].nat.NATping_id = random_64b();
++dht->num_friends; ++dht->num_friends;
#ifdef ENABLE_ASSOC_DHT
if (dht->assoc) { if (dht->assoc) {
/* get up to MAX_FRIEND_CLIENTS connectable nodes */ /* get up to MAX_FRIEND_CLIENTS connectable nodes */
@ -1206,6 +1221,7 @@ int DHT_addfriend(DHT *dht, uint8_t *client_id)
} }
} }
#endif
/*TODO: make this better?*/ /*TODO: make this better?*/
get_bunchnodes(dht, dht->close_clientlist, LCLIENT_LIST, MAX_FRIEND_CLIENTS, client_id); get_bunchnodes(dht, dht->close_clientlist, LCLIENT_LIST, MAX_FRIEND_CLIENTS, client_id);
@ -1374,14 +1390,15 @@ void DHT_getnodes(DHT *dht, IP_Port *from_ipp, uint8_t *from_id, uint8_t *which_
void DHT_bootstrap(DHT *dht, IP_Port ip_port, uint8_t *public_key) void DHT_bootstrap(DHT *dht, IP_Port ip_port, uint8_t *public_key)
{ {
/* /*#ifdef ENABLE_ASSOC_DHT
if (dht->assoc) { if (dht->assoc) {
IPPTs ippts; IPPTs ippts;
ippts.ip_port = ip_port; ippts.ip_port = ip_port;
ippts.timestamp = 0; ippts.timestamp = 0;
Assoc_add_entry(dht->assoc, public_key, &ippts, NULL, 0); Assoc_add_entry(dht->assoc, public_key, &ippts, NULL, 0);
}*/ }
#endif*/
getnodes(dht, ip_port, public_key, dht->self_public_key, NULL); getnodes(dht, ip_port, public_key, dht->self_public_key, NULL);
} }
@ -2221,8 +2238,9 @@ DHT *new_DHT(Net_Crypto *c)
new_symmetric_key(dht->secret_symmetric_key); new_symmetric_key(dht->secret_symmetric_key);
crypto_box_keypair(dht->self_public_key, dht->self_secret_key); crypto_box_keypair(dht->self_public_key, dht->self_secret_key);
#ifdef ENABLE_ASSOC_DHT
dht->assoc = new_Assoc_default(dht->self_public_key); dht->assoc = new_Assoc_default(dht->self_public_key);
#endif
return dht; return dht;
} }
@ -2239,15 +2257,19 @@ void do_DHT(DHT *dht)
do_NAT(dht); do_NAT(dht);
do_toping(dht->ping); do_toping(dht->ping);
do_hardening(dht); do_hardening(dht);
#ifdef ENABLE_ASSOC_DHT
if (dht->assoc) if (dht->assoc)
do_Assoc(dht->assoc, dht); do_Assoc(dht->assoc, dht);
#endif
dht->last_run = unix_time(); dht->last_run = unix_time();
} }
void kill_DHT(DHT *dht) void kill_DHT(DHT *dht)
{ {
#ifdef ENABLE_ASSOC_DHT
kill_Assoc(dht->assoc); kill_Assoc(dht->assoc);
#endif
kill_ping(dht->ping); kill_ping(dht->ping);
free(dht->friends_list); free(dht->friends_list);
free(dht); free(dht);

View File

@ -154,9 +154,9 @@ typedef struct {
uint16_t num_friends; uint16_t num_friends;
struct PING *ping; struct PING *ping;
#ifdef ENABLE_ASSOC_DHT
struct Assoc *assoc; struct Assoc *assoc;
#endif
uint64_t last_run; uint64_t last_run;
} DHT; } DHT;
/*----------------------------------------------------------------------------------*/ /*----------------------------------------------------------------------------------*/

View File

@ -2214,9 +2214,12 @@ static int messenger_load_state_callback(void *outer, uint8_t *data, uint32_t le
if (length == crypto_box_PUBLICKEYBYTES + crypto_box_SECRETKEYBYTES + sizeof(uint32_t)) { if (length == crypto_box_PUBLICKEYBYTES + crypto_box_SECRETKEYBYTES + sizeof(uint32_t)) {
set_nospam(&(m->fr), *(uint32_t *)data); set_nospam(&(m->fr), *(uint32_t *)data);
load_keys(m->net_crypto, &data[sizeof(uint32_t)]); load_keys(m->net_crypto, &data[sizeof(uint32_t)]);
#ifdef ENABLE_ASSOC_DHT
if (m->dht->assoc) if (m->dht->assoc)
Assoc_self_client_id_changed(m->dht->assoc, m->net_crypto->self_public_key); Assoc_self_client_id_changed(m->dht->assoc, m->net_crypto->self_public_key);
#endif
} else } else
return -1; /* critical */ return -1; /* critical */

View File

@ -635,7 +635,7 @@ static void do_friend(Onion_Client *onion_c, uint16_t friendnum)
/* send packets to friend telling them our fake DHT id. */ /* send packets to friend telling them our fake DHT id. */
if (is_timeout(onion_c->friends_list[friendnum].last_fakeid_sent, ONION_FAKEID_INTERVAL)) if (is_timeout(onion_c->friends_list[friendnum].last_fakeid_sent, ONION_FAKEID_INTERVAL))
if (send_fakeid_announce(onion_c, friendnum) > 3) if (send_fakeid_announce(onion_c, friendnum) > 1)
onion_c->friends_list[friendnum].last_fakeid_sent = unix_time(); onion_c->friends_list[friendnum].last_fakeid_sent = unix_time();
} }
/* Function to call when onion data packet with contents beginning with byte is received. */ /* Function to call when onion data packet with contents beginning with byte is received. */