1
1

corrected interval byte count mismatch, corrected out of order packet count

Этот коммит содержится в:
kaustubhprabhu 2009-07-13 21:50:08 +00:00
родитель fea54f51f7
Коммит 3023ce6ec5

Просмотреть файл

@ -323,16 +323,18 @@ int iperf_udp_recv(struct iperf_stream *sp)
{ {
message = udp->state; message = udp->state;
} }
if(message != STREAM_END && message != STREAM_BEGIN && (sp->stream_id == udp->stream_id)) if(message != STREAM_END && message != STREAM_BEGIN && (sp->stream_id == udp->stream_id))
{ {
sp->result->bytes_received+= result; sp->result->bytes_received+= result;
if(udp->packet_count == sp->packet_count + 1)
sp->packet_count++; sp->packet_count++;
//jitter measurement //jitter measurement
if(gettimeofday(&arrival_time, NULL) < 0) { if(gettimeofday(&arrival_time, NULL) < 0) {
perror("gettimeofday"); perror("gettimeofday");
} }
transit = timeval_diff(&udp->sent_time, &arrival_time); transit = timeval_diff(&udp->sent_time, &arrival_time);
d = transit - sp->prev_transit; d = transit - sp->prev_transit;
if(d < 0) if(d < 0)
@ -342,22 +344,22 @@ int iperf_udp_recv(struct iperf_stream *sp)
//OUT OF ORDER PACKETS //OUT OF ORDER PACKETS
if(udp->packet_count != sp->packet_count + 1) if(udp->packet_count != sp->packet_count)
{ {
if( udp->packet_count < sp->packet_count + 1) if( udp->packet_count < sp->packet_count + 1)
{ {
sp->outoforder_packets++; sp->outoforder_packets++;
//printf("OUT OF ORDER - incoming packet = %d and received packet = %d AND SP = %d\n", udp->packet_count, sp->packet_count, sp->socket); printf("OUT OF ORDER - incoming packet = %d and received packet = %d AND SP = %d\n", udp->packet_count, sp->packet_count, sp->socket);
} }
else else
sp->cnt_error += udp->packet_count - sp->packet_count; sp->cnt_error += udp->packet_count - sp->packet_count;
} }
// store the latest packet id // store the latest packet id
if(udp->packet_count > sp->packet_count) if(udp->packet_count > sp->packet_count)
sp->packet_count = udp->packet_count; sp->packet_count = udp->packet_count;
//printf("incoming packet = %d and received packet = %d AND SP = %d\n", udp->packet_count, sp->packet_count, sp->socket); //printf("incoming packet = %d and received packet = %d AND SP = %d\n", udp->packet_count, sp->packet_count, sp->socket);
} }
@ -496,7 +498,7 @@ int iperf_udp_send(struct iperf_stream *sp)
result = send(sp->socket, buf, size, 0); result = send(sp->socket, buf, size, 0);
if(sp->settings->state == STREAM_RUNNING) if(sp->settings->state == STREAM_RUNNING)
//printf("State = %d Outgoing packet = %d AND SP = %d\n",sp->settings->state, sp->packet_count, sp->socket); printf("State = %d Outgoing packet = %d AND SP = %d\n",sp->settings->state, sp->packet_count, sp->socket);
if(sp->settings->state == STREAM_RUNNING) if(sp->settings->state == STREAM_RUNNING)
sp->result->bytes_sent+= result; sp->result->bytes_sent+= result;
@ -659,8 +661,7 @@ void *iperf_stats_callback(struct iperf_test *test)
rp = sp->result; rp = sp->result;
if(!rp->interval_results) if(!rp->interval_results)
{ {
printf("1st time sp is %d \n", (int)sp);
if(test ->role == 'c') if(test ->role == 'c')
temp.bytes_transferred = rp->bytes_sent; temp.bytes_transferred = rp->bytes_sent;
else else
@ -676,8 +677,6 @@ void *iperf_stats_callback(struct iperf_test *test)
else else
{ {
printf("sp is %d \n", (int)sp);
ip = sp->result->interval_results; ip = sp->result->interval_results;
while(1) while(1)
{ {
@ -688,7 +687,7 @@ void *iperf_stats_callback(struct iperf_test *test)
break; break;
} }
if(test ->role == 'c') if(test ->role == 'c')
temp.bytes_transferred = rp->bytes_sent - cumulative_bytes; temp.bytes_transferred = rp->bytes_sent - cumulative_bytes;
else else
temp.bytes_transferred = rp->bytes_received - cumulative_bytes; temp.bytes_transferred = rp->bytes_received - cumulative_bytes;
@ -696,8 +695,7 @@ void *iperf_stats_callback(struct iperf_test *test)
gettimeofday(&temp.interval_time, NULL); gettimeofday(&temp.interval_time, NULL);
temp.interval_duration = timeval_diff(&sp->result->start_time, &temp.interval_time); temp.interval_duration = timeval_diff(&sp->result->start_time, &temp.interval_time);
gettimeofday( &sp->result->end_time, NULL); gettimeofday( &sp->result->end_time, NULL);
add_interval_list(rp, temp); add_interval_list(rp, temp);
} }
@ -737,7 +735,9 @@ char *iperf_reporter_callback(struct iperf_test *test)
if(test->default_settings->state == TEST_RUNNING) if(test->default_settings->state == TEST_RUNNING)
{ {
while(sp) while(sp)
{ {
ip = sp->result->interval_results;
while(ip->next!= NULL) while(ip->next!= NULL)
{ {
ip_prev = ip; ip_prev = ip;
@ -764,7 +764,7 @@ char *iperf_reporter_callback(struct iperf_test *test)
sprintf(message, report_bw_format, sp->socket, 0.0, ip->interval_duration, ubuf, nbuf); sprintf(message, report_bw_format, sp->socket, 0.0, ip->interval_duration, ubuf, nbuf);
} }
strcat(message_final, message); strcat(message_final, message);
sp = sp->next; sp = sp->next;
} }
unit_snprintf(ubuf, UNIT_LEN, (double) ( bytes), test->unit_format); unit_snprintf(ubuf, UNIT_LEN, (double) ( bytes), test->unit_format);
@ -846,11 +846,9 @@ char *iperf_reporter_callback(struct iperf_test *test)
{ {
sprintf(message, report_datagrams, sp->socket, sp->packet_count); sprintf(message, report_datagrams, sp->socket, sp->packet_count);
strcat(message_final, message); strcat(message_final, message);
} }
if ( sp->outoforder_packets > 0 )
if ( sp->cnt_error > 0 ) printf( report_sum_outoforder, start_time, end_time, sp->cnt_error);
printf( report_sum_outoforder, start_time, end_time, sp->cnt_error);
} }
} }
@ -872,7 +870,7 @@ char *iperf_reporter_callback(struct iperf_test *test)
} }
else else
{ {
sprintf(message, report_sum_bw_jitter_loss_format, start_time, end_time, ubuf, nbuf,sp->jitter, lost_packets, total_packets, (double)(100.0 * sp->cnt_error / sp->packet_count)); sprintf(message, report_sum_bw_jitter_loss_format, start_time, end_time, ubuf, nbuf,sp->jitter, lost_packets, total_packets, (double)(100.0 * lost_packets/total_packets));
strcat(message_final, message); strcat(message_final, message);
} }
@ -1036,7 +1034,7 @@ int iperf_udp_accept(struct iperf_test *test)
connect_msg(sp); connect_msg(sp);
printf("1st UDP data packet for socket %d has arrived \n", sp->socket); printf("1st UDP data packet for socket %d has arrived \n", sp->socket);
sp->stream_id = udp->stream_id; sp->stream_id = udp->stream_id;
sp->result->bytes_received+= sz; sp->result->bytes_received+= sz;
//OUT OF ORDER PACKETS //OUT OF ORDER PACKETS
@ -1051,7 +1049,8 @@ int iperf_udp_accept(struct iperf_test *test)
// store the latest packet id // store the latest packet id
if(udp->packet_count > sp->packet_count) if(udp->packet_count > sp->packet_count)
sp->packet_count = udp->packet_count; sp->packet_count = udp->packet_count;
printf("incoming packet = %d and received packet = %d AND SP = %d\n", udp->packet_count, sp->packet_count, sp->socket);
//printf("incoming packet = %d and received packet = %d AND SP = %d\n", udp->packet_count, sp->packet_count, sp->socket);
free(buf); free(buf);
return 0; return 0;