mp3.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. #include <rtthread.h>
  2. #include <dfs_posix.h>
  3. #include <mp3/pub/mp3dec.h>
  4. #include <string.h>
  5. #include "board.h"
  6. #include "netbuffer.h"
  7. #include "player_ui.h"
  8. #include "player_bg.h"
  9. #define MP3_AUDIO_BUF_SZ 8192
  10. #ifndef MIN
  11. #define MIN(x, y) ((x) < (y)? (x) : (y))
  12. #endif
  13. rt_uint8_t mp3_fd_buffer[MP3_AUDIO_BUF_SZ];
  14. struct mp3_decoder
  15. {
  16. /* mp3 information */
  17. HMP3Decoder decoder;
  18. MP3FrameInfo frame_info;
  19. rt_uint32_t frames;
  20. /* mp3 file descriptor */
  21. rt_size_t (*fetch_data)(void* parameter, rt_uint8_t *buffer, rt_size_t length);
  22. void* fetch_parameter;
  23. /* mp3 read session */
  24. rt_uint8_t *read_buffer, *read_ptr;
  25. rt_int32_t read_offset;
  26. rt_uint32_t bytes_left, bytes_left_before_decoding;
  27. /* audio device */
  28. rt_device_t snd_device;
  29. };
  30. static rt_err_t mp3_decoder_tx_done(rt_device_t dev, void *buffer)
  31. {
  32. /* release memory block */
  33. sbuf_release(buffer);
  34. return RT_EOK;
  35. }
  36. void mp3_decoder_init(struct mp3_decoder* decoder)
  37. {
  38. RT_ASSERT(decoder != RT_NULL);
  39. /* init read session */
  40. decoder->read_ptr = RT_NULL;
  41. decoder->bytes_left_before_decoding = decoder->bytes_left = 0;
  42. decoder->frames = 0;
  43. // decoder->read_buffer = rt_malloc(MP3_AUDIO_BUF_SZ);
  44. decoder->read_buffer = &mp3_fd_buffer[0];
  45. if (decoder->read_buffer == RT_NULL) return;
  46. decoder->decoder = MP3InitDecoder();
  47. /* open audio device */
  48. decoder->snd_device = rt_device_find("snd");
  49. if (decoder->snd_device != RT_NULL)
  50. {
  51. /* set tx complete call back function */
  52. rt_device_set_tx_complete(decoder->snd_device, mp3_decoder_tx_done);
  53. rt_device_open(decoder->snd_device, RT_DEVICE_OFLAG_WRONLY);
  54. }
  55. }
  56. void mp3_decoder_detach(struct mp3_decoder* decoder)
  57. {
  58. RT_ASSERT(decoder != RT_NULL);
  59. /* close audio device */
  60. if (decoder->snd_device != RT_NULL)
  61. rt_device_close(decoder->snd_device);
  62. /* release mp3 decoder */
  63. MP3FreeDecoder(decoder->decoder);
  64. }
  65. struct mp3_decoder* mp3_decoder_create()
  66. {
  67. struct mp3_decoder* decoder;
  68. /* allocate object */
  69. decoder = (struct mp3_decoder*) rt_malloc (sizeof(struct mp3_decoder));
  70. if (decoder != RT_NULL)
  71. {
  72. mp3_decoder_init(decoder);
  73. }
  74. return decoder;
  75. }
  76. void mp3_decoder_delete(struct mp3_decoder* decoder)
  77. {
  78. RT_ASSERT(decoder != RT_NULL);
  79. /* de-init mp3 decoder object */
  80. mp3_decoder_detach(decoder);
  81. /* release this object */
  82. rt_free(decoder);
  83. }
  84. rt_uint32_t current_offset = 0;
  85. static rt_int32_t mp3_decoder_fill_buffer(struct mp3_decoder* decoder)
  86. {
  87. rt_size_t bytes_read;
  88. rt_size_t bytes_to_read;
  89. // rt_kprintf("left: %d. refilling inbuffer...\n", decoder->bytes_left);
  90. if (decoder->bytes_left > 0)
  91. {
  92. // better: move unused rest of buffer to the start
  93. rt_memmove(decoder->read_buffer, decoder->read_ptr, decoder->bytes_left);
  94. }
  95. bytes_to_read = (MP3_AUDIO_BUF_SZ - decoder->bytes_left) & ~(512 - 1);
  96. bytes_read = decoder->fetch_data(decoder->fetch_parameter,
  97. (rt_uint8_t *)(decoder->read_buffer + decoder->bytes_left),
  98. bytes_to_read);
  99. if (bytes_read != 0)
  100. {
  101. decoder->read_ptr = decoder->read_buffer;
  102. decoder->read_offset = 0;
  103. decoder->bytes_left = decoder->bytes_left + bytes_read;
  104. return 0;
  105. }
  106. else
  107. {
  108. rt_kprintf("can't read more data\n");
  109. return -1;
  110. }
  111. }
  112. int mp3_decoder_run(struct mp3_decoder* decoder)
  113. {
  114. int err;
  115. rt_uint16_t* buffer;
  116. rt_uint32_t delta;
  117. RT_ASSERT(decoder != RT_NULL);
  118. if (player_is_playing() != RT_TRUE) return -1;
  119. if ((decoder->read_ptr == RT_NULL) || decoder->bytes_left < 2*MAINBUF_SIZE)
  120. {
  121. if(mp3_decoder_fill_buffer(decoder) != 0)
  122. return -1;
  123. }
  124. // rt_kprintf("read offset: 0x%08x\n", decoder->read_ptr - decoder->read_buffer);
  125. decoder->read_offset = MP3FindSyncWord(decoder->read_ptr, decoder->bytes_left);
  126. if (decoder->read_offset < 0)
  127. {
  128. /* discard this data */
  129. rt_kprintf("outof sync, byte left: %d\n", decoder->bytes_left);
  130. decoder->bytes_left = 0;
  131. return 0;
  132. }
  133. decoder->read_ptr += decoder->read_offset;
  134. delta = decoder->read_offset;
  135. decoder->bytes_left -= decoder->read_offset;
  136. if (decoder->bytes_left < 1024)
  137. {
  138. /* fill more data */
  139. if(mp3_decoder_fill_buffer(decoder) != 0)
  140. return -1;
  141. }
  142. /* get a decoder buffer */
  143. buffer = (rt_uint16_t*)sbuf_alloc();
  144. decoder->bytes_left_before_decoding = decoder->bytes_left;
  145. err = MP3Decode(decoder->decoder, &decoder->read_ptr,
  146. (int*)&decoder->bytes_left, (short*)buffer, 0);
  147. delta += (decoder->bytes_left_before_decoding - decoder->bytes_left);
  148. current_offset += delta;
  149. player_set_position(current_offset);
  150. // rt_kprintf("bytes left after decode: %d\n", decoder->bytes_left);
  151. decoder->frames++;
  152. if (err != ERR_MP3_NONE)
  153. {
  154. switch (err)
  155. {
  156. case ERR_MP3_INDATA_UNDERFLOW:
  157. rt_kprintf("ERR_MP3_INDATA_UNDERFLOW\n");
  158. decoder->bytes_left = 0;
  159. if(mp3_decoder_fill_buffer(decoder) != 0)
  160. {
  161. /* release this memory block */
  162. sbuf_release(buffer);
  163. return -1;
  164. }
  165. break;
  166. case ERR_MP3_MAINDATA_UNDERFLOW:
  167. /* do nothing - next call to decode will provide more mainData */
  168. rt_kprintf("ERR_MP3_MAINDATA_UNDERFLOW\n");
  169. break;
  170. default:
  171. rt_kprintf("unknown error: %d, left: %d\n", err, decoder->bytes_left);
  172. // skip this frame
  173. if (decoder->bytes_left > 0)
  174. {
  175. decoder->bytes_left --;
  176. decoder->read_ptr ++;
  177. }
  178. else
  179. {
  180. // TODO
  181. RT_ASSERT(0);
  182. }
  183. break;
  184. }
  185. /* release this memory block */
  186. sbuf_release(buffer);
  187. }
  188. else
  189. {
  190. /* no error */
  191. MP3GetLastFrameInfo(decoder->decoder, &decoder->frame_info);
  192. /* set sample rate */
  193. /* write to sound device */
  194. if (decoder->frame_info.outputSamps > 0)
  195. {
  196. rt_device_write(decoder->snd_device, 0, buffer, decoder->frame_info.outputSamps * 2);
  197. }
  198. else
  199. {
  200. /* no output */
  201. sbuf_release(buffer);
  202. }
  203. }
  204. return 0;
  205. }
  206. static int mp3_parse_id3v1(int fd, struct tag_info *info)
  207. {
  208. lseek(fd, -128, SEEK_END);
  209. read(fd, (char *) mp3_fd_buffer, 128);
  210. /* ID3v1 */
  211. if (strncmp("TAG", (char *) mp3_fd_buffer, 3) == 0)
  212. {
  213. strncpy(info->title, (char *) mp3_fd_buffer + 3, MIN(30, sizeof(info->title) - 1));
  214. strncpy(info->artist, (char *) mp3_fd_buffer + 3 + 30, MIN(30, sizeof(info->artist) - 1));
  215. return 0;
  216. }
  217. return -1;
  218. }
  219. static int mp3_parse_id3v2(int fd, struct tag_info *info)
  220. {
  221. rt_uint32_t p = 0;
  222. lseek(fd, 0, SEEK_SET);
  223. read(fd, (char *) mp3_fd_buffer, sizeof(mp3_fd_buffer));
  224. if (strncmp("ID3", (char *) mp3_fd_buffer, 3) == 0)
  225. {
  226. rt_uint32_t tag_size, frame_size, i;
  227. rt_uint8_t version_major;
  228. int frame_header_size;
  229. tag_size = ((rt_uint32_t) mp3_fd_buffer[6] << 21) | ((rt_uint32_t) mp3_fd_buffer[7] << 14) | ((rt_uint16_t) mp3_fd_buffer[8] << 7) | mp3_fd_buffer[9];
  230. info->data_start = tag_size;
  231. version_major = mp3_fd_buffer[3];
  232. if (version_major >= 3)
  233. {
  234. frame_header_size = 10;
  235. }
  236. else
  237. {
  238. frame_header_size = 6;
  239. }
  240. i = p = 10;
  241. // iterate through frames
  242. while (p < tag_size)
  243. {
  244. if (version_major >= 3)
  245. {
  246. frame_size = ((rt_uint32_t) mp3_fd_buffer[i + 4] << 24) | ((rt_uint32_t) mp3_fd_buffer[i + 5] << 16) | ((rt_uint16_t) mp3_fd_buffer[i + 6] << 8) | mp3_fd_buffer[i + 7];
  247. }
  248. else
  249. {
  250. frame_size = ((rt_uint32_t) mp3_fd_buffer[i + 3] << 14) | ((rt_uint16_t) mp3_fd_buffer[i + 4] << 7) | mp3_fd_buffer[i + 5];
  251. }
  252. if (i + frame_size + frame_header_size + frame_header_size >= sizeof(mp3_fd_buffer))
  253. {
  254. if (frame_size + frame_header_size > sizeof(mp3_fd_buffer))
  255. {
  256. lseek(fd, p + frame_size + frame_header_size, SEEK_CUR);
  257. read(fd, (char *) mp3_fd_buffer, sizeof(mp3_fd_buffer));
  258. p += frame_size + frame_header_size;
  259. i = 0;
  260. continue;
  261. }
  262. else
  263. {
  264. int r = sizeof(mp3_fd_buffer) - i;
  265. memmove(mp3_fd_buffer, mp3_fd_buffer + i, r);
  266. read(fd, (char *) mp3_fd_buffer + r, i);
  267. i = 0;
  268. }
  269. }
  270. if (strncmp("TT2", (char *) mp3_fd_buffer + i, 3) == 0 || strncmp("TIT2", (char *) mp3_fd_buffer + i, 4) == 0)
  271. {
  272. strncpy(info->title, (char *) mp3_fd_buffer + i + frame_header_size + 1, MIN(frame_size - 1, sizeof(info->title) - 1));
  273. }
  274. else if (strncmp("TP1", (char *) mp3_fd_buffer + i, 3) == 0 || strncmp("TPE1", (char *) mp3_fd_buffer + i, 4) == 0)
  275. {
  276. strncpy(info->artist, (char *) mp3_fd_buffer + i + frame_header_size + 1, MIN(frame_size - 1, sizeof(info->artist) - 1));
  277. }
  278. p += frame_size + frame_header_size;
  279. i += frame_size + frame_header_size;
  280. }
  281. return 0;
  282. }
  283. return -1;
  284. }
  285. /* get mp3 information */
  286. void mp3_get_info(const char* filename, struct tag_info* info)
  287. {
  288. int fd;
  289. rt_size_t bytes_read;
  290. int sync_word;
  291. HMP3Decoder decoder;
  292. MP3FrameInfo frame_info;
  293. if (filename == RT_NULL || info == RT_NULL) return;
  294. fd = open(filename, O_RDONLY, 0);
  295. if (fd < 0) return; /* can't read file */
  296. /* init decoder */
  297. decoder = MP3InitDecoder();
  298. info->data_start = 0;
  299. /*
  300. * TODO - Add UTF-8 support and fix this.
  301. *
  302. * ID3 v2 is generally useless here, because it
  303. * uses UTF-8 encoding, which we can't handle right now.
  304. * But parsing v2 first is nesessary in order to
  305. * find the correct MP3 frame header location,
  306. * in case of the ID3 v2 tag should be there.
  307. */
  308. // if (mp3_parse_id3v2(fd, info) < 0)
  309. // {
  310. // // ID3 v2 is not available. Fall back to ID3 v1.
  311. // mp3_parse_id3v1(fd, info);
  312. // }
  313. mp3_parse_id3v2(fd, info);
  314. mp3_parse_id3v1(fd, info);
  315. lseek(fd, info->data_start, SEEK_SET);
  316. bytes_read = read(fd, (char *) mp3_fd_buffer, sizeof(mp3_fd_buffer));
  317. /* get frame information */
  318. sync_word = MP3FindSyncWord(mp3_fd_buffer, bytes_read);
  319. if (sync_word >= 0)
  320. {
  321. rt_uint32_t p;
  322. short samples_per_frame;
  323. /* get frame information */
  324. MP3GetNextFrameInfo(decoder, &frame_info, &mp3_fd_buffer[sync_word]);
  325. // Try to locate the Xing VBR header.
  326. if (frame_info.version == MPEG1)
  327. {
  328. p = frame_info.nChans == 2 ? 32 : 17;
  329. samples_per_frame = 1152;
  330. }
  331. else
  332. {
  333. p = frame_info.nChans == 2 ? 17 : 9;
  334. samples_per_frame = 576;
  335. }
  336. p += sync_word + 4;
  337. if (strncmp("Xing", (char *) mp3_fd_buffer + p, 4) == 0 || strncmp("Info", (char *) mp3_fd_buffer + p, 4) == 0)
  338. {
  339. // VBR
  340. if (mp3_fd_buffer[p + 7] & 1 == 1) /* Checks if the frames field exists */
  341. {
  342. rt_uint32_t frames = ((rt_uint32_t) mp3_fd_buffer[p + 8] << 24) | ((rt_uint32_t) mp3_fd_buffer[p + 9] << 16) | ((rt_uint32_t) mp3_fd_buffer[p + 10] << 8) | (rt_uint32_t) mp3_fd_buffer[p + 11];
  343. info->duration = frames * samples_per_frame / frame_info.samprate;
  344. info->bit_rate = lseek(fd, 0, SEEK_END) * 8 / info->duration;
  345. }
  346. else
  347. {
  348. // Calculate as CBR
  349. info->duration = lseek(fd, 0, SEEK_END) / (frame_info.bitrate / 8); /* second */
  350. info->bit_rate = frame_info.bitrate;
  351. }
  352. }
  353. /*
  354. * There're two other rarely used VBR header standards: VBRI & MLLT.
  355. * I can't find any sample with these headers. So I just ignored them. :)
  356. */
  357. else
  358. {
  359. // CBR
  360. info->duration = lseek(fd, 0, SEEK_END) / (frame_info.bitrate / 8); /* second */
  361. info->bit_rate = frame_info.bitrate;
  362. }
  363. info->sampling = frame_info.samprate;
  364. }
  365. /* set current position */
  366. info->position = 0;
  367. /* release mp3 decoder */
  368. MP3FreeDecoder(decoder);
  369. /* close file */
  370. close(fd);
  371. }
  372. #include <finsh.h>
  373. rt_size_t fd_fetch(void* parameter, rt_uint8_t *buffer, rt_size_t length)
  374. {
  375. int fd = (int)parameter;
  376. int read_bytes;
  377. read_bytes = read(fd, (char*)buffer, length);
  378. if (read_bytes <= 0) return 0;
  379. return read_bytes;
  380. }
  381. void mp3(char* filename)
  382. {
  383. int fd;
  384. struct mp3_decoder* decoder;
  385. extern rt_bool_t is_playing;
  386. is_playing = RT_TRUE;
  387. fd = open(filename, O_RDONLY, 0);
  388. if (fd >= 0)
  389. {
  390. decoder = mp3_decoder_create();
  391. if (decoder != RT_NULL)
  392. {
  393. decoder->fetch_data = fd_fetch;
  394. decoder->fetch_parameter = (void*)fd;
  395. current_offset = 0;
  396. while (mp3_decoder_run(decoder) != -1);
  397. /* delete decoder object */
  398. mp3_decoder_delete(decoder);
  399. }
  400. close(fd);
  401. }
  402. is_playing = RT_FALSE;
  403. }
  404. FINSH_FUNCTION_EXPORT(mp3, mp3 decode test);
  405. #if STM32_EXT_SRAM
  406. /* http mp3 */
  407. #include "http.h"
  408. static rt_size_t http_fetch(rt_uint8_t* ptr, rt_size_t len, void* parameter)
  409. {
  410. struct http_session* session = (struct http_session*)parameter;
  411. RT_ASSERT(session != RT_NULL);
  412. return http_session_read(session, ptr, len);
  413. }
  414. static void http_close(void* parameter)
  415. {
  416. struct http_session* session = (struct http_session*)parameter;
  417. RT_ASSERT(session != RT_NULL);
  418. http_session_close(session);
  419. }
  420. rt_size_t http_data_fetch(void* parameter, rt_uint8_t *buffer, rt_size_t length)
  421. {
  422. return net_buf_read(buffer, length);
  423. }
  424. void http_mp3(char* url)
  425. {
  426. struct http_session* session;
  427. struct mp3_decoder* decoder;
  428. extern rt_bool_t is_playing;
  429. is_playing = RT_TRUE;
  430. session = http_session_open(url);
  431. if (session != RT_NULL)
  432. {
  433. /* add a job to netbuf worker */
  434. net_buf_add_job(http_fetch, http_close, (void*)session);
  435. decoder = mp3_decoder_create();
  436. if (decoder != RT_NULL)
  437. {
  438. decoder->fetch_data = http_data_fetch;
  439. decoder->fetch_parameter = RT_NULL;
  440. current_offset = 0;
  441. while (mp3_decoder_run(decoder) != -1);
  442. /* delete decoder object */
  443. mp3_decoder_delete(decoder);
  444. }
  445. session = RT_NULL;
  446. }
  447. }
  448. FINSH_FUNCTION_EXPORT(http_mp3, http mp3 decode test);
  449. /* ice mp3 */
  450. static rt_size_t ice_fetch(rt_uint8_t* ptr, rt_size_t len, void* parameter)
  451. {
  452. struct shoutcast_session* session = (struct shoutcast_session*)parameter;
  453. RT_ASSERT(session != RT_NULL);
  454. return shoutcast_session_read(session, ptr, len);
  455. }
  456. static void ice_close(void* parameter)
  457. {
  458. struct shoutcast_session* session = (struct shoutcast_session*)parameter;
  459. RT_ASSERT(session != RT_NULL);
  460. shoutcast_session_close(session);
  461. }
  462. rt_size_t ice_data_fetch(void* parameter, rt_uint8_t *buffer, rt_size_t length)
  463. {
  464. return net_buf_read(buffer, length);
  465. }
  466. void ice_mp3(char* url)
  467. {
  468. struct shoutcast_session* session;
  469. struct mp3_decoder* decoder;
  470. extern rt_bool_t is_playing;
  471. is_playing = RT_TRUE;
  472. session = shoutcast_session_open(url);
  473. if (session != RT_NULL)
  474. {
  475. /* add a job to netbuf worker */
  476. net_buf_add_job(ice_fetch, ice_close, (void*)session);
  477. decoder = mp3_decoder_create();
  478. if (decoder != RT_NULL)
  479. {
  480. decoder->fetch_data = ice_data_fetch;
  481. decoder->fetch_parameter = RT_NULL;
  482. current_offset = 0;
  483. while (mp3_decoder_run(decoder) != -1);
  484. /* delete decoder object */
  485. mp3_decoder_delete(decoder);
  486. }
  487. session = RT_NULL;
  488. }
  489. }
  490. FINSH_FUNCTION_EXPORT(ice_mp3, shoutcast mp3 decode test);
  491. #endif