Fix receiving SPTPS data in sptps_speed and sptps_test.

The sptps_receive_data() was changed in commit d237efd to only process
one SPTPS record from a stream input. So now we have to put a loop
around it to ensure we process everything.
This commit is contained in:
Guus Sliepen 2015-06-07 23:14:48 +02:00 committed by thorkill
parent 479a10b484
commit 06a7c60db7
2 changed files with 21 additions and 5 deletions

View file

@ -47,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; int fd = *(int *)sptps->handle;
size_t len = recv(fd, buf, sizeof buf, 0); size_t len = recv(fd, buf, sizeof buf, 0);
if(!sptps_receive_data(sptps, buf, len)) while(len) {
abort(); size_t done = sptps_receive_data(sptps, bufp, len);
if(!done)
abort();
bufp += done;
len -= done;
}
} }
struct timespec start; struct timespec start;

View file

@ -357,8 +357,19 @@ int main(int argc, char *argv[]) {
fprintf(stderr, "Dropped.\n"); fprintf(stderr, "Dropped.\n");
continue; continue;
} }
if(!sptps_receive_data(&s, buf, len) && !datagram) char *bufp = buf;
return 1; while(len) {
size_t done = sptps_receive_data(&s, bufp, len);
if(!done) {
if(!datagram)
return 1;
} else {
break;
}
bufp += done;
len -= done;
}
} }
} }