common.c 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. /*
  2. * Copyright (c) 2019-2025 Allwinner Technology Co., Ltd. ALL rights reserved.
  3. *
  4. * Allwinner is a trademark of Allwinner Technology Co.,Ltd., registered in
  5. * the the people's Republic of China and other countries.
  6. * All Allwinner Technology Co.,Ltd. trademarks are used with permission.
  7. *
  8. * DISCLAIMER
  9. * THIRD PARTY LICENCES MAY BE REQUIRED TO IMPLEMENT THE SOLUTION/PRODUCT.
  10. * IF YOU NEED TO INTEGRATE THIRD PARTY’S TECHNOLOGY (SONY, DTS, DOLBY, AVS OR MPEGLA, ETC.)
  11. * IN ALLWINNERS’SDK OR PRODUCTS, YOU SHALL BE SOLELY RESPONSIBLE TO OBTAIN
  12. * ALL APPROPRIATELY REQUIRED THIRD PARTY LICENCES.
  13. * ALLWINNER SHALL HAVE NO WARRANTY, INDEMNITY OR OTHER OBLIGATIONS WITH RESPECT TO MATTERS
  14. * COVERED UNDER ANY REQUIRED THIRD PARTY LICENSE.
  15. * YOU ARE SOLELY RESPONSIBLE FOR YOUR USAGE OF THIRD PARTY’S TECHNOLOGY.
  16. *
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY ALLWINNER"AS IS" AND TO THE MAXIMUM EXTENT
  19. * PERMITTED BY LAW, ALLWINNER EXPRESSLY DISCLAIMS ALL WARRANTIES OF ANY KIND,
  20. * WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING WITHOUT LIMITATION REGARDING
  21. * THE TITLE, NON-INFRINGEMENT, ACCURACY, CONDITION, COMPLETENESS, PERFORMANCE
  22. * OR MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  23. * IN NO EVENT SHALL ALLWINNER BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  24. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  25. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  26. * LOSS OF USE, DATA, OR PROFITS, OR BUSINESS INTERRUPTION)
  27. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  28. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  29. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  30. * OF THE POSSIBILITY OF SUCH DAMAGE.
  31. */
  32. #include <stdio.h>
  33. #include <string.h>
  34. #include <unistd.h>
  35. #include <stdlib.h>
  36. //#include <FreeRTOS.h>
  37. #include <aw-alsa-lib/pcm.h>
  38. #include "common.h"
  39. #include <hal_timer.h>
  40. unsigned int g_verbose = 0;
  41. int set_param(snd_pcm_t *handle, snd_pcm_format_t format,
  42. unsigned int rate, unsigned int channels,
  43. snd_pcm_uframes_t period_size,
  44. snd_pcm_uframes_t buffer_size)
  45. {
  46. int ret = 0;
  47. snd_pcm_hw_params_t *params;
  48. snd_pcm_sw_params_t *sw_params;
  49. snd_pcm_uframes_t period_size_tmp = period_size;
  50. snd_pcm_uframes_t buffer_size_tmp = buffer_size;
  51. /* HW params */
  52. snd_pcm_hw_params_alloca(&params);
  53. ret = snd_pcm_hw_params_any(handle, params);
  54. if (ret < 0) {
  55. printf("no configurations available\n");
  56. return ret;
  57. }
  58. ret = snd_pcm_hw_params_set_access(handle, params, SND_PCM_ACCESS_RW_INTERLEAVED);
  59. if (ret < 0) {
  60. printf("failed to set access\n");
  61. return ret;
  62. }
  63. ret = snd_pcm_hw_params_set_format(handle, params, format);
  64. if (ret < 0) {
  65. printf("failed to set format\n");
  66. return ret;
  67. }
  68. ret = snd_pcm_hw_params_set_channels(handle, params, channels);
  69. if (ret < 0) {
  70. printf("failed to set channels\n");
  71. return ret;
  72. }
  73. ret = snd_pcm_hw_params_set_rate(handle, params, rate, 0);
  74. if (ret < 0) {
  75. printf("failed to set rate\n");
  76. return ret;
  77. }
  78. ret = snd_pcm_hw_params_set_period_size_near(handle, params, &period_size_tmp, NULL);
  79. if (ret < 0) {
  80. printf("failed to set period size\n");
  81. return ret;
  82. }
  83. if (period_size_tmp != period_size) {
  84. printf("period size changed (request: %lu, get: %lu)\n",
  85. period_size, period_size_tmp);
  86. period_size = period_size_tmp;
  87. }
  88. ret = snd_pcm_hw_params_set_buffer_size_near(handle, params, &buffer_size_tmp);
  89. if (ret < 0) {
  90. printf("failed to set buffer size\n");
  91. return ret;
  92. }
  93. if (buffer_size_tmp != buffer_size) {
  94. printf("buffer size changed (request: %lu, get: %lu)\n",
  95. buffer_size, buffer_size_tmp);
  96. buffer_size = buffer_size_tmp;
  97. }
  98. ret = snd_pcm_hw_params(handle, params);
  99. if (ret < 0) {
  100. printf("Unable to install hw prams! (return: %d)\n", ret);
  101. return ret;
  102. }
  103. /* SW params */
  104. snd_pcm_sw_params_alloca(&sw_params);
  105. snd_pcm_sw_params_current(handle, sw_params);
  106. if (snd_pcm_stream(handle) == SND_PCM_STREAM_CAPTURE) {
  107. snd_pcm_sw_params_set_start_threshold(handle, sw_params, 1);
  108. } else {
  109. snd_pcm_uframes_t boundary = 0;
  110. snd_pcm_sw_params_get_boundary(sw_params, &boundary);
  111. snd_pcm_sw_params_set_start_threshold(handle, sw_params, buffer_size);
  112. /* set silence size, in order to fill silence data into ringbuffer */
  113. snd_pcm_sw_params_set_silence_size(handle, sw_params, boundary);
  114. }
  115. snd_pcm_sw_params_set_stop_threshold(handle, sw_params, buffer_size);
  116. snd_pcm_sw_params_set_avail_min(handle, sw_params, period_size);
  117. ret = snd_pcm_sw_params(handle ,sw_params);
  118. if (ret < 0) {
  119. printf("Unable to install sw prams!\n");
  120. return ret;
  121. }
  122. if (g_verbose)
  123. snd_pcm_dump(handle);
  124. return ret;
  125. }
  126. void xrun(snd_pcm_t *handle)
  127. {
  128. int ret;
  129. printf("Xrun...\n");
  130. ret = snd_pcm_prepare(handle);
  131. if (ret < 0) {
  132. printf("prepare failed in xrun. return %d\n", ret);
  133. }
  134. }
  135. void do_pause(snd_pcm_t *handle)
  136. {
  137. int ret = 0;
  138. printf("[%s] line:%d pause start...\n", __func__, __LINE__);
  139. ret = snd_pcm_pause(handle, 1);
  140. if (ret < 0)
  141. printf("pause failed!, return %d\n", ret);
  142. hal_sleep(5);
  143. ret = snd_pcm_pause(handle, 0);
  144. if (ret < 0)
  145. printf("pause release failed!, return %d\n", ret);
  146. printf("[%s] line:%d pause end...\n", __func__, __LINE__);
  147. }
  148. void do_other_test(snd_pcm_t *handle)
  149. {
  150. do_pause(handle);
  151. return;
  152. }
  153. audio_mgr_t *audio_mgr_create(void)
  154. {
  155. audio_mgr_t *audio_mgr = NULL;
  156. audio_mgr = malloc(sizeof(audio_mgr_t));
  157. if (!audio_mgr) {
  158. printf("no memory\n");
  159. return NULL;
  160. }
  161. memset(audio_mgr, 0, sizeof(audio_mgr_t));
  162. audio_mgr->format = SND_PCM_FORMAT_S16_LE;
  163. audio_mgr->rate = 16000;
  164. audio_mgr->channels = 2;
  165. audio_mgr->period_size = 1024;
  166. audio_mgr->buffer_size = 4096;
  167. return audio_mgr;
  168. }
  169. void audio_mgr_release(audio_mgr_t *mgr)
  170. {
  171. if (!mgr) {
  172. printf("%s: mgr null !\n", __func__);
  173. return;
  174. }
  175. free(mgr);
  176. }