|
@@ -48,6 +48,11 @@
|
|
#define SARADC_RESULT_MASK 0x0FFF
|
|
#define SARADC_RESULT_MASK 0x0FFF
|
|
#define SARADC_RESULT_VALID (1 << 15)
|
|
#define SARADC_RESULT_VALID (1 << 15)
|
|
|
|
|
|
|
|
+#define SARADC_TEST_OFFSET 0x030
|
|
|
|
+#define SARADC_TEST_VREFSEL_BIT 2
|
|
|
|
+
|
|
|
|
+#define SARADC_TRIM_OFFSET 0x034
|
|
|
|
+
|
|
rt_inline void cvi_set_saradc_ctrl(unsigned long reg_base, rt_uint32_t value)
|
|
rt_inline void cvi_set_saradc_ctrl(unsigned long reg_base, rt_uint32_t value)
|
|
{
|
|
{
|
|
value |= mmio_read_32(reg_base + SARADC_CTRL_OFFSET);
|
|
value |= mmio_read_32(reg_base + SARADC_CTRL_OFFSET);
|
|
@@ -78,6 +83,19 @@ rt_inline void cvi_set_cyc(unsigned long reg_base)
|
|
mmio_write_32(reg_base + SARADC_CYC_SET_OFFSET, value);
|
|
mmio_write_32(reg_base + SARADC_CYC_SET_OFFSET, value);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+rt_inline void cvi_do_calibration(unsigned long reg_base)
|
|
|
|
+{
|
|
|
|
+ rt_uint32_t val;
|
|
|
|
+
|
|
|
|
+ val = mmio_read_32(reg_base + SARADC_TEST_OFFSET);
|
|
|
|
+ val |= 1 << SARADC_TEST_VREFSEL_BIT;
|
|
|
|
+ mmio_write_32(reg_base + SARADC_TEST_OFFSET, val);
|
|
|
|
+
|
|
|
|
+ val = mmio_read_32(reg_base + SARADC_TRIM_OFFSET);
|
|
|
|
+ val |= 0x4;
|
|
|
|
+ mmio_write_32(reg_base + SARADC_TRIM_OFFSET, val);
|
|
|
|
+}
|
|
|
|
+
|
|
int rt_hw_adc_init(void);
|
|
int rt_hw_adc_init(void);
|
|
|
|
|
|
#endif /* __DRV_ADC_H__ */
|
|
#endif /* __DRV_ADC_H__ */
|