test_dma.c 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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 <stdlib.h>
  34. #include <string.h>
  35. #include <hal_log.h>
  36. #include <hal_cmd.h>
  37. #include <hal_mem.h>
  38. #include <hal_cache.h>
  39. #include <hal_dma.h>
  40. #define DMA_TEST_LEN 1024
  41. static void dma_test_cb(void *param)
  42. {
  43. hal_log_info("DMA finished, callback to do something...\n");
  44. }
  45. int cmd_test_dma(int argc, char **argv)
  46. {
  47. int ret, i;
  48. struct sunxi_dma_chan *hdma = NULL;
  49. char *buf1 = NULL,*buf2 = NULL;
  50. struct dma_slave_config config = {0};
  51. uint32_t size = 0;
  52. hal_log_info("run in dma test");
  53. buf2 = hal_malloc(DMA_TEST_LEN);
  54. buf1 = hal_malloc(DMA_TEST_LEN);
  55. if (buf1 == NULL) {
  56. hal_log_err("malloc buf1 error!");
  57. goto end;
  58. }
  59. if (buf2 == NULL) {
  60. hal_log_err("malloc buf2 error!");
  61. goto end;
  62. }
  63. memset(buf1, 0, DMA_TEST_LEN);
  64. memset(buf2, 0, DMA_TEST_LEN);
  65. for (i = 0;i < DMA_TEST_LEN; i++)
  66. buf1[i] = i & 0xff;
  67. hal_dcache_clean_all();
  68. /* request dma chan */
  69. ret = hal_dma_chan_request(&hdma);
  70. if (ret == HAL_DMA_CHAN_STATUS_BUSY) {
  71. hal_log_err("dma channel busy!");
  72. goto end;
  73. }
  74. /* register dma callback */
  75. ret = hal_dma_callback_install(hdma, dma_test_cb, hdma);
  76. if (ret != HAL_DMA_STATUS_OK) {
  77. hal_log_err("register dma callback failed!");
  78. goto end;
  79. }
  80. config.direction = DMA_MEM_TO_MEM;
  81. config.dst_addr_width = DMA_SLAVE_BUSWIDTH_8_BYTES;
  82. config.src_addr_width = DMA_SLAVE_BUSWIDTH_8_BYTES;
  83. config.dst_maxburst = DMA_SLAVE_BURST_16;
  84. config.src_maxburst = DMA_SLAVE_BURST_16;
  85. config.slave_id = sunxi_slave_id(DRQDST_SDRAM, DRQSRC_SDRAM);
  86. ret = hal_dma_slave_config(hdma, &config);
  87. if (ret != HAL_DMA_STATUS_OK) {
  88. hal_log_err("dma config error, ret:%d", ret);
  89. goto end;
  90. }
  91. ret = hal_dma_prep_memcpy(hdma, (uint32_t)buf2, (uint32_t)buf1, DMA_TEST_LEN);
  92. if (ret != HAL_DMA_STATUS_OK) {
  93. hal_log_err("dma prep error, ret:%d", ret);
  94. goto end;
  95. }
  96. ret = hal_dma_start(hdma);
  97. if (ret != HAL_DMA_STATUS_OK) {
  98. hal_log_err("dma start error, ret:%d", ret);
  99. goto end;
  100. }
  101. while (hal_dma_tx_status(hdma, &size)!= 0);
  102. ret = hal_dma_stop(hdma);
  103. if (ret != HAL_DMA_STATUS_OK) {
  104. hal_log_err("dma stop error, ret:%d", ret);
  105. goto end;
  106. }
  107. ret = hal_dma_chan_free(hdma);
  108. if (ret != HAL_DMA_STATUS_OK) {
  109. hal_log_err("dma free error, ret:%d", ret);
  110. goto end;
  111. }
  112. hal_dcache_invalidate_all();
  113. hal_log_info("src buf:\n");
  114. for (i = 0;i < DMA_TEST_LEN; i++)
  115. printf("0x%x ", buf1[i]);
  116. hal_log_info("dst buf:\n");
  117. for (i = 0;i < DMA_TEST_LEN; i++)
  118. printf("0x%x ", buf2[i]);
  119. end:
  120. hal_free(buf1);
  121. hal_free(buf2);
  122. return 0;
  123. }
  124. MSH_CMD_EXPORT_ALIAS(cmd_test_dma, hal_dma, dma hal APIs tests)