projects
/
tinc
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Document how invitation files work.
[tinc]
/
src
/
sptps_speed.c
diff --git
a/src/sptps_speed.c
b/src/sptps_speed.c
index
ab41e8d
..
bde3d69
100644
(file)
--- a/
src/sptps_speed.c
+++ b/
src/sptps_speed.c
@@
-33,6
+33,7
@@
bool send_request(void *c, const char *msg, ...) { return false; }
struct list_t *connection_list = NULL;
bool send_meta(void *c, const char *msg , int len) { return false; }
char *logfilename = NULL;
struct list_t *connection_list = NULL;
bool send_meta(void *c, const char *msg , int len) { return false; }
char *logfilename = NULL;
+bool do_detach = false;
struct timeval now;
static bool send_data(void *handle, uint8_t type, const void *data, size_t len) {
struct timeval now;
static bool send_data(void *handle, uint8_t type, const void *data, size_t len) {
@@
-46,11
+47,16
@@
static bool receive_record(void *handle, uint8_t type, const void *data, uint16_
}
static void receive_data(sptps_t *sptps) {
}
static void receive_data(sptps_t *sptps) {
- char buf[4096];
+ char buf[4096]
, *bufp = buf
;
int fd = *(int *)sptps->handle;
size_t len = recv(fd, buf, sizeof buf, 0);
int fd = *(int *)sptps->handle;
size_t len = recv(fd, buf, sizeof buf, 0);
- if(!sptps_receive_data(sptps, buf, len))
- abort();
+ while(len) {
+ size_t done = sptps_receive_data(sptps, bufp, len);
+ if(!done)
+ abort();
+ bufp += done;
+ len -= done;
+ }
}
struct timespec start;
}
struct timespec start;
@@
-101,19
+107,26
@@
int main(int argc, char *argv[]) {
fprintf(stderr, "Ed25519 sign for %lg seconds: ", duration);
for(clock_start(); clock_countto(duration);)
fprintf(stderr, "Ed25519 sign for %lg seconds: ", duration);
for(clock_start(); clock_countto(duration);)
- ecdsa_sign(key1, buf1, 256, buf2);
- fprintf(stderr, "%22.2lf op/s\n", rate);
+ if(!ecdsa_sign(key1, buf1, 256, buf2))
+ return 1;
+ fprintf(stderr, "%20.2lf op/s\n", rate);
fprintf(stderr, "Ed25519 verify for %lg seconds: ", duration);
for(clock_start(); clock_countto(duration);)
fprintf(stderr, "Ed25519 verify for %lg seconds: ", duration);
for(clock_start(); clock_countto(duration);)
- ecdsa_verify(key1, buf1, 256, buf2);
- fprintf(stderr, "%20.2lf op/s\n", rate);
+ if(!ecdsa_verify(key1, buf1, 256, buf2)) {
+ fprintf(stderr, "Signature verification failed\n");
+ return 1;
+ }
+ fprintf(stderr, "%18.2lf op/s\n", rate);
ecdh1 = ecdh_generate_public(buf1);
fprintf(stderr, "ECDH for %lg seconds: ", duration);
for(clock_start(); clock_countto(duration);) {
ecdh2 = ecdh_generate_public(buf2);
ecdh1 = ecdh_generate_public(buf1);
fprintf(stderr, "ECDH for %lg seconds: ", duration);
for(clock_start(); clock_countto(duration);) {
ecdh2 = ecdh_generate_public(buf2);
- ecdh_compute_shared(ecdh2, buf1, buf3);
+ if(!ecdh2)
+ return 1;
+ if(!ecdh_compute_shared(ecdh2, buf1, buf3))
+ return 1;
}
fprintf(stderr, "%28.2lf op/s\n", rate);
ecdh_free(ecdh1);
}
fprintf(stderr, "%28.2lf op/s\n", rate);
ecdh_free(ecdh1);