drv_adc.h 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /*
  2. * Copyright (c) 2006-2024, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2024/02/22 flyingcys first version
  9. */
  10. #ifndef __DRV_ADC_H__
  11. #define __DRV_ADC_H__
  12. #include "pinctrl.h"
  13. #include "mmio.h"
  14. #define SARADC_BASE 0x030F0000
  15. #define SARADC_CH_MAX 3
  16. #define SARADC_CTRL_OFFSET 0x04
  17. #define SARADC_CTRL_START (1 << 0)
  18. #define SARADC_CTRL_SEL_POS 0x04
  19. #define SARADC_STATUS_OFFSET 0x08
  20. #define SARADC_STATUS_BUSY (1 << 0)
  21. #define SARADC_CYC_SET_OFFSET 0x0C
  22. #define SARADC_CYC_CLKDIV_DIV_POS (12U)
  23. #define SARADC_CYC_CLKDIV_DIV_MASK (0xF << SARADC_CYC_CLKDIV_DIV_POS)
  24. #define SARADC_CYC_CLKDIV_DIV_1 (0U<< SARADC_CYC_CLKDIV_DIV_POS)
  25. #define SARADC_CYC_CLKDIV_DIV_2 (1U<< SARADC_CYC_CLKDIV_DIV_POS)
  26. #define SARADC_CYC_CLKDIV_DIV_3 (2U<< SARADC_CYC_CLKDIV_DIV_POS)
  27. #define SARADC_CYC_CLKDIV_DIV_4 (3U<< SARADC_CYC_CLKDIV_DIV_POS)
  28. #define SARADC_CYC_CLKDIV_DIV_5 (4U<< SARADC_CYC_CLKDIV_DIV_POS)
  29. #define SARADC_CYC_CLKDIV_DIV_6 (5U<< SARADC_CYC_CLKDIV_DIV_POS)
  30. #define SARADC_CYC_CLKDIV_DIV_7 (6U<< SARADC_CYC_CLKDIV_DIV_POS)
  31. #define SARADC_CYC_CLKDIV_DIV_8 (7U<< SARADC_CYC_CLKDIV_DIV_POS)
  32. #define SARADC_CYC_CLKDIV_DIV_9 (8U<< SARADC_CYC_CLKDIV_DIV_POS)
  33. #define SARADC_CYC_CLKDIV_DIV_10 (9U<< SARADC_CYC_CLKDIV_DIV_POS)
  34. #define SARADC_CYC_CLKDIV_DIV_11 (10U<< SARADC_CYC_CLKDIV_DIV_POS)
  35. #define SARADC_CYC_CLKDIV_DIV_12 (11U<< SARADC_CYC_CLKDIV_DIV_POS)
  36. #define SARADC_CYC_CLKDIV_DIV_13 (12U<< SARADC_CYC_CLKDIV_DIV_POS)
  37. #define SARADC_CYC_CLKDIV_DIV_14 (13U<< SARADC_CYC_CLKDIV_DIV_POS)
  38. #define SARADC_CYC_CLKDIV_DIV_15 (14U<< SARADC_CYC_CLKDIV_DIV_POS)
  39. #define SARADC_CYC_CLKDIV_DIV_16 (15U<< SARADC_CYC_CLKDIV_DIV_POS)
  40. #define SARADC_RESULT_OFFSET 0x014
  41. #define SARADC_RESULT(n) (SARADC_RESULT_OFFSET + (n) * 4)
  42. #define SARADC_RESULT_MASK 0x0FFF
  43. #define SARADC_RESULT_VALID (1 << 15)
  44. rt_inline void cvi_set_saradc_ctrl(unsigned long reg_base, rt_uint32_t value)
  45. {
  46. value |= mmio_read_32(reg_base + SARADC_CTRL_OFFSET);
  47. mmio_write_32(reg_base + SARADC_CTRL_OFFSET, value);
  48. }
  49. rt_inline void cvi_reset_saradc_ctrl(unsigned long reg_base, rt_uint32_t value)
  50. {
  51. value = mmio_read_32(reg_base + SARADC_CTRL_OFFSET) & ~value;
  52. mmio_write_32(reg_base + SARADC_CTRL_OFFSET, value);
  53. }
  54. rt_inline rt_uint32_t cvi_get_saradc_status(unsigned long reg_base)
  55. {
  56. return((rt_uint32_t)mmio_read_32(reg_base + SARADC_STATUS_OFFSET));
  57. }
  58. rt_inline void cvi_set_cyc(unsigned long reg_base)
  59. {
  60. rt_uint32_t value;
  61. value = mmio_read_32(reg_base + SARADC_CYC_SET_OFFSET);
  62. value &= ~SARADC_CYC_CLKDIV_DIV_16;
  63. mmio_write_32(reg_base + SARADC_CYC_SET_OFFSET, value);
  64. value |= SARADC_CYC_CLKDIV_DIV_16; //set saradc clock cycle=840ns
  65. mmio_write_32(reg_base + SARADC_CYC_SET_OFFSET, value);
  66. }
  67. int rt_hw_adc_init(void);
  68. #endif /* __DRV_ADC_H__ */