mirror of
https://github.com/irungentoo/toxcore.git
synced 2024-03-22 13:30:51 +08:00
Small performance increases.
This commit is contained in:
parent
608330efef
commit
d11cf9c5a8
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
/*----------------------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------------------*/
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
||||||
|
|
|
@ -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. */
|
||||||
|
|
Loading…
Reference in New Issue
Block a user