double dropout;
long total_out;
long total_in;
+FILE *reference;
char *reorder_data;
size_t reorder_len;
}
return -1;
}
+ if(reference) {
+ char buf[len];
+ if(fread(buf, len, 1, reference) != 1) {
+ debug("Error reading reference\n");
+ abort();
+ }
+ if(memcmp(buf, data, len)) {
+ debug("Received data differs from reference\n");
+ abort();
+ }
+ }
return write(1, data, len);
}
bool server = argc == 2;
bool connected = false;
+ uint32_t flags = UTCP_TCP;
+ size_t read_size = 102400;
if(getenv("DROPIN")) dropin = atof(getenv("DROPIN"));
if(getenv("DROPOUT")) dropout = atof(getenv("DROPOUT"));
if(getenv("DROPTO")) dropto = atoi(getenv("DROPTO"));
if(getenv("REORDER")) reorder = atof(getenv("REORDER"));
if(getenv("REORDER_DIST")) reorder_dist = atoi(getenv("REORDER_DIST"));
+ if(getenv("FLAGS")) flags = atoi(getenv("FLAGS"));
+ if(getenv("READ_SIZE")) read_size = atoi(getenv("READ_SIZE"));
+
+ char *reference_filename = getenv("REFERENCE");
+ if(reference_filename)
+ reference = fopen(reference_filename, "r");
if(dropto < dropfrom)
dropto = 1 << 30;
utcp_set_user_timeout(u, 10);
if(!server)
- c = utcp_connect(u, 1, do_recv, NULL);
+ c = utcp_connect_ex(u, 1, do_recv, NULL, flags);
struct pollfd fds[2] = {
{.fd = 0, .events = POLLIN | POLLERR | POLLHUP},
size_t max = c ? utcp_get_sndbuf_free(c) : 0;
if(max > sizeof buf)
max = sizeof buf;
+ if(max > read_size)
+ max = read_size;
int timeout_ms = timeout.tv_sec * 1000 + timeout.tv_usec / 1000 + 1;