blob: 3dd3994e4533045c8801991be3c48d196493bde1 [file] [log] [blame]
Bo Lv72d0e902023-01-02 14:27:34 +00001/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
2/*
3 * Copyright (c) 2019 Amlogic, Inc. All rights reserved.
4 */
5
6#ifndef __MESON_SARADC_H__
7#define __MESON_SARADC_H__
8
9#include <common.h>
10#include <adc.h>
11#include <clk.h>
12
13enum ADC_CHANNEL_TYPE {
14 MESON_SARADC_CH0 = 0,
15 MESON_SARADC_CH1,
16 MESON_SARADC_CH2,
17 MESON_SARADC_CH3,
18 MESON_SARADC_CH4,
19 MESON_SARADC_CH5,
20 MESON_SARADC_CH6,
21 MESON_SARADC_CH7,
22 MESON_SARADC_CH_MAX,
23};
24
25enum MESON_SARADC_AVG_MODE {
26 NO_AVERAGING = 0x0,
27 MEAN_AVERAGING = 0x1,
28 MEDIAN_AVERAGING = 0x2,
29};
30
31enum MESON_SARADC_NUM_SAMPLES {
32 ONE_SAMPLE = 0x0,
33 TWO_SAMPLES = 0x1,
34 FOUR_SAMPLES = 0x2,
35 EIGHT_SAMPLES = 0x3,
36};
37
38enum MESON_SARADC_RESOLUTION {
39 SARADC_10BIT = 10,
40 SARADC_12BIT = 12,
41 SARADC_22BIT = 22,
42};
43
44enum MESON_SARADC_BIT_STATE {
45 BIT_LOW = 0,
46 BIT_HIGH = 1,
47};
48
49struct meson_saradc;
50
51struct meson_saradc_diff_ops {
52 void (*extra_init)(struct meson_saradc *priv);
53 void (*set_ch7_mux)(struct meson_saradc *priv, int ch, int mux);
54 void (*enable_decim_filter)(struct meson_saradc *priv,
55 int ch, unsigned int mode);
56 void (*set_ref_voltage)(struct meson_saradc *priv, unsigned int mode,
57 int ch);
58 int (*get_fifo_channel)(int val);
59 int (*get_fifo_data)(struct meson_saradc *priv,
Huqiang Qin7a5665f2023-02-23 13:39:10 +080060 struct adc_uclass_plat *uc_pdata, int val);
Bo Lv72d0e902023-01-02 14:27:34 +000061};
62
63/*
64 * struct meson_saradc_data - describe the differences of different platform
65 *
66 * @reg3_ring_counter_disable: to disable continuous ring counter.
67 * gxl and later: 1; others(gxtvbb etc): 0
Huqiang Qina11c2302023-08-03 13:17:55 +080068 * @reg11_bandgap_en_mask: txhd2/s1a: bit[12]; g12a: bit[13]
Bo Lv72d0e902023-01-02 14:27:34 +000069 * @reg11_vref_en: g12a and later: 0; others(axg etc): 1
Huqiang Qinb3b003c2023-07-06 17:22:05 +080070 * @reg11_vcm_sel: g12a and later: 0; others(axg etc): 1
Huqiang Qina11c2302023-08-03 13:17:55 +080071 * @reg11_eoc: g12a and later: 1; others(axg etc): 0; txhd2/s1a: 0
72 * @reg13_calib_factor_mask: txhd2/s1a: bit[22:16]; g12a: bit[13:8]
Bo Lv72d0e902023-01-02 14:27:34 +000073 * @has_bl30_integration:
74 * @update_vref_conf: only for C2 & A5; C2: 0; A5: 1
75 * @num_channels: the number of adc channels
76 * @self_test_channel: channel of self-test
77 * @resolution: gxl and later: 12bit; others(gxtvbb etc): 10bit
78 * @clock_rate: saradc clock rate
79 */
80struct meson_saradc_data {
81 bool reg3_ring_counter_disable;
Huqiang Qina11c2302023-08-03 13:17:55 +080082 unsigned int reg11_bandgap_en_mask;
Bo Lv72d0e902023-01-02 14:27:34 +000083 bool reg11_vref_en;
Huqiang Qinb3b003c2023-07-06 17:22:05 +080084 bool reg11_vcm_sel;
Bo Lv72d0e902023-01-02 14:27:34 +000085 bool reg11_eoc;
Huqiang Qina11c2302023-08-03 13:17:55 +080086 unsigned int reg13_calib_factor_mask;
Bo Lv72d0e902023-01-02 14:27:34 +000087 bool has_bl30_integration;
88 bool update_vref_conf;
89 unsigned char self_test_channel;
90 unsigned char num_channels;
91 unsigned int resolution;
92 const struct meson_saradc_diff_ops *dops;
93 unsigned int capacity;
94 unsigned long clock_rate;
95};
96
97struct meson_saradc {
98 phys_addr_t base;
99 int active_channel;
100 unsigned int current_mode;
101 struct clk xtal;
102 struct clk adc_mux;
103 struct clk adc_div;
104 struct clk adc_gate;
105 struct meson_saradc_data *data;
106};
107
108extern const struct adc_ops meson_saradc_ops;
109int meson_saradc_probe(struct udevice *dev);
110int meson_saradc_remove(struct udevice *dev);
Huqiang Qin7a5665f2023-02-23 13:39:10 +0800111int meson_saradc_of_to_plat(struct udevice *dev);
Bo Lv72d0e902023-01-02 14:27:34 +0000112
113#define SARADC_CH_SELF_TEST MESON_SARADC_CH7
114
115#endif /*_MESON_SARADC_H_*/