double dropout;
long total_out;
long total_in;
+FILE *reference;
char *reorder_data;
size_t reorder_len;
int reorder_countdown;
+#if UTCP_DEBUG
void debug(const char *format, ...) {
struct timeval now;
gettimeofday(&now, NULL);
vfprintf(stderr, format, ap);
va_end(ap);
}
+#else
+#define debug(...)
+#endif
ssize_t do_recv(struct utcp_connection *c, const void *data, size_t len) {
if(!data || !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);
}
int s = *(int *)utcp->priv;
outpktno++;
if(outpktno >= dropfrom && outpktno < dropto) {
- if(drand48() < dropout)
+ if(drand48() < dropout) {
+ debug("Dropped outgoing packet\n");
return len;
+ }
if(!reorder_data && drand48() < reorder) {
reorder_data = malloc(len);
if(!reorder_data) {
if(getenv("REORDER")) reorder = atof(getenv("REORDER"));
if(getenv("REORDER_DIST")) reorder_dist = atoi(getenv("REORDER_DIST"));
+ char *reference_filename = getenv("REFERENCE");
+ if(reference_filename)
+ reference = fopen(reference_filename, "r");
+
if(dropto < dropfrom)
dropto = 1 << 30;
inpktno++;
if(inpktno >= dropto || inpktno < dropfrom || drand48() >= dropin) {
total_in += len;
- utcp_recv(u, buf, len);
+ if(utcp_recv(u, buf, len) == -1)
+ debug("Error receiving UTCP packet: %s\n", strerror(errno));
+ } else {
+ debug("Dropped incoming packet\n");
}
}