long outpktno;
long dropfrom;
long dropto;
+double reorder;
+long reorder_dist = 10;
double dropin;
double dropout;
long total_out;
long total_in;
+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) {
ssize_t do_send(struct utcp *utcp, const void *data, size_t len) {
int s = *(int *)utcp->priv;
outpktno++;
- if(outpktno < dropto && outpktno >= dropfrom && drand48() < dropout)
- return len;
+ if(outpktno >= dropfrom && outpktno < dropto) {
+ if(drand48() < dropout) {
+ debug("Dropped outgoing packet\n");
+ return len;
+ }
+ if(!reorder_data && drand48() < reorder) {
+ reorder_data = malloc(len);
+ if(!reorder_data) {
+ debug("Out of memory\n");
+ return len;
+ }
+ reorder_len = len;
+ memcpy(reorder_data, data, len);
+ reorder_countdown = 1 + drand48() * reorder_dist;
+ return len;
+ }
+ }
+
+ if(reorder_data) {
+ if(--reorder_countdown < 0) {
+ total_out += reorder_len;
+ send(s, reorder_data, reorder_len, MSG_DONTWAIT);
+ free(reorder_data);
+ reorder_data = NULL;
+ }
+ }
total_out += len;
ssize_t result = send(s, data, len, MSG_DONTWAIT);
bool server = argc == 2;
bool connected = false;
- dropin = atof(getenv("DROPIN") ?: "0");
- dropout = atof(getenv("DROPOUT") ?: "0");
- dropfrom = atoi(getenv("DROPFROM") ?: "0");
- dropto = atoi(getenv("DROPTO") ?: "0");
+ if(getenv("DROPIN")) dropin = atof(getenv("DROPIN"));
+ if(getenv("DROPOUT")) dropout = atof(getenv("DROPOUT"));
+ if(getenv("DROPFROM")) dropfrom = atoi(getenv("DROPFROM"));
+ 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(dropto < dropfrom)
+ dropto = 1 << 30;
struct addrinfo *ai;
struct addrinfo hint = {
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");
}
}
utcp_close(c);
utcp_exit(u);
+ free(reorder_data);
debug("Total bytes in: %ld, out: %ld\n", total_in, total_out);