/*
 * Copyright (c) 1996, 1997, 1998 The University of Utah and
 * the Computer Systems Laboratory at the University of Utah (CSL).
 *
 * This file is part of Flick, the Flexible IDL Compiler Kit.
 *
 * Flick is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Flick is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Flick; see the file COPYING.  If not, write to
 * the Free Software Foundation, 59 Temple Place #330, Boston, MA 02111, USA.
 */

#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include "ttcp-client.h"
#include <sys/time.h>

/* Function to print statistics */
void print_stats(int size, struct timeval starttime, struct timeval endtime, int samples)
{
        double msecs = (1000.0 * (endtime.tv_sec - starttime.tv_sec)) +
                ( (endtime.tv_usec - starttime.tv_usec) / 1000.0);
	printf("%d\t%3.2f\t%3.2f\n", size,
	       (double)(size * samples) * 8.0 / (1048576.0 * msecs / 1000.0),
	       (double)(size * samples) / (1048576.0 * msecs / 1000.0));
}

void handle_exception(CORBA_Environment *ev);

int main(int argc, char **argv)
{
	CORBA_ORB orb = 0;
	CORBA_Environment ev;
	CORBA_Object obj;
	
	int qty = 65536, i, j;
        structBuffer sbuf;
        intBuffer ibuf;	
	
	obj = CORBA_ORB_string_to_object(orb, argv[1], &ev);
	if (ev._major != CORBA_NO_EXCEPTION) {
		printf("Problem in string to object conversion...\n");
		exit(1);
	}
	printf("Structures\nData\tMbps\tMBps\n");
        for (i = 32; i <= 512; i+= 32 ) {
                struct timeval starttime, endtime;
                sbuf._length = i;
		sbuf._buffer = (b *)flick_trapeze_client_array__alloc();
		if (!sbuf._buffer) {
			printf("Error allocating s-buffer.\n");
			exit(1);
		}		
		
		ttcp_structtest(obj, &sbuf, &ev);
		qty = 0x400000 / (i * sizeof(b));
		if (qty > 1024)
			qty = 1024;
		gettimeofday(&starttime, NULL);
                for (j = 0; j < qty; j++) {
                        ttcp_structtest(obj, &sbuf, &ev);
			if (ev._major != CORBA_NO_EXCEPTION)
				handle_exception(&ev);
		}
		

                gettimeofday(&endtime, NULL);
                print_stats(i*16, starttime, endtime, qty);
		flick_trapeze_client_array__free(sbuf._buffer);
                qty /= 3;
        }
	
        qty = 65536;
	printf("Integers\nData\tMbps\tMBps\n");
        for (i = 1024; i <= 2048; i += 64) {
                struct timeval starttime, endtime;
		
		ibuf._length = i;
		ibuf._buffer = (int *)flick_trapeze_client_array__alloc();
		if (!ibuf._buffer) {
			printf("Error allocating i-buffer.\n");
			exit(1);
		}		
		
		ttcp_inttest(obj, &ibuf, &ev);
		qty = 0x400000 / (i * sizeof(int));
		if (qty > 1024)
			qty = 1024;
		
                gettimeofday(&starttime, NULL);
                for (j = 0; j < qty; j++) {
                        ttcp_inttest(obj, &ibuf, &ev);
			if (ev._major != CORBA_NO_EXCEPTION)
				handle_exception(&ev);
		}
                gettimeofday(&endtime, NULL);
                print_stats(i * 4, starttime, endtime, qty);
		flick_trapeze_client_array__free(ibuf._buffer);
                qty /= 3;
        }
	return 0;
}

void handle_exception(CORBA_Environment *ev)
{
	switch (ev->_major) {
	case CORBA_NO_EXCEPTION:
		return; /* don't abort the program */
	case CORBA_SYSTEM_EXCEPTION:
		fprintf(stderr, "%s ERROR %d.%d\n",
			CORBA_exception_id(ev),
			((CORBA_UNKNOWN *)CORBA_exception_value(ev))->minor,
			((CORBA_UNKNOWN *)CORBA_exception_value(
				ev))->completed);		
		break;
	case CORBA_USER_EXCEPTION:
        	if (!strcmp(CORBA_exception_id(ev), ex_useless))
                        /* the 'useless' exception */
			fprintf(stderr, "Useless exception raised - %d\n",
				((useless *)
				 CORBA_exception_value(ev))->baloney);
		else
			fprintf(stderr, "Unknown user exception raised!");
		break;
	default:
		fprintf(stderr, "Unknown exception type\n");
	}
	
	CORBA_exception_free(ev);
	exit(1);
}

/* End of file. */



syntax highlighted by Code2HTML, v. 0.9.1