File: bulk_app.c

package info (click to toggle)
rtlinux 3.1pre3-2
  • links: PTS
  • area: non-free
  • in suites: sarge, woody
  • size: 4,892 kB
  • ctags: 4,228
  • sloc: ansic: 26,204; sh: 2,069; makefile: 1,414; perl: 855; tcl: 489; asm: 380; cpp: 42
file content (67 lines) | stat: -rw-r--r-- 1,366 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
#include <stdio.h>
#include <errno.h>
#include <sys/time.h>
#include <sys/types.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/ioctl.h>
#include <rtl_fifo.h>
#include <rtl_time.h>
#include "bulk.h"


struct timeval t,t2;
int buf[BUF_SIZE];
int main()
{
	int fdr;
	int fdw;
	int n,i;
	unsigned long long  us =0,mbps;
	
	if ((fdr = open("/dev/rtf1", O_RDONLY)) < 0) {
		fprintf(stderr, "Error opening /dev/rtf1\n");
		exit(1);
	}
	if ((fdw = open("/dev/rtf2", O_WRONLY)) < 0) {
		fprintf(stderr, "Error opening /dev/rtf2\n");
		exit(1);
	}

	gettimeofday(&t,0);
	for (i = 0; i < COUNT* (BUF_SIZE* sizeof(int)); i+=n) {
	    n = read(fdr, buf, sizeof(buf));
	    if(n <0){
		    printf("Error in reading %d\n",n);
		    break;
	    }
	}
	gettimeofday(&t2,0);
	us = ((t2.tv_sec - t.tv_sec)*1000000) + t2.tv_usec;
	us -= t.tv_usec;
	mbps = i/us;
        printf("Read %d bytes in %Ld microseconds = %Ld Mb/second \n",i,us,mbps);
	fflush(stdout);


	gettimeofday(&t,0);
	for (i = 0; i < COUNT* (BUF_SIZE* sizeof(int)); i+=n) {
	    n = write(fdw, buf, sizeof(buf));
	    if(n <0){
		    printf("Error in writing %d\n",n);
		    break;
	    }
	}
	gettimeofday(&t2,0);
	us = (t2.tv_sec*1000000) + t2.tv_usec;
	us -= ((t.tv_sec*1000000) + t.tv_usec);
	mbps = i/us;
        printf("Wrote %d bytes in %Ld microseconds = %Ld Mb/second \n",i,us,mbps);


	return 0;

}