sunxi_hal_avs.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  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. #ifndef SUNXI_HAL_AVS_H
  33. #define SUNXI_HAL_AVS_H
  34. #include "hal_interrupt.h"
  35. #include "sunxi_hal_common.h"
  36. #include <timer/platform_timer.h>
  37. #include <interrupt.h>
  38. #include <stdio.h>
  39. #include <hal_osal.h>
  40. #ifdef __cplusplus
  41. extern "C" {
  42. #endif
  43. #define CONFIG_DRIVERS_TMR_DEBUG
  44. #ifdef CONFIG_DRIVERS_TMR_DEBUG
  45. #define AVS_INFO(fmt, arg...) hal_log_info(fmt, ##arg)
  46. #else
  47. #define AVS_INFO(fmt, arg...) do {}while(0)
  48. #endif
  49. #define AVS_ERR(fmt, arg...) hal_log_err(fmt, ##arg)
  50. #define AVS_CNT_CTRL_REG (0x00C0)
  51. #define AVS_CNT_REG(n) (0x00C4 + 0x0004 * n)
  52. #define AVS_CNT_DIV_REG (0x00CC)
  53. #define AVS_DIV_MASK 0xfff
  54. typedef enum
  55. {
  56. AVS_ENABLE = 0,
  57. AVS_DISABLE,
  58. AVS_PAUSE,
  59. AVS_CONTINUE,
  60. AVS_GET_COUNTER,
  61. AVS_SET_COUNTER,
  62. AVS_SET_DIV,
  63. } hal_avs_cmd_t;
  64. typedef enum
  65. {
  66. AVS0 = 0,
  67. AVS1,
  68. AVS_NUM,
  69. } hal_avs_id_t;
  70. typedef struct
  71. {
  72. hal_avs_id_t id;
  73. unsigned long base;
  74. hal_clk_t clk;
  75. u8 enable;
  76. } hal_sunxi_avs;
  77. int hal_avs_continue(hal_avs_id_t id);
  78. int hal_avs_pause(hal_avs_id_t id);
  79. int hal_avs_disable(hal_avs_id_t id);
  80. int hal_avs_enable(hal_avs_id_t id);
  81. int hal_avs_get_counter(hal_avs_id_t id, u32 *counter);
  82. int hal_avs_set_counter(hal_avs_id_t id, u32 counter);
  83. int hal_avs_set_cnt_div(hal_avs_id_t id, u32 div);
  84. int hal_avs_init(hal_avs_id_t id);
  85. int hal_avs_uninit(hal_avs_id_t id);
  86. int hal_avs_control(hal_avs_id_t id, hal_avs_cmd_t cmd, void *arg);
  87. #ifdef __cplusplus
  88. }
  89. #endif
  90. #endif