test-midi.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. *
  4. * BlueZ - Bluetooth protocol stack for Linux
  5. *
  6. * Copyright (C) 2015,2016 Felipe F. Tonello <eu@felipetonello.com>
  7. * Copyright (C) 2016 ROLI Ltd.
  8. *
  9. */
  10. #ifdef HAVE_CONFIG_H
  11. #include <config.h>
  12. #endif
  13. #include <glib.h>
  14. #define NUM_WRITE_TESTS 100
  15. #include "src/shared/tester.h"
  16. #include "profiles/midi/libmidi.h"
  17. struct ble_midi_packet {
  18. const uint8_t *data;
  19. size_t size;
  20. };
  21. #define BLE_MIDI_PACKET_INIT(_packet) \
  22. { \
  23. .data = (_packet), \
  24. .size = sizeof(_packet), \
  25. }
  26. struct midi_read_test {
  27. const struct ble_midi_packet *ble_packet;
  28. size_t ble_packet_size;
  29. const snd_seq_event_t *event;
  30. size_t event_size;
  31. };
  32. #define BLE_READ_TEST_INIT(_ble_packet, _event) \
  33. { \
  34. .ble_packet = (_ble_packet), \
  35. .ble_packet_size = G_N_ELEMENTS(_ble_packet), \
  36. .event = (_event), \
  37. .event_size = G_N_ELEMENTS(_event), \
  38. }
  39. struct midi_write_test {
  40. const snd_seq_event_t *event;
  41. size_t event_size;
  42. const snd_seq_event_t *event_expect;
  43. size_t event_expect_size;
  44. };
  45. #define BLE_WRITE_TEST_INIT(_event, _event_expect) \
  46. { \
  47. .event = (_event), \
  48. .event_size = G_N_ELEMENTS(_event), \
  49. .event_expect = (_event_expect), \
  50. .event_expect_size = G_N_ELEMENTS(_event_expect), \
  51. }
  52. #define BLE_WRITE_TEST_INIT_BASIC(_event) BLE_WRITE_TEST_INIT(_event, _event)
  53. #define NOTE_EVENT(_event, _channel, _note, _velocity) \
  54. { \
  55. .type = SND_SEQ_EVENT_##_event, \
  56. .data = { \
  57. .note = { \
  58. .channel = (_channel), \
  59. .note = (_note), \
  60. .velocity = (_velocity), \
  61. }, \
  62. }, \
  63. }
  64. #define CONTROL_EVENT(_event, _channel, _value, _param) \
  65. { \
  66. .type = SND_SEQ_EVENT_##_event, \
  67. .data = { \
  68. .control = { \
  69. .channel = (_channel), \
  70. .value = (_value), \
  71. .param = (_param), \
  72. }, \
  73. }, \
  74. }
  75. #define SYSEX_EVENT_RAW(_message, _size, _offset) \
  76. { \
  77. .type = SND_SEQ_EVENT_SYSEX, \
  78. .data = { \
  79. .ext = { \
  80. .ptr = (void *)(_message) + (_offset), \
  81. .len = (_size), \
  82. }, \
  83. }, \
  84. }
  85. #define SYSEX_EVENT(_message) SYSEX_EVENT_RAW(_message, sizeof(_message), 0)
  86. /* Multiple messages in one packet */
  87. static const uint8_t packet1_1[] = {
  88. 0xa6, 0x88, 0xe8, 0x00, 0x40, 0x88, 0xb8, 0x4a,
  89. 0x3f, 0x88, 0x98, 0x3e, 0x0e
  90. };
  91. /* Several one message per packet */
  92. static const uint8_t packet1_2[] = {
  93. 0xa6, 0xaa, 0xd8, 0x71
  94. };
  95. static const uint8_t packet1_3[] = {
  96. 0xa6, 0xb7, 0xb8, 0x4a, 0x43
  97. };
  98. /* This message contains a running status message */
  99. static const uint8_t packet1_4[] = {
  100. 0xa6, 0xc4, 0xe8, 0x7e, 0x3f, 0x7d, 0x3f, 0xc4,
  101. 0x7c, 0x3f
  102. };
  103. /* This message contain a running status message misplaced */
  104. static const uint8_t packet1_5[] = {
  105. 0xa6, 0xd9, 0x3e, 0x00, 0x88, 0x3e, 0x00
  106. };
  107. static const struct ble_midi_packet packet1[] = {
  108. BLE_MIDI_PACKET_INIT(packet1_1),
  109. BLE_MIDI_PACKET_INIT(packet1_2),
  110. BLE_MIDI_PACKET_INIT(packet1_3),
  111. BLE_MIDI_PACKET_INIT(packet1_4),
  112. BLE_MIDI_PACKET_INIT(packet1_5),
  113. };
  114. static const snd_seq_event_t event1[] = {
  115. CONTROL_EVENT(PITCHBEND, 8, 0, 0), /* Pitch Bend */
  116. CONTROL_EVENT(CONTROLLER, 8, 63, 74), /* Control Change */
  117. NOTE_EVENT(NOTEON, 8, 62, 14), /* Note On */
  118. CONTROL_EVENT(CHANPRESS, 8, 113, 0), /* Channel Aftertouch */
  119. CONTROL_EVENT(CONTROLLER, 8, 67, 74), /* Control Change*/
  120. CONTROL_EVENT(PITCHBEND, 8, -2, 0), /* Pitch Bend */
  121. CONTROL_EVENT(PITCHBEND, 8, -3, 0), /* Pitch Bend */
  122. CONTROL_EVENT(PITCHBEND, 8, -4, 0), /* Pitch Bend */
  123. NOTE_EVENT(NOTEOFF, 8, 62, 0), /* Note Off */
  124. };
  125. static const struct midi_read_test midi1 = BLE_READ_TEST_INIT(packet1, event1);
  126. /* Basic SysEx in one packet */
  127. static const uint8_t packet2_1[] = {
  128. 0xa6, 0xda, 0xf0, 0x01, 0x02, 0x03, 0xda, 0xf7
  129. };
  130. /* SysEx across two packets */
  131. static const uint8_t packet2_2[] = {
  132. 0xa6, 0xda, 0xf0, 0x01, 0x02, 0x03, 0x04, 0x05
  133. };
  134. static const uint8_t packet2_3[] = {
  135. 0xa6, 0x06, 0x07, 0x08, 0x09, 0x0a, 0xdb, 0xf7
  136. };
  137. /* SysEx across multiple packets */
  138. static const uint8_t packet2_4[] = {
  139. 0xa6, 0xda, 0xf0, 0x01, 0x02, 0x03, 0x04, 0x05
  140. };
  141. static const uint8_t packet2_5[] = {
  142. 0xa6, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c
  143. };
  144. static const uint8_t packet2_6[] = {
  145. 0xa6, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13
  146. };
  147. static const uint8_t packet2_7[] = {
  148. 0xa6, 0x14, 0x15, 0x16, 0x17, 0x18, 0xdb, 0xf7
  149. };
  150. /* Two SysEx interleaved in two packets */
  151. static const uint8_t packet2_8[] = {
  152. 0xa6, 0xda, 0xf0, 0x01, 0x02, 0x03, 0xda, 0xf7,
  153. 0xda, 0xf0
  154. };
  155. static const uint8_t packet2_9[] = {
  156. 0xa6, 0x06, 0x07, 0x08, 0x09, 0x0a, 0xdb, 0xf7
  157. };
  158. static const struct ble_midi_packet packet2[] = {
  159. BLE_MIDI_PACKET_INIT(packet2_1),
  160. BLE_MIDI_PACKET_INIT(packet2_2),
  161. BLE_MIDI_PACKET_INIT(packet2_3),
  162. BLE_MIDI_PACKET_INIT(packet2_4),
  163. BLE_MIDI_PACKET_INIT(packet2_5),
  164. BLE_MIDI_PACKET_INIT(packet2_6),
  165. BLE_MIDI_PACKET_INIT(packet2_7),
  166. BLE_MIDI_PACKET_INIT(packet2_8),
  167. BLE_MIDI_PACKET_INIT(packet2_9),
  168. };
  169. static const uint8_t sysex2_1[] = {
  170. 0xf0, 0x01, 0x02, 0x03, 0xf7
  171. };
  172. static const uint8_t sysex2_2[] = {
  173. 0xf0, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
  174. 0x08, 0x09, 0x0a, 0xf7
  175. };
  176. static const uint8_t sysex2_3[] = {
  177. 0xf0, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
  178. 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
  179. 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
  180. 0x18, 0xf7
  181. };
  182. static const uint8_t sysex2_4[] = {
  183. 0xf0, 0x01, 0x02, 0x03, 0xf7
  184. };
  185. static const uint8_t sysex2_5[] = {
  186. 0xf0, 0x06, 0x07, 0x08, 0x09, 0x0a, 0xf7
  187. };
  188. static const snd_seq_event_t event2[] = {
  189. SYSEX_EVENT(sysex2_1),
  190. SYSEX_EVENT(sysex2_2),
  191. SYSEX_EVENT(sysex2_3),
  192. SYSEX_EVENT(sysex2_4),
  193. SYSEX_EVENT(sysex2_5),
  194. };
  195. static const struct midi_read_test midi2 = BLE_READ_TEST_INIT(packet2, event2);
  196. static void compare_events(const snd_seq_event_t *ev1,
  197. const snd_seq_event_t *ev2)
  198. {
  199. g_assert_cmpint(ev1->type, ==, ev2->type);
  200. switch (ev1->type) {
  201. case SND_SEQ_EVENT_NOTEON:
  202. case SND_SEQ_EVENT_NOTEOFF:
  203. case SND_SEQ_EVENT_KEYPRESS:
  204. g_assert_cmpint(ev1->data.note.channel,
  205. ==,
  206. ev2->data.note.channel);
  207. g_assert_cmpint(ev1->data.note.note,
  208. ==,
  209. ev2->data.note.note);
  210. g_assert_cmpint(ev1->data.note.velocity,
  211. ==,
  212. ev2->data.note.velocity);
  213. break;
  214. case SND_SEQ_EVENT_CONTROLLER:
  215. g_assert_cmpint(ev1->data.control.param,
  216. ==,
  217. ev2->data.control.param);
  218. break;
  219. case SND_SEQ_EVENT_PITCHBEND:
  220. case SND_SEQ_EVENT_CHANPRESS:
  221. case SND_SEQ_EVENT_PGMCHANGE:
  222. g_assert_cmpint(ev1->data.control.channel,
  223. ==,
  224. ev2->data.control.channel);
  225. g_assert_cmpint(ev1->data.control.value,
  226. ==,
  227. ev2->data.control.value);
  228. break;
  229. case SND_SEQ_EVENT_SYSEX:
  230. g_assert_cmpint(ev1->data.ext.len,
  231. ==,
  232. ev2->data.ext.len);
  233. g_assert(memcmp(ev1->data.ext.ptr,
  234. ev2->data.ext.ptr,
  235. ev2->data.ext.len) == 0);
  236. break;
  237. default:
  238. g_assert_not_reached();
  239. }
  240. }
  241. static void test_midi_reader(gconstpointer data)
  242. {
  243. const struct midi_read_test *midi_test = data;
  244. struct midi_read_parser midi;
  245. int err;
  246. size_t i; /* ble_packet counter */
  247. size_t j; /* ble_packet length counter */
  248. size_t k = 0; /* event counter */
  249. err = midi_read_init(&midi);
  250. g_assert_cmpint(err, ==, 0);
  251. for (i = 0; i < midi_test->ble_packet_size; i++) {
  252. const size_t length = midi_test->ble_packet[i].size;
  253. j = 0;
  254. midi_read_reset(&midi);
  255. while (j < length) {
  256. snd_seq_event_t ev;
  257. const snd_seq_event_t *ev_expect = &midi_test->event[k];
  258. size_t count;
  259. g_assert_cmpint(k, <, midi_test->event_size);
  260. snd_seq_ev_clear(&ev);
  261. count = midi_read_raw(&midi,
  262. midi_test->ble_packet[i].data + j,
  263. length - j,
  264. &ev);
  265. g_assert_cmpuint(count, >, 0);
  266. if (ev.type == SND_SEQ_EVENT_NONE)
  267. goto _continue_loop;
  268. else
  269. k++;
  270. compare_events(ev_expect, &ev);
  271. _continue_loop:
  272. j += count;
  273. }
  274. }
  275. midi_read_free(&midi);
  276. tester_test_passed();
  277. }
  278. static const snd_seq_event_t event3[] = {
  279. CONTROL_EVENT(PITCHBEND, 8, 0, 0), /* Pitch Bend */
  280. CONTROL_EVENT(CONTROLLER, 8, 63, 74), /* Control Change */
  281. NOTE_EVENT(NOTEON, 8, 62, 14), /* Note On */
  282. CONTROL_EVENT(CHANPRESS, 8, 113, 0), /* Channel Aftertouch */
  283. CONTROL_EVENT(CONTROLLER, 8, 67, 74), /* Control Change*/
  284. CONTROL_EVENT(PITCHBEND, 8, -2, 0), /* Pitch Bend */
  285. CONTROL_EVENT(PITCHBEND, 8, -3, 0), /* Pitch Bend */
  286. CONTROL_EVENT(PITCHBEND, 8, -4, 0), /* Pitch Bend */
  287. NOTE_EVENT(NOTEOFF, 8, 62, 0), /* Note Off */
  288. };
  289. static const struct midi_write_test midi3 = BLE_WRITE_TEST_INIT_BASIC(event3);
  290. static const uint8_t sysex4_1[] = {
  291. 0xf0, 0x01, 0x02, 0x03, 0xf7
  292. };
  293. static const uint8_t sysex4_2[] = {
  294. 0xf0, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
  295. 0x08, 0x09, 0x0a, 0xf7
  296. };
  297. static const uint8_t sysex4_3[] = {
  298. 0xf0, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
  299. 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
  300. 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17,
  301. 0x18, 0xf7
  302. };
  303. static const uint8_t sysex4_4[] = {
  304. 0xf0, 0x01, 0x02, 0x03, 0xf7
  305. };
  306. static const uint8_t sysex4_5[] = {
  307. 0xf0, 0x06, 0x07, 0x08, 0x09, 0x0a, 0xf7
  308. };
  309. static const snd_seq_event_t event4[] = {
  310. SYSEX_EVENT(sysex4_1),
  311. SYSEX_EVENT(sysex4_2),
  312. SYSEX_EVENT(sysex4_3),
  313. SYSEX_EVENT(sysex4_4),
  314. SYSEX_EVENT(sysex4_5),
  315. };
  316. static const struct midi_write_test midi4 = BLE_WRITE_TEST_INIT_BASIC(event4);
  317. /* Sysex split in multiple events (256 bytes each),
  318. it's common for ALSA to split big sysexes into 256 bytes events */
  319. static const uint8_t sysex5_1[] = {
  320. 0xf0, 0x1b, 0x46, 0x52, 0x68, 0x45, 0x19, 0x3d,
  321. 0x70, 0x3c, 0x2b, 0x41, 0x09, 0x09, 0x28, 0x2d,
  322. 0x66, 0x00, 0x4f, 0x06, 0x22, 0x30, 0x77, 0x0d,
  323. 0x5d, 0x0e, 0x30, 0x21, 0x64, 0x5f, 0x72, 0x3c,
  324. 0x31, 0x3a, 0x03, 0x37, 0x3f, 0x00, 0x66, 0x52,
  325. 0x61, 0x6d, 0x03, 0x1e, 0x24, 0x2d, 0x33, 0x20,
  326. 0x69, 0x17, 0x77, 0x36, 0x58, 0x53, 0x11, 0x25,
  327. 0x2f, 0x51, 0x70, 0x4f, 0x00, 0x73, 0x6c, 0x3e,
  328. 0x66, 0x62, 0x53, 0x20, 0x0e, 0x41, 0x0b, 0x0e,
  329. 0x22, 0x27, 0x37, 0x14, 0x75, 0x31, 0x6f, 0x4b,
  330. 0x3e, 0x4b, 0x55, 0x71, 0x33, 0x2d, 0x0d, 0x3e,
  331. 0x58, 0x74, 0x4c, 0x44, 0x42, 0x2d, 0x47, 0x15,
  332. 0x3c, 0x75, 0x5f, 0x10, 0x26, 0x54, 0x5a, 0x1e,
  333. 0x07, 0x5a, 0x4a, 0x55, 0x55, 0x31, 0x40, 0x5d,
  334. 0x7f, 0x25, 0x32, 0x0c, 0x74, 0x1a, 0x05, 0x22,
  335. 0x66, 0x33, 0x5d, 0x38, 0x70, 0x15, 0x77, 0x35,
  336. 0x52, 0x09, 0x3e, 0x63, 0x76, 0x37, 0x3c, 0x25,
  337. 0x4c, 0x5c, 0x1e, 0x7d, 0x47, 0x0f, 0x2d, 0x67,
  338. 0x6e, 0x68, 0x3c, 0x4e, 0x08, 0x6c, 0x16, 0x58,
  339. 0x3d, 0x47, 0x19, 0x6d, 0x56, 0x12, 0x57, 0x56,
  340. 0x5e, 0x2d, 0x0d, 0x0d, 0x43, 0x25, 0x75, 0x70,
  341. 0x6a, 0x59, 0x3a, 0x7a, 0x41, 0x54, 0x03, 0x17,
  342. 0x2d, 0x7a, 0x67, 0x06, 0x78, 0x53, 0x0f, 0x43,
  343. 0x53, 0x4c, 0x02, 0x42, 0x68, 0x59, 0x0f, 0x51,
  344. 0x74, 0x40, 0x1d, 0x64, 0x6f, 0x46, 0x3f, 0x77,
  345. 0x71, 0x56, 0x2a, 0x24, 0x17, 0x25, 0x7f, 0x1f,
  346. 0x60, 0x19, 0x1d, 0x75, 0x4e, 0x43, 0x3d, 0x0d,
  347. 0x0d, 0x2e, 0x53, 0x44, 0x6c, 0x73, 0x7c, 0x6a,
  348. 0x12, 0x02, 0x11, 0x38, 0x6c, 0x2b, 0x2c, 0x5d,
  349. 0x4a, 0x48, 0x70, 0x7d, 0x44, 0x20, 0x41, 0x1e,
  350. 0x15, 0x4c, 0x43, 0x33, 0x1b, 0x7e, 0x43, 0x2f,
  351. 0x60, 0x6a, 0x61, 0x71, 0x21, 0x12, 0x32, 0x77,
  352. 0x3c, 0x21, 0x7a, 0x5f, 0x58, 0x6c, 0x1f, 0x3a,
  353. 0x68, 0x1c, 0x5d, 0x57, 0x1b, 0x0d, 0x77, 0x01,
  354. 0x10, 0x31, 0x4a, 0x73, 0x03, 0x48, 0x18, 0x0a,
  355. 0x32, 0x69, 0x38, 0x3f, 0x4d, 0x1a, 0x6e, 0x2f,
  356. 0x30, 0x56, 0x4c, 0x66, 0x76, 0x16, 0x3c, 0x7a,
  357. 0x31, 0x42, 0x40, 0x5d, 0x05, 0x33, 0x46, 0x53,
  358. 0x5f, 0x2c, 0x4d, 0x0d, 0x39, 0x53, 0x20, 0x6e,
  359. 0x61, 0x58, 0x12, 0x38, 0x25, 0x56, 0x22, 0x5b,
  360. 0x27, 0x44, 0x27, 0x44, 0x59, 0x16, 0x77, 0x26,
  361. 0x53, 0x35, 0x6e, 0x05, 0x70, 0x0f, 0x31, 0x30,
  362. 0x23, 0x2c, 0x65, 0x16, 0x2d, 0x05, 0x3e, 0x22,
  363. 0x6d, 0x22, 0x44, 0x3d, 0x18, 0x05, 0x10, 0x25,
  364. 0x6b, 0x66, 0x69, 0x14, 0x63, 0x63, 0x1b, 0x04,
  365. 0x41, 0x34, 0x6c, 0x09, 0x37, 0x6a, 0x63, 0x2e,
  366. 0x70, 0x72, 0x44, 0x41, 0x33, 0x01, 0x05, 0x05,
  367. 0x0b, 0x2a, 0x1a, 0x71, 0x55, 0x7e, 0x6e, 0x59,
  368. 0x47, 0x7d, 0x2f, 0x44, 0x03, 0x52, 0x6e, 0x6b,
  369. 0x4e, 0x11, 0x60, 0x1e, 0x0a, 0x71, 0x3d, 0x54,
  370. 0x02, 0x1c, 0x73, 0x0b, 0x76, 0x32, 0x48, 0x66,
  371. 0x36, 0x47, 0x6f, 0x5b, 0x6b, 0x3b, 0x14, 0x47,
  372. 0x0c, 0x16, 0x6c, 0x27, 0x2a, 0x73, 0x17, 0x1d,
  373. 0x16, 0x60, 0x63, 0x7b, 0x1d, 0x4f, 0x61, 0x5b,
  374. 0x13, 0x20, 0x46, 0x0c, 0x71, 0x7d, 0x27, 0x43,
  375. 0x49, 0x48, 0x7f, 0x3e, 0x4b, 0x7b, 0x27, 0x7b,
  376. 0x73, 0x53, 0x57, 0x68, 0x05, 0x2a, 0x2f, 0x36,
  377. 0x3b, 0x31, 0x11, 0x4e, 0x4c, 0x13, 0x2e, 0x06,
  378. 0x06, 0x7c, 0x40, 0x37, 0x27, 0x0f, 0x01, 0x67,
  379. 0x06, 0x09, 0x4b, 0x17, 0x0f, 0x4e, 0x51, 0x44,
  380. 0x66, 0x6c, 0x70, 0x2a, 0x55, 0x62, 0x6d, 0x3b,
  381. 0x16, 0x1b, 0x79, 0x08, 0x08, 0x77, 0x4a, 0x17,
  382. 0x15, 0x47, 0x58, 0x5c, 0x5d, 0x3d, 0x12, 0x36,
  383. 0x48, 0x5e, 0x51, 0x19, 0x6e, 0x5f, 0x64, 0x3c,
  384. 0x62, 0x0b, 0x00, 0x15, 0x15, 0x2e, 0x4d, 0x5c,
  385. 0x1b, 0x0a, 0x51, 0x1b, 0x13, 0x68, 0x14, 0x28,
  386. 0x26, 0x69, 0x27, 0x52, 0x13, 0x1e, 0x19, 0x31,
  387. 0x42, 0x0e, 0x3a, 0x29, 0x07, 0x41, 0x27, 0x40,
  388. 0x4e, 0x68, 0x68, 0x78, 0x64, 0x36, 0x52, 0x7a,
  389. 0x07, 0x6e, 0x46, 0x63, 0x4a, 0x6c, 0x5b, 0x4c,
  390. 0x74, 0x14, 0x14, 0x76, 0x15, 0x2d, 0x79, 0x10,
  391. 0x65, 0x48, 0x60, 0x6a, 0x1c, 0x65, 0x74, 0x73,
  392. 0x56, 0x3c, 0x4b, 0x34, 0x20, 0x24, 0x36, 0x0d,
  393. 0x3c, 0x59, 0x0f, 0x46, 0x47, 0x4a, 0x53, 0x62,
  394. 0x63, 0x44, 0x22, 0x39, 0x15, 0x68, 0x60, 0x7b,
  395. 0x73, 0x0f, 0x34, 0x79, 0x6a, 0x76, 0x4e, 0x0f,
  396. 0x02, 0x5d, 0x09, 0x73, 0x76, 0x18, 0x48, 0x4f,
  397. 0x72, 0x19, 0x71, 0x3c, 0x6e, 0x0b, 0x3b, 0x45,
  398. 0x1c, 0x3e, 0x1b, 0x46, 0x74, 0x03, 0x5d, 0x0a,
  399. 0x01, 0x62, 0x04, 0x2f, 0x6f, 0x03, 0x4c, 0x36,
  400. 0x5f, 0x6a, 0x0c, 0x79, 0x34, 0x4f, 0x42, 0x6c,
  401. 0x66, 0x21, 0x26, 0x21, 0x4a, 0x0e, 0x3e, 0x73,
  402. 0x45, 0x43, 0x5e, 0x2a, 0x63, 0x32, 0x0b, 0x66,
  403. 0x09, 0x46, 0x15, 0x46, 0x1c, 0x46, 0x10, 0x5b,
  404. 0x09, 0x75, 0x67, 0x7f, 0x51, 0x6d, 0x12, 0x65,
  405. 0x0d, 0x52, 0x06, 0x28, 0x61, 0x0f, 0x4e, 0x51,
  406. 0x61, 0x75, 0x1f, 0x26, 0x31, 0x66, 0x34, 0x67,
  407. 0x5d, 0x59, 0x2e, 0x18, 0x40, 0x63, 0x16, 0x12,
  408. 0x49, 0x60, 0x1c, 0x62, 0x30, 0x21, 0x5c, 0x69,
  409. 0x2c, 0x29, 0x1c, 0x3b, 0x3d, 0x13, 0x49, 0x4d,
  410. 0x1f, 0x5f, 0x1d, 0x0a, 0x54, 0x1e, 0x52, 0x27,
  411. 0x79, 0x79, 0x31, 0x03, 0x67, 0x02, 0x6a, 0x63,
  412. 0x36, 0x5d, 0x38, 0x48, 0x1b, 0x4e, 0x5b, 0x63,
  413. 0x7b, 0x7b, 0x4e, 0x71, 0x45, 0x37, 0x34, 0x44,
  414. 0x03, 0x51, 0x31, 0x23, 0x0b, 0x18, 0x6d, 0x7f,
  415. 0x76, 0x21, 0x17, 0x27, 0x45, 0x09, 0x0c, 0x2e,
  416. 0x69, 0x74, 0x59, 0x2b, 0x75, 0x0c, 0x34, 0x0a,
  417. 0x3a, 0x27, 0x25, 0x7b, 0x45, 0x0d, 0x59, 0x2f,
  418. 0x2b, 0x57, 0x7e, 0x1f, 0x05, 0x62, 0x28, 0x79,
  419. 0x7e, 0x1d, 0x58, 0x30, 0x35, 0x06, 0x67, 0x5b,
  420. 0x7a, 0x00, 0x34, 0x32, 0x33, 0x2f, 0x68, 0x4b,
  421. 0x76, 0x38, 0x7e, 0x58, 0x50, 0x56, 0x6d, 0x1f,
  422. 0x14, 0x6f, 0x77, 0x39, 0x71, 0x35, 0x08, 0x44,
  423. 0x3b, 0x09, 0x16, 0x19, 0x13, 0x1c, 0x67, 0x7d,
  424. 0x7f, 0x56, 0x7e, 0x31, 0x6b, 0x67, 0x44, 0x76,
  425. 0x53, 0x55, 0x6d, 0x3d, 0x13, 0x3b, 0x37, 0x1c,
  426. 0x0b, 0x21, 0x58, 0x03, 0x31, 0x2d, 0x3d, 0x6c,
  427. 0x01, 0x6d, 0x08, 0x1d, 0x03, 0x4d, 0x6e, 0x63,
  428. 0x4c, 0x21, 0x2c, 0x57, 0x48, 0x07, 0x52, 0x2a,
  429. 0x6d, 0x64, 0x0d, 0x56, 0x7e, 0x08, 0x3c, 0x1b,
  430. 0x28, 0x04, 0x0f, 0x58, 0x0d, 0x6a, 0x73, 0x70,
  431. 0x28, 0x0c, 0x6e, 0x1e, 0x09, 0x39, 0x46, 0x3e,
  432. 0x62, 0x08, 0x72, 0x52, 0x42, 0x02, 0x78, 0x62,
  433. 0x31, 0x73, 0x0d, 0x4d, 0x5c, 0x07, 0x64, 0x17,
  434. 0x55, 0x29, 0x60, 0x07, 0x67, 0x59, 0x63, 0x78,
  435. 0x73, 0x17, 0x42, 0x27, 0x0e, 0x77, 0x15, 0x60,
  436. 0x07, 0x46, 0x53, 0x6a, 0x05, 0x38, 0x12, 0x14,
  437. 0x1f, 0x1b, 0x11, 0x6a, 0x1d, 0x02, 0x3c, 0x05,
  438. 0x75, 0x6d, 0x51, 0x16, 0x10, 0x6f, 0x02, 0x46,
  439. 0x39, 0x2e, 0x37, 0x47, 0x7a, 0x5b, 0x39, 0x15,
  440. 0x14, 0x4b, 0x77, 0x0b, 0x19, 0x24, 0x4d, 0x36,
  441. 0x33, 0x4c, 0x6a, 0x53, 0x79, 0x69, 0x57, 0x17,
  442. 0x10, 0x75, 0x1f, 0x72, 0x08, 0x71, 0x58, 0x14,
  443. 0x46, 0x4a, 0x6f, 0x3c, 0x30, 0x34, 0x5b, 0x36,
  444. 0x42, 0x13, 0x11, 0x45, 0x78, 0x5a, 0x57, 0x68,
  445. 0x33, 0x4b, 0x21, 0x00, 0x06, 0x6b, 0x3d, 0x17,
  446. 0x0e, 0x6a, 0x2b, 0x2a, 0x32, 0x3a, 0x2a, 0x46,
  447. 0x79, 0x1f, 0x56, 0x40, 0x43, 0x36, 0x18, 0xf7,
  448. };
  449. static const snd_seq_event_t event5[] = {
  450. /* SysEx over 4 events */
  451. SYSEX_EVENT_RAW(sysex5_1, 256, 0),
  452. SYSEX_EVENT_RAW(sysex5_1, 256, 256),
  453. SYSEX_EVENT_RAW(sysex5_1, 256, 512),
  454. SYSEX_EVENT_RAW(sysex5_1, 256, 768),
  455. };
  456. static const snd_seq_event_t event5_expect[] = {
  457. SYSEX_EVENT(sysex5_1),
  458. };
  459. static const struct midi_write_test midi5 = BLE_WRITE_TEST_INIT(event5, event5_expect);
  460. static void test_midi_writer(gconstpointer data)
  461. {
  462. const struct midi_write_test *midi_test = data;
  463. struct midi_write_parser midi_out;
  464. struct midi_read_parser midi_in;
  465. size_t i; /* event counter */
  466. size_t j; /* test counter */
  467. struct midi_data {
  468. size_t events_tested;
  469. const struct midi_write_test *midi_test;
  470. struct midi_read_parser *midi_in;
  471. } midi_data;
  472. void compare_events_cb(const struct midi_write_parser *parser, void *user_data) {
  473. struct midi_data *midi_data = user_data;
  474. const struct midi_write_test *midi_test = midi_data->midi_test;
  475. struct midi_read_parser *midi_in = midi_data->midi_in;
  476. size_t i = 0;
  477. midi_read_reset(midi_in);
  478. while (i < midi_write_data_size(parser)) {
  479. snd_seq_event_t ev;
  480. size_t count;
  481. snd_seq_ev_clear(&ev);
  482. count = midi_read_raw(midi_in, midi_write_data(parser) + i,
  483. midi_write_data_size(parser) - i, &ev);
  484. g_assert_cmpuint(count, >, 0);
  485. if (ev.type != SND_SEQ_EVENT_NONE){
  486. g_assert_cmpint(midi_data->events_tested,
  487. <,
  488. midi_test->event_expect_size);
  489. compare_events(&midi_test->event_expect[midi_data->events_tested],
  490. &ev);
  491. midi_data->events_tested++;
  492. }
  493. i += count;
  494. }
  495. };
  496. midi_read_init(&midi_in);
  497. for (j = 0; j < NUM_WRITE_TESTS; j++) {
  498. /* Range of test for different MTU sizes. The spec specifies
  499. sizes of packet as MTU - 3 */
  500. midi_write_init(&midi_out, g_random_int_range(5, 512));
  501. midi_data.events_tested = 0;
  502. midi_data.midi_test = midi_test;
  503. midi_data.midi_in = &midi_in;
  504. for (i = 0; i < midi_test->event_size; i++)
  505. midi_read_ev(&midi_out, &midi_test->event[i],
  506. compare_events_cb, &midi_data);
  507. if (midi_write_has_data(&midi_out))
  508. compare_events_cb(&midi_out, &midi_data);
  509. g_assert_cmpint(midi_data.events_tested,
  510. ==,
  511. midi_test->event_expect_size);
  512. midi_write_free(&midi_out);
  513. }
  514. midi_read_free(&midi_in);
  515. tester_test_passed();
  516. }
  517. int main(int argc, char *argv[])
  518. {
  519. tester_init(&argc, &argv);
  520. tester_add("Raw BLE packets read",
  521. &midi1, NULL, test_midi_reader, NULL);
  522. tester_add("Raw BLE packets SysEx read",
  523. &midi2, NULL, test_midi_reader, NULL);
  524. tester_add("ALSA Seq events to Raw BLE packets",
  525. &midi3, NULL, test_midi_writer, NULL);
  526. tester_add("ALSA SysEx events to Raw BLE packets",
  527. &midi4, NULL, test_midi_writer, NULL);
  528. tester_add("Split ALSA SysEx events to raw BLE packets",
  529. &midi5, NULL, test_midi_writer, NULL);
  530. return tester_run();
  531. }