audio_test.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /**************************************************************************//**
  2. *
  3. * @copyright (C) 2019 Nuvoton Technology Corp. All rights reserved.
  4. *
  5. * SPDX-License-Identifier: Apache-2.0
  6. *
  7. * Change Logs:
  8. * Date Author Notes
  9. * 2020-1-16 Wayne First version
  10. *
  11. ******************************************************************************/
  12. #include <rtconfig.h>
  13. #if defined(PKG_USING_WAVPLAYER)
  14. #include "wavrecorder.h"
  15. #include "wavplayer.h"
  16. #include "dfs_posix.h"
  17. /*
  18. The routine just for test automatically.
  19. - For record function: Run it w/o parameter.
  20. - For replay function: Run it with parameter.
  21. */
  22. static int audio_test(int argc, char **argv)
  23. {
  24. #define DEF_MAX_ARGV_NUM 8
  25. #define DEF_MAX_TEST_SECOND 5
  26. int smplrate[] = {8000, 16000, 44100, 48000};
  27. int smplbit[] = {16};
  28. int chnum[] = {1, 2};
  29. struct wavrecord_info info;
  30. char strbuf[128];
  31. int i, j, k;
  32. int bDoRecording = 1;
  33. struct stat stat_buf;
  34. if (argc > 1)
  35. bDoRecording = 0;
  36. for (i = 0; i < sizeof(smplrate) / sizeof(int); i++)
  37. {
  38. for (j = 0; j < sizeof(smplbit) / sizeof(int); j++)
  39. {
  40. for (k = 0; k < sizeof(chnum) / sizeof(int); k++)
  41. {
  42. snprintf(strbuf, sizeof(strbuf), "/mnt/sd0/%d_%d_%d.wav", smplrate[i], smplbit[j], chnum[k]);
  43. if (bDoRecording)
  44. {
  45. rt_kprintf("Recording file at %s\n", strbuf);
  46. info.uri = strbuf;
  47. info.samplerate = smplrate[i];
  48. info.samplebits = smplbit[j];
  49. info.channels = chnum[k];
  50. wavrecorder_start(&info);
  51. rt_thread_mdelay(DEF_MAX_TEST_SECOND * 1000);
  52. wavrecorder_stop();
  53. rt_thread_mdelay(DEF_MAX_TEST_SECOND * 1000);
  54. }
  55. else
  56. {
  57. if (stat((const char *)strbuf, &stat_buf) < 0)
  58. {
  59. rt_kprintf("%s non-exist.\n", strbuf);
  60. continue;
  61. }
  62. rt_kprintf("Replay file at %s\n", strbuf);
  63. wavplayer_play(strbuf);
  64. rt_thread_mdelay(DEF_MAX_TEST_SECOND * 1000);
  65. wavplayer_stop();
  66. }
  67. } // k
  68. } // j
  69. } // i
  70. return 0;
  71. }
  72. #ifdef FINSH_USING_MSH
  73. MSH_CMD_EXPORT(audio_test, Audio record / replay);
  74. #endif
  75. static int audio_overnight(int argc, char **argv)
  76. {
  77. #define DEF_MAX_TEST_SECOND 5
  78. struct wavrecord_info info;
  79. char strbuf[128];
  80. struct stat stat_buf;
  81. snprintf(strbuf, sizeof(strbuf), "/test.wav");
  82. while (1)
  83. {
  84. rt_kprintf("Recording file at %s\n", strbuf);
  85. info.uri = strbuf;
  86. info.samplerate = 16000;
  87. info.samplebits = 16;
  88. info.channels = 2;
  89. wavrecorder_start(&info);
  90. rt_thread_mdelay(DEF_MAX_TEST_SECOND * 1000);
  91. wavrecorder_stop();
  92. rt_thread_mdelay(1000);
  93. if (stat((const char *)strbuf, &stat_buf) < 0)
  94. {
  95. rt_kprintf("%s non-exist.\n", strbuf);
  96. break;
  97. }
  98. rt_kprintf("Replay file at %s\n", strbuf);
  99. wavplayer_play(strbuf);
  100. rt_thread_mdelay(DEF_MAX_TEST_SECOND * 1000);
  101. wavplayer_stop();
  102. rt_thread_mdelay(1000);
  103. }
  104. return 0;
  105. }
  106. #ifdef FINSH_USING_MSH
  107. MSH_CMD_EXPORT(audio_overnight, auto test record / replay);
  108. #endif
  109. #endif /* PKG_USING_WAVPLAYER */