5 #include "../include/asoundlib.h"
9 static void usage(void)
11 fprintf(stderr, "Usage: midiloop [options]\n");
12 fprintf(stderr, " options:\n");
13 fprintf(stderr, " -v: verbose mode\n");
14 fprintf(stderr, " -i <rawmidi device> : test input device\n");
15 fprintf(stderr, " -o <rawmidi device> : test output device\n");
20 void sighandler(int dummy ATTRIBUTE_UNUSED)
25 long long timediff(struct timeval t1, struct timeval t2)
29 t1.tv_sec -= t2.tv_sec;
30 l = (signed long) t1.tv_usec - (signed long) t2.tv_usec;
36 return ((long long)t1.tv_sec * (long long)1000000) + (long long)l;
39 int writepattern(snd_rawmidi_t *handle_out, unsigned char *obuf)
44 for (i = 0; i < 15; i++) {
45 obuf[patsize++] = 0x90 + i;
46 obuf[patsize++] = 0x40;
47 obuf[patsize++] = 0x3f;
48 obuf[patsize++] = 0xb0 + i;
49 obuf[patsize++] = 0x2e;
50 obuf[patsize++] = 0x7a;
51 obuf[patsize++] = 0x80 + i;
52 obuf[patsize++] = 0x23;
53 obuf[patsize++] = 0x24;
54 obuf[patsize++] = 0xf0;
56 obuf[patsize++] = 0xf7;
58 i = snd_rawmidi_write(handle_out, obuf, patsize);
60 printf("Written only %i bytes from %i bytes\n", i, patsize);
66 int main(int argc, char** argv)
68 int i, j, k, opos, ipos, patsize;
71 snd_rawmidi_t *handle_in = NULL, *handle_out = NULL;
72 unsigned char ibuf[512], obuf[512];
73 char *iname = "hw:0,0", *oname = "hw:0,0";
74 struct timeval start, end;
76 snd_rawmidi_status_t *istat, *ostat;
78 for (i = 1 ; i<argc ; i++) {
79 if (argv[i][0]=='-') {
80 if (!strcmp(argv[i], "--help")) {
109 fprintf(stderr, "Using: \n");
110 fprintf(stderr, " Input: %s Output: %s\n", iname, oname);
113 err = snd_rawmidi_open(&handle_in, NULL, iname, SND_RAWMIDI_NONBLOCK);
115 fprintf(stderr,"snd_rawmidi_open %s failed: %d\n",iname,err);
119 err = snd_rawmidi_open(NULL, &handle_out, oname, 0);
121 fprintf(stderr,"snd_rawmidi_open %s failed: %d\n",oname,err);
125 signal(SIGINT, sighandler);
127 i = snd_rawmidi_read(handle_in, ibuf, sizeof(ibuf));
129 printf("Read ahead: %i\n", i);
130 for (j = 0; j < i; j++)
131 printf("%02x:", ibuf[j]);
136 snd_rawmidi_nonblock(handle_in, 0);
138 patsize = writepattern(handle_out, obuf);
139 gettimeofday(&start, NULL);
140 patsize = writepattern(handle_out, obuf);
142 k = ipos = opos = err = 0;
144 i = snd_rawmidi_read(handle_in, ibuf, sizeof(ibuf));
145 for (j = 0; j < i; j++, ipos++)
146 if (obuf[k] != ibuf[j]) {
147 printf("ipos = %i, i[0x%x] != o[0x%x]\n", ipos, ibuf[j], obuf[k]);
151 printf("match success: ipos = %i, opos = %i [%i:0x%x]\n", ipos, opos, k, obuf[k]);
154 patsize = writepattern(handle_out, obuf);
160 gettimeofday(&end, NULL);
164 snd_rawmidi_status_alloca(&istat);
165 snd_rawmidi_status_alloca(&ostat);
166 err = snd_rawmidi_status(handle_in, istat);
168 fprintf(stderr, "input stream status error: %d\n", err);
169 err = snd_rawmidi_status(handle_out, ostat);
171 fprintf(stderr, "output stream status error: %d\n", err);
172 printf("input.status.avail = %zi\n", snd_rawmidi_status_get_avail(istat));
173 printf("input.status.xruns = %zi\n", snd_rawmidi_status_get_xruns(istat));
174 printf("output.status.avail = %zi\n", snd_rawmidi_status_get_avail(ostat));
175 printf("output.status.xruns = %zi\n", snd_rawmidi_status_get_xruns(ostat));
177 diff = timediff(end, start);
178 printf("Time diff: %Liusec (%Li bytes/sec)\n", diff, ((long long)opos * 1000000) / diff);
181 fprintf(stderr,"Closing\n");
184 snd_rawmidi_drain(handle_in);
185 snd_rawmidi_close(handle_in);
186 snd_rawmidi_drain(handle_out);
187 snd_rawmidi_close(handle_out);