Merge pull request #1 from ork/master
[evhz] / evhz.c
1 #include <string.h>
2 #include <stdio.h>
3 #include <linux/input.h>
4 #include <fcntl.h>
5 #include <signal.h>
6 #include <getopt.h>
7 #include <unistd.h>
8
9 #define EVENTS 50
10 #define HZ_LIST 64
11
12 typedef struct event_s {
13 int fd;
14 int hz[HZ_LIST];
15 int count;
16 int avghz;
17 double prvtime;
18 char name[128];
19 } event_t;
20
21 int quit = 0;
22
23 void sigint() {
24 quit = 1;
25 }
26
27 int main(int argc, char *argv[]) {
28 int optch;
29 int i;
30 event_t events[EVENTS];
31 int verbose = 0;
32
33 while((optch = getopt(argc, argv, "hv")) != -1) {
34 switch(optch) {
35 case('h'):
36 printf("Usage: %s [-v|-h]\n", argv[0]);
37 return 0;
38 break;
39 case('v'):
40 verbose = 1;
41 break;
42 }
43 }
44
45 if(geteuid() != 0) {
46 printf("%s must be used as superuser\n", argv[0]);
47 return 1;
48 }
49
50 signal(SIGINT, sigint);
51
52 printf("Press CTRL-C to exit.\n\n");
53
54 memset(events, 0, sizeof(events));
55
56 // List input devices
57 for(i = 0; i < EVENTS; i++) {
58 char device[18];
59
60 sprintf(device, "/dev/input/event%i", i);
61 events[i].fd = open(device, O_RDONLY);
62
63 if(events[i].fd != -1) {
64 ioctl(events[i].fd, EVIOCGNAME(sizeof(events[i].name)), events[i].name);
65 if(verbose) printf("event%i: %s\n", i, events[i].name);
66 }
67 }
68
69 while(!quit) {
70 fd_set set;
71
72 FD_ZERO(&set);
73
74 for(i = 0; i < EVENTS; i++) {
75 if(events[i].fd != -1) {
76 FD_SET(events[i].fd, &set);
77 }
78 }
79
80 if(select(FD_SETSIZE, &set, NULL, NULL, NULL) > 0) {
81 int bytes;
82 struct input_event event;
83
84 for(i = 0; i < EVENTS; i++) {
85 if(events[i].fd == -1 || !FD_ISSET(events[i].fd, &set)) {
86 continue;
87 }
88
89 bytes = read(events[i].fd, &event, sizeof(event));
90
91 if(bytes != sizeof(event)) {
92 continue;
93 }
94
95 if(event.type == EV_REL) {
96 double time;
97 int hz;
98
99 time = event.time.tv_sec * 1000 + event.time.tv_usec / 1000;
100 hz = 1000 / (time - events[i].prvtime);
101
102 if(hz > 0) {
103 int j;
104
105 events[i].count++;
106 events[i].hz[events[i].count & (HZ_LIST - 1)] = hz;
107
108 events[i].avghz = 0;
109
110 for(j = 0; j < HZ_LIST; j++) {
111 events[i].avghz += events[i].hz[j];
112 }
113
114 events[i].avghz /= (events[i].count > HZ_LIST) ? HZ_LIST : events[i].count;
115
116 if(verbose) printf("%s: Latest % 5iHz, Average % 5iHz\n", events[i].name, hz, events[i].avghz);
117 }
118
119 events[i].prvtime = time;
120 }
121 }
122 }
123 }
124
125 for(i = 0; i < EVENTS; i++) {
126 if(events[i].fd != -1) {
127 if (events[i].avghz != 0) {
128 printf("\nAverage for %s: % 5iHz\n", events[i].name, events[i].avghz);
129 }
130 close(events[i].fd);
131 }
132 }
133
134 return 0;
135 }