mp3.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513
  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 4096
  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. // rt_kprintf("read bytes: %d\n", bytes_to_read);
  97. bytes_read = decoder->fetch_data(decoder->fetch_parameter,
  98. (rt_uint8_t *)(decoder->read_buffer + decoder->bytes_left),
  99. bytes_to_read);
  100. if (bytes_read == bytes_to_read)
  101. {
  102. decoder->read_ptr = decoder->read_buffer;
  103. decoder->read_offset = 0;
  104. decoder->bytes_left = decoder->bytes_left + bytes_to_read;
  105. return 0;
  106. }
  107. else
  108. {
  109. rt_kprintf("can't read more data");
  110. return -1;
  111. }
  112. }
  113. int mp3_decoder_run(struct mp3_decoder* decoder)
  114. {
  115. int err;
  116. rt_uint16_t* buffer;
  117. rt_uint32_t delta;
  118. RT_ASSERT(decoder != RT_NULL);
  119. if (player_is_playing() != RT_TRUE) return -1;
  120. if ((decoder->read_ptr == RT_NULL) || decoder->bytes_left < 2*MAINBUF_SIZE)
  121. {
  122. if(mp3_decoder_fill_buffer(decoder) != 0)
  123. return -1;
  124. }
  125. // rt_kprintf("read offset: 0x%08x\n", decoder->read_ptr - decoder->read_buffer);
  126. decoder->read_offset = MP3FindSyncWord(decoder->read_ptr, decoder->bytes_left);
  127. if (decoder->read_offset < 0)
  128. {
  129. /* discard this data */
  130. rt_kprintf("outof sync\n");
  131. decoder->bytes_left = 0;
  132. return 0;
  133. }
  134. decoder->read_ptr += decoder->read_offset;
  135. delta = decoder->read_offset;
  136. decoder->bytes_left -= decoder->read_offset;
  137. if (decoder->bytes_left < 1024)
  138. {
  139. /* fill more data */
  140. if(mp3_decoder_fill_buffer(decoder) != 0)
  141. return -1;
  142. }
  143. /* get a decoder buffer */
  144. buffer = (rt_uint16_t*)sbuf_alloc();
  145. decoder->bytes_left_before_decoding = decoder->bytes_left;
  146. err = MP3Decode(decoder->decoder, &decoder->read_ptr,
  147. (int*)&decoder->bytes_left, (short*)buffer, 0);
  148. delta += (decoder->bytes_left_before_decoding - decoder->bytes_left);
  149. current_offset += delta;
  150. player_set_position(current_offset);
  151. // rt_kprintf("bytes left after decode: %d\n", decoder->bytes_left);
  152. decoder->frames++;
  153. if (err != ERR_MP3_NONE)
  154. {
  155. switch (err)
  156. {
  157. case ERR_MP3_INDATA_UNDERFLOW:
  158. rt_kprintf("ERR_MP3_INDATA_UNDERFLOW\n");
  159. decoder->bytes_left = 0;
  160. if(mp3_decoder_fill_buffer(decoder) != 0)
  161. {
  162. /* release this memory block */
  163. sbuf_release(buffer);
  164. return -1;
  165. }
  166. break;
  167. case ERR_MP3_MAINDATA_UNDERFLOW:
  168. /* do nothing - next call to decode will provide more mainData */
  169. rt_kprintf("ERR_MP3_MAINDATA_UNDERFLOW\n");
  170. break;
  171. default:
  172. rt_kprintf("unknown error: %d, left: %d\n", err, decoder->bytes_left);
  173. // skip this frame
  174. if (decoder->bytes_left > 0)
  175. {
  176. decoder->bytes_left --;
  177. decoder->read_ptr ++;
  178. }
  179. else
  180. {
  181. // TODO
  182. RT_ASSERT(0);
  183. }
  184. break;
  185. }
  186. /* release this memory block */
  187. sbuf_release(buffer);
  188. }
  189. else
  190. {
  191. /* no error */
  192. MP3GetLastFrameInfo(decoder->decoder, &decoder->frame_info);
  193. /* set sample rate */
  194. /* write to sound device */
  195. if (decoder->frame_info.outputSamps > 0)
  196. {
  197. rt_device_write(decoder->snd_device, 0, buffer, decoder->frame_info.outputSamps * 2);
  198. }
  199. else
  200. {
  201. /* no output */
  202. sbuf_release(buffer);
  203. }
  204. }
  205. return 0;
  206. }
  207. /* get mp3 information */
  208. void mp3_get_info(const char* filename, struct tag_info* info)
  209. {
  210. int fd;
  211. char* id3buffer;
  212. rt_size_t bytes_read;
  213. int sync_word;
  214. HMP3Decoder decoder;
  215. MP3FrameInfo frame_info;
  216. id3buffer = (char*)&mp3_fd_buffer[0];
  217. if (filename == RT_NULL || info == RT_NULL) return;
  218. fd = open(filename, O_RDONLY, 0);
  219. if (fd < 0) return; /* can't read file */
  220. /* init decoder */
  221. decoder = MP3InitDecoder();
  222. /* read data */
  223. bytes_read = read(fd, id3buffer, sizeof(mp3_fd_buffer));
  224. /* get frame information */
  225. sync_word = MP3FindSyncWord(id3buffer, bytes_read);
  226. if (sync_word < 0)
  227. {
  228. /* can't get sync word */
  229. close(fd);
  230. mp3_decoder_detach(decoder);
  231. }
  232. /* get frame information */
  233. MP3GetNextFrameInfo(decoder, &frame_info, &id3buffer[sync_word]);
  234. info->bit_rate = frame_info.bitrate;
  235. info->sampling = frame_info.samprate;
  236. info->duration = lseek(fd, 0, SEEK_END)/ (info->bit_rate / 8); /* second */
  237. if (strncmp("ID3", id3buffer, 4) == 0)
  238. {
  239. rt_uint32_t tag_size, frame_size, i;
  240. rt_uint8_t version_major;
  241. int frame_header_size;
  242. tag_size = ((rt_uint32_t)id3buffer[6] << 21)|((rt_uint32_t)id3buffer[7] << 14)|((rt_uint16_t)id3buffer[8] << 7)|id3buffer[9];
  243. info->data_start = tag_size;
  244. version_major = id3buffer[3];
  245. if (version_major >= 3)
  246. {
  247. frame_header_size = 10;
  248. }
  249. else
  250. {
  251. frame_header_size = 6;
  252. }
  253. i = 10;
  254. // iterate through frames
  255. while (i < MIN(tag_size, sizeof(id3buffer)))
  256. {
  257. if (version_major >= 3)
  258. {
  259. frame_size = ((rt_uint32_t)id3buffer[i + 4] << 24)|((rt_uint32_t)id3buffer[i + 5] << 16)|((rt_uint16_t)id3buffer[i + 6] << 8)|id3buffer[i + 7];
  260. }
  261. else
  262. {
  263. frame_size = ((rt_uint32_t)id3buffer[i + 3] << 14)|((rt_uint16_t)id3buffer[i + 4] << 7)|id3buffer[i + 5];
  264. }
  265. if (strncmp("TT2", id3buffer + i, 3) == 0 || strncmp("TIT2", id3buffer + i, 4) == 0)
  266. {
  267. strncpy(info->title, id3buffer + i + frame_header_size + 1, MIN(frame_size - 1, sizeof(info->title) - 1));
  268. }
  269. else if (strncmp("TP1", id3buffer + i, 3) == 0 || strncmp("TPE1", id3buffer + i, 4) == 0)
  270. {
  271. strncpy(info->artist, id3buffer + i + frame_header_size + 1, MIN(frame_size - 1, sizeof(info->artist) - 1));
  272. }
  273. i += frame_size + frame_header_size;
  274. }
  275. }
  276. else
  277. {
  278. lseek(fd, -128, SEEK_END);
  279. bytes_read = read(fd, id3buffer, 128);
  280. /* ID3v1 */
  281. if (strncmp("TAG", id3buffer, 3) == 0)
  282. {
  283. strncpy(info->title, id3buffer + 3, MIN(30, sizeof(info->title) - 1));
  284. strncpy(info->artist, id3buffer + 3 + 30, MIN(30, sizeof(info->artist) - 1));
  285. }
  286. /* set data start position */
  287. info->data_start = 0;
  288. }
  289. /* set current position */
  290. info->position = 0;
  291. /* release mp3 decoder */
  292. MP3FreeDecoder(decoder);
  293. /* close file */
  294. close(fd);
  295. }
  296. #include <finsh.h>
  297. rt_size_t fd_fetch(void* parameter, rt_uint8_t *buffer, rt_size_t length)
  298. {
  299. int fd = (int)parameter;
  300. return read(fd, (char*)buffer, length);
  301. }
  302. void mp3(char* filename)
  303. {
  304. int fd;
  305. struct mp3_decoder* decoder;
  306. extern rt_bool_t is_playing;
  307. is_playing = RT_TRUE;
  308. fd = open(filename, O_RDONLY, 0);
  309. if (fd >= 0)
  310. {
  311. decoder = mp3_decoder_create();
  312. if (decoder != RT_NULL)
  313. {
  314. decoder->fetch_data = fd_fetch;
  315. decoder->fetch_parameter = (void*)fd;
  316. current_offset = 0;
  317. while (mp3_decoder_run(decoder) != -1);
  318. /* delete decoder object */
  319. mp3_decoder_delete(decoder);
  320. }
  321. close(fd);
  322. }
  323. is_playing = RT_FALSE;
  324. }
  325. FINSH_FUNCTION_EXPORT(mp3, mp3 decode test);
  326. #if STM32_EXT_SRAM
  327. /* http mp3 */
  328. #include "http.h"
  329. static rt_size_t http_fetch(rt_uint8_t* ptr, rt_size_t len, void* parameter)
  330. {
  331. struct http_session* session = (struct http_session*)parameter;
  332. RT_ASSERT(session != RT_NULL);
  333. return http_session_read(session, ptr, len);
  334. }
  335. static void http_close(void* parameter)
  336. {
  337. struct http_session* session = (struct http_session*)parameter;
  338. RT_ASSERT(session != RT_NULL);
  339. http_session_close(session);
  340. }
  341. rt_size_t http_data_fetch(void* parameter, rt_uint8_t *buffer, rt_size_t length)
  342. {
  343. return net_buf_read(buffer, length);
  344. }
  345. void http_mp3(char* url)
  346. {
  347. struct http_session* session;
  348. struct mp3_decoder* decoder;
  349. extern rt_bool_t is_playing;
  350. is_playing = RT_TRUE;
  351. session = http_session_open(url);
  352. if (session != RT_NULL)
  353. {
  354. /* add a job to netbuf worker */
  355. net_buf_add_job(http_fetch, http_close, (void*)session);
  356. decoder = mp3_decoder_create();
  357. if (decoder != RT_NULL)
  358. {
  359. decoder->fetch_data = http_data_fetch;
  360. decoder->fetch_parameter = RT_NULL;
  361. current_offset = 0;
  362. while (mp3_decoder_run(decoder) != -1);
  363. /* delete decoder object */
  364. mp3_decoder_delete(decoder);
  365. }
  366. session = RT_NULL;
  367. }
  368. }
  369. FINSH_FUNCTION_EXPORT(http_mp3, http mp3 decode test);
  370. /* http mp3 */
  371. #include "http.h"
  372. static rt_size_t ice_fetch(rt_uint8_t* ptr, rt_size_t len, void* parameter)
  373. {
  374. struct shoutcast_session* session = (struct shoutcast_session*)parameter;
  375. RT_ASSERT(session != RT_NULL);
  376. return shoutcast_session_read(session, ptr, len);
  377. }
  378. static void ice_close(void* parameter)
  379. {
  380. struct shoutcast_session* session = (struct shoutcast_session*)parameter;
  381. RT_ASSERT(session != RT_NULL);
  382. shoutcast_session_close(session);
  383. }
  384. rt_size_t ice_data_fetch(void* parameter, rt_uint8_t *buffer, rt_size_t length)
  385. {
  386. return net_buf_read(buffer, length);
  387. }
  388. void ice_mp3(char* url)
  389. {
  390. struct shoutcast_session* session;
  391. struct mp3_decoder* decoder;
  392. extern rt_bool_t is_playing;
  393. is_playing = RT_TRUE;
  394. session = shoutcast_session_open(url);
  395. if (session != RT_NULL)
  396. {
  397. /* add a job to netbuf worker */
  398. net_buf_add_job(ice_fetch, ice_close, (void*)session);
  399. decoder = mp3_decoder_create();
  400. if (decoder != RT_NULL)
  401. {
  402. decoder->fetch_data = ice_data_fetch;
  403. decoder->fetch_parameter = RT_NULL;
  404. current_offset = 0;
  405. while (mp3_decoder_run(decoder) != -1);
  406. /* delete decoder object */
  407. mp3_decoder_delete(decoder);
  408. }
  409. session = RT_NULL;
  410. }
  411. }
  412. FINSH_FUNCTION_EXPORT(ice_mp3, shoutcast mp3 decode test);
  413. char ice_url[] = "http://192.168.1.5:8000/stream";
  414. void ice()
  415. {
  416. rt_thread_t tid;
  417. tid = rt_thread_create("ice", ice_mp3, (void*)ice_url,
  418. 4096, 0x08, 5);
  419. if (tid != RT_NULL) rt_thread_startup(tid);
  420. }
  421. FINSH_FUNCTION_EXPORT(ice, shoutcast thread test);
  422. #endif