meson_saradc.c 40 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Amlogic Meson Successive Approximation Register (SAR) A/D Converter
  4. *
  5. * Copyright (C) 2017 Martin Blumenstingl <[email protected]>
  6. */
  7. #include <linux/bitfield.h>
  8. #include <linux/clk.h>
  9. #include <linux/clk-provider.h>
  10. #include <linux/delay.h>
  11. #include <linux/io.h>
  12. #include <linux/iio/iio.h>
  13. #include <linux/module.h>
  14. #include <linux/nvmem-consumer.h>
  15. #include <linux/interrupt.h>
  16. #include <linux/of.h>
  17. #include <linux/of_irq.h>
  18. #include <linux/of_device.h>
  19. #include <linux/platform_device.h>
  20. #include <linux/regmap.h>
  21. #include <linux/regulator/consumer.h>
  22. #include <linux/mfd/syscon.h>
  23. #define MESON_SAR_ADC_REG0 0x00
  24. #define MESON_SAR_ADC_REG0_PANEL_DETECT BIT(31)
  25. #define MESON_SAR_ADC_REG0_BUSY_MASK GENMASK(30, 28)
  26. #define MESON_SAR_ADC_REG0_DELTA_BUSY BIT(30)
  27. #define MESON_SAR_ADC_REG0_AVG_BUSY BIT(29)
  28. #define MESON_SAR_ADC_REG0_SAMPLE_BUSY BIT(28)
  29. #define MESON_SAR_ADC_REG0_FIFO_FULL BIT(27)
  30. #define MESON_SAR_ADC_REG0_FIFO_EMPTY BIT(26)
  31. #define MESON_SAR_ADC_REG0_FIFO_COUNT_MASK GENMASK(25, 21)
  32. #define MESON_SAR_ADC_REG0_ADC_BIAS_CTRL_MASK GENMASK(20, 19)
  33. #define MESON_SAR_ADC_REG0_CURR_CHAN_ID_MASK GENMASK(18, 16)
  34. #define MESON_SAR_ADC_REG0_ADC_TEMP_SEN_SEL BIT(15)
  35. #define MESON_SAR_ADC_REG0_SAMPLING_STOP BIT(14)
  36. #define MESON_SAR_ADC_REG0_CHAN_DELTA_EN_MASK GENMASK(13, 12)
  37. #define MESON_SAR_ADC_REG0_DETECT_IRQ_POL BIT(10)
  38. #define MESON_SAR_ADC_REG0_DETECT_IRQ_EN BIT(9)
  39. #define MESON_SAR_ADC_REG0_FIFO_CNT_IRQ_MASK GENMASK(8, 4)
  40. #define MESON_SAR_ADC_REG0_FIFO_IRQ_EN BIT(3)
  41. #define MESON_SAR_ADC_REG0_SAMPLING_START BIT(2)
  42. #define MESON_SAR_ADC_REG0_CONTINUOUS_EN BIT(1)
  43. #define MESON_SAR_ADC_REG0_SAMPLE_ENGINE_ENABLE BIT(0)
  44. #define MESON_SAR_ADC_CHAN_LIST 0x04
  45. #define MESON_SAR_ADC_CHAN_LIST_MAX_INDEX_MASK GENMASK(26, 24)
  46. #define MESON_SAR_ADC_CHAN_LIST_ENTRY_MASK(_chan) \
  47. (GENMASK(2, 0) << ((_chan) * 3))
  48. #define MESON_SAR_ADC_AVG_CNTL 0x08
  49. #define MESON_SAR_ADC_AVG_CNTL_AVG_MODE_SHIFT(_chan) \
  50. (16 + ((_chan) * 2))
  51. #define MESON_SAR_ADC_AVG_CNTL_AVG_MODE_MASK(_chan) \
  52. (GENMASK(17, 16) << ((_chan) * 2))
  53. #define MESON_SAR_ADC_AVG_CNTL_NUM_SAMPLES_SHIFT(_chan) \
  54. (0 + ((_chan) * 2))
  55. #define MESON_SAR_ADC_AVG_CNTL_NUM_SAMPLES_MASK(_chan) \
  56. (GENMASK(1, 0) << ((_chan) * 2))
  57. #define MESON_SAR_ADC_REG3 0x0c
  58. #define MESON_SAR_ADC_REG3_CNTL_USE_SC_DLY BIT(31)
  59. #define MESON_SAR_ADC_REG3_CLK_EN BIT(30)
  60. #define MESON_SAR_ADC_REG3_BL30_INITIALIZED BIT(28)
  61. #define MESON_SAR_ADC_REG3_CTRL_CONT_RING_COUNTER_EN BIT(27)
  62. #define MESON_SAR_ADC_REG3_CTRL_SAMPLING_CLOCK_PHASE BIT(26)
  63. #define MESON_SAR_ADC_REG3_CTRL_CHAN7_MUX_SEL_MASK GENMASK(25, 23)
  64. #define MESON_SAR_ADC_REG3_DETECT_EN BIT(22)
  65. #define MESON_SAR_ADC_REG3_ADC_EN BIT(21)
  66. #define MESON_SAR_ADC_REG3_PANEL_DETECT_COUNT_MASK GENMASK(20, 18)
  67. #define MESON_SAR_ADC_REG3_PANEL_DETECT_FILTER_TB_MASK GENMASK(17, 16)
  68. #define MESON_SAR_ADC_REG3_ADC_CLK_DIV_SHIFT 10
  69. #define MESON_SAR_ADC_REG3_ADC_CLK_DIV_WIDTH 6
  70. #define MESON_SAR_ADC_REG3_BLOCK_DLY_SEL_MASK GENMASK(9, 8)
  71. #define MESON_SAR_ADC_REG3_BLOCK_DLY_MASK GENMASK(7, 0)
  72. #define MESON_SAR_ADC_DELAY 0x10
  73. #define MESON_SAR_ADC_DELAY_INPUT_DLY_SEL_MASK GENMASK(25, 24)
  74. #define MESON_SAR_ADC_DELAY_BL30_BUSY BIT(15)
  75. #define MESON_SAR_ADC_DELAY_KERNEL_BUSY BIT(14)
  76. #define MESON_SAR_ADC_DELAY_INPUT_DLY_CNT_MASK GENMASK(23, 16)
  77. #define MESON_SAR_ADC_DELAY_SAMPLE_DLY_SEL_MASK GENMASK(9, 8)
  78. #define MESON_SAR_ADC_DELAY_SAMPLE_DLY_CNT_MASK GENMASK(7, 0)
  79. #define MESON_SAR_ADC_LAST_RD 0x14
  80. #define MESON_SAR_ADC_LAST_RD_LAST_CHANNEL1_MASK GENMASK(23, 16)
  81. #define MESON_SAR_ADC_LAST_RD_LAST_CHANNEL0_MASK GENMASK(9, 0)
  82. #define MESON_SAR_ADC_FIFO_RD 0x18
  83. #define MESON_SAR_ADC_FIFO_RD_CHAN_ID_MASK GENMASK(14, 12)
  84. #define MESON_SAR_ADC_FIFO_RD_SAMPLE_VALUE_MASK GENMASK(11, 0)
  85. #define MESON_SAR_ADC_AUX_SW 0x1c
  86. #define MESON_SAR_ADC_AUX_SW_MUX_SEL_CHAN_SHIFT(_chan) \
  87. (8 + (((_chan) - 2) * 3))
  88. #define MESON_SAR_ADC_AUX_SW_VREF_P_MUX BIT(6)
  89. #define MESON_SAR_ADC_AUX_SW_VREF_N_MUX BIT(5)
  90. #define MESON_SAR_ADC_AUX_SW_MODE_SEL BIT(4)
  91. #define MESON_SAR_ADC_AUX_SW_YP_DRIVE_SW BIT(3)
  92. #define MESON_SAR_ADC_AUX_SW_XP_DRIVE_SW BIT(2)
  93. #define MESON_SAR_ADC_AUX_SW_YM_DRIVE_SW BIT(1)
  94. #define MESON_SAR_ADC_AUX_SW_XM_DRIVE_SW BIT(0)
  95. #define MESON_SAR_ADC_CHAN_10_SW 0x20
  96. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_MUX_SEL_MASK GENMASK(25, 23)
  97. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_VREF_P_MUX BIT(22)
  98. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_VREF_N_MUX BIT(21)
  99. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_MODE_SEL BIT(20)
  100. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_YP_DRIVE_SW BIT(19)
  101. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_XP_DRIVE_SW BIT(18)
  102. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_YM_DRIVE_SW BIT(17)
  103. #define MESON_SAR_ADC_CHAN_10_SW_CHAN1_XM_DRIVE_SW BIT(16)
  104. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_MUX_SEL_MASK GENMASK(9, 7)
  105. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_VREF_P_MUX BIT(6)
  106. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_VREF_N_MUX BIT(5)
  107. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_MODE_SEL BIT(4)
  108. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_YP_DRIVE_SW BIT(3)
  109. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_XP_DRIVE_SW BIT(2)
  110. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_YM_DRIVE_SW BIT(1)
  111. #define MESON_SAR_ADC_CHAN_10_SW_CHAN0_XM_DRIVE_SW BIT(0)
  112. #define MESON_SAR_ADC_DETECT_IDLE_SW 0x24
  113. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_SW_EN BIT(26)
  114. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_MUX_MASK GENMASK(25, 23)
  115. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_VREF_P_MUX BIT(22)
  116. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_VREF_N_MUX BIT(21)
  117. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_MODE_SEL BIT(20)
  118. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_YP_DRIVE_SW BIT(19)
  119. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_XP_DRIVE_SW BIT(18)
  120. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_YM_DRIVE_SW BIT(17)
  121. #define MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_XM_DRIVE_SW BIT(16)
  122. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_MUX_SEL_MASK GENMASK(9, 7)
  123. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_VREF_P_MUX BIT(6)
  124. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_VREF_N_MUX BIT(5)
  125. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_MODE_SEL BIT(4)
  126. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_YP_DRIVE_SW BIT(3)
  127. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_XP_DRIVE_SW BIT(2)
  128. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_YM_DRIVE_SW BIT(1)
  129. #define MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_XM_DRIVE_SW BIT(0)
  130. #define MESON_SAR_ADC_DELTA_10 0x28
  131. #define MESON_SAR_ADC_DELTA_10_TEMP_SEL BIT(27)
  132. #define MESON_SAR_ADC_DELTA_10_TS_REVE1 BIT(26)
  133. #define MESON_SAR_ADC_DELTA_10_CHAN1_DELTA_VALUE_MASK GENMASK(25, 16)
  134. #define MESON_SAR_ADC_DELTA_10_TS_REVE0 BIT(15)
  135. #define MESON_SAR_ADC_DELTA_10_TS_C_MASK GENMASK(14, 11)
  136. #define MESON_SAR_ADC_DELTA_10_TS_VBG_EN BIT(10)
  137. #define MESON_SAR_ADC_DELTA_10_CHAN0_DELTA_VALUE_MASK GENMASK(9, 0)
  138. /*
  139. * NOTE: registers from here are undocumented (the vendor Linux kernel driver
  140. * and u-boot source served as reference). These only seem to be relevant on
  141. * GXBB and newer.
  142. */
  143. #define MESON_SAR_ADC_REG11 0x2c
  144. #define MESON_SAR_ADC_REG11_BANDGAP_EN BIT(13)
  145. #define MESON_SAR_ADC_REG13 0x34
  146. #define MESON_SAR_ADC_REG13_12BIT_CALIBRATION_MASK GENMASK(13, 8)
  147. #define MESON_SAR_ADC_MAX_FIFO_SIZE 32
  148. #define MESON_SAR_ADC_TIMEOUT 100 /* ms */
  149. #define MESON_SAR_ADC_VOLTAGE_AND_TEMP_CHANNEL 6
  150. #define MESON_SAR_ADC_TEMP_OFFSET 27
  151. /* temperature sensor calibration information in eFuse */
  152. #define MESON_SAR_ADC_EFUSE_BYTES 4
  153. #define MESON_SAR_ADC_EFUSE_BYTE3_UPPER_ADC_VAL GENMASK(6, 0)
  154. #define MESON_SAR_ADC_EFUSE_BYTE3_IS_CALIBRATED BIT(7)
  155. #define MESON_HHI_DPLL_TOP_0 0x318
  156. #define MESON_HHI_DPLL_TOP_0_TSC_BIT4 BIT(9)
  157. /* for use with IIO_VAL_INT_PLUS_MICRO */
  158. #define MILLION 1000000
  159. #define MESON_SAR_ADC_CHAN(_chan) { \
  160. .type = IIO_VOLTAGE, \
  161. .indexed = 1, \
  162. .channel = _chan, \
  163. .address = _chan, \
  164. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
  165. BIT(IIO_CHAN_INFO_AVERAGE_RAW), \
  166. .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE), \
  167. .info_mask_shared_by_all = BIT(IIO_CHAN_INFO_CALIBBIAS) | \
  168. BIT(IIO_CHAN_INFO_CALIBSCALE), \
  169. .datasheet_name = "SAR_ADC_CH"#_chan, \
  170. }
  171. #define MESON_SAR_ADC_TEMP_CHAN(_chan) { \
  172. .type = IIO_TEMP, \
  173. .channel = _chan, \
  174. .address = MESON_SAR_ADC_VOLTAGE_AND_TEMP_CHANNEL, \
  175. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
  176. BIT(IIO_CHAN_INFO_AVERAGE_RAW), \
  177. .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_OFFSET) | \
  178. BIT(IIO_CHAN_INFO_SCALE), \
  179. .info_mask_shared_by_all = BIT(IIO_CHAN_INFO_CALIBBIAS) | \
  180. BIT(IIO_CHAN_INFO_CALIBSCALE), \
  181. .datasheet_name = "TEMP_SENSOR", \
  182. }
  183. static const struct iio_chan_spec meson_sar_adc_iio_channels[] = {
  184. MESON_SAR_ADC_CHAN(0),
  185. MESON_SAR_ADC_CHAN(1),
  186. MESON_SAR_ADC_CHAN(2),
  187. MESON_SAR_ADC_CHAN(3),
  188. MESON_SAR_ADC_CHAN(4),
  189. MESON_SAR_ADC_CHAN(5),
  190. MESON_SAR_ADC_CHAN(6),
  191. MESON_SAR_ADC_CHAN(7),
  192. IIO_CHAN_SOFT_TIMESTAMP(8),
  193. };
  194. static const struct iio_chan_spec meson_sar_adc_and_temp_iio_channels[] = {
  195. MESON_SAR_ADC_CHAN(0),
  196. MESON_SAR_ADC_CHAN(1),
  197. MESON_SAR_ADC_CHAN(2),
  198. MESON_SAR_ADC_CHAN(3),
  199. MESON_SAR_ADC_CHAN(4),
  200. MESON_SAR_ADC_CHAN(5),
  201. MESON_SAR_ADC_CHAN(6),
  202. MESON_SAR_ADC_CHAN(7),
  203. MESON_SAR_ADC_TEMP_CHAN(8),
  204. IIO_CHAN_SOFT_TIMESTAMP(9),
  205. };
  206. enum meson_sar_adc_avg_mode {
  207. NO_AVERAGING = 0x0,
  208. MEAN_AVERAGING = 0x1,
  209. MEDIAN_AVERAGING = 0x2,
  210. };
  211. enum meson_sar_adc_num_samples {
  212. ONE_SAMPLE = 0x0,
  213. TWO_SAMPLES = 0x1,
  214. FOUR_SAMPLES = 0x2,
  215. EIGHT_SAMPLES = 0x3,
  216. };
  217. enum meson_sar_adc_chan7_mux_sel {
  218. CHAN7_MUX_VSS = 0x0,
  219. CHAN7_MUX_VDD_DIV4 = 0x1,
  220. CHAN7_MUX_VDD_DIV2 = 0x2,
  221. CHAN7_MUX_VDD_MUL3_DIV4 = 0x3,
  222. CHAN7_MUX_VDD = 0x4,
  223. CHAN7_MUX_CH7_INPUT = 0x7,
  224. };
  225. struct meson_sar_adc_param {
  226. bool has_bl30_integration;
  227. unsigned long clock_rate;
  228. u32 bandgap_reg;
  229. unsigned int resolution;
  230. const struct regmap_config *regmap_config;
  231. u8 temperature_trimming_bits;
  232. unsigned int temperature_multiplier;
  233. unsigned int temperature_divider;
  234. };
  235. struct meson_sar_adc_data {
  236. const struct meson_sar_adc_param *param;
  237. const char *name;
  238. };
  239. struct meson_sar_adc_priv {
  240. struct regmap *regmap;
  241. struct regulator *vref;
  242. const struct meson_sar_adc_param *param;
  243. struct clk *clkin;
  244. struct clk *core_clk;
  245. struct clk *adc_sel_clk;
  246. struct clk *adc_clk;
  247. struct clk_gate clk_gate;
  248. struct clk *adc_div_clk;
  249. struct clk_divider clk_div;
  250. struct completion done;
  251. int calibbias;
  252. int calibscale;
  253. struct regmap *tsc_regmap;
  254. bool temperature_sensor_calibrated;
  255. u8 temperature_sensor_coefficient;
  256. u16 temperature_sensor_adc_val;
  257. };
  258. static const struct regmap_config meson_sar_adc_regmap_config_gxbb = {
  259. .reg_bits = 8,
  260. .val_bits = 32,
  261. .reg_stride = 4,
  262. .max_register = MESON_SAR_ADC_REG13,
  263. };
  264. static const struct regmap_config meson_sar_adc_regmap_config_meson8 = {
  265. .reg_bits = 8,
  266. .val_bits = 32,
  267. .reg_stride = 4,
  268. .max_register = MESON_SAR_ADC_DELTA_10,
  269. };
  270. static unsigned int meson_sar_adc_get_fifo_count(struct iio_dev *indio_dev)
  271. {
  272. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  273. u32 regval;
  274. regmap_read(priv->regmap, MESON_SAR_ADC_REG0, &regval);
  275. return FIELD_GET(MESON_SAR_ADC_REG0_FIFO_COUNT_MASK, regval);
  276. }
  277. static int meson_sar_adc_calib_val(struct iio_dev *indio_dev, int val)
  278. {
  279. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  280. int tmp;
  281. /* use val_calib = scale * val_raw + offset calibration function */
  282. tmp = div_s64((s64)val * priv->calibscale, MILLION) + priv->calibbias;
  283. return clamp(tmp, 0, (1 << priv->param->resolution) - 1);
  284. }
  285. static int meson_sar_adc_wait_busy_clear(struct iio_dev *indio_dev)
  286. {
  287. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  288. int val;
  289. /*
  290. * NOTE: we need a small delay before reading the status, otherwise
  291. * the sample engine may not have started internally (which would
  292. * seem to us that sampling is already finished).
  293. */
  294. udelay(1);
  295. return regmap_read_poll_timeout_atomic(priv->regmap, MESON_SAR_ADC_REG0, val,
  296. !FIELD_GET(MESON_SAR_ADC_REG0_BUSY_MASK, val),
  297. 1, 10000);
  298. }
  299. static int meson_sar_adc_read_raw_sample(struct iio_dev *indio_dev,
  300. const struct iio_chan_spec *chan,
  301. int *val)
  302. {
  303. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  304. struct device *dev = indio_dev->dev.parent;
  305. int regval, fifo_chan, fifo_val, count;
  306. if (!wait_for_completion_timeout(&priv->done,
  307. msecs_to_jiffies(MESON_SAR_ADC_TIMEOUT)))
  308. return -ETIMEDOUT;
  309. count = meson_sar_adc_get_fifo_count(indio_dev);
  310. if (count != 1) {
  311. dev_err(dev, "ADC FIFO has %d element(s) instead of one\n", count);
  312. return -EINVAL;
  313. }
  314. regmap_read(priv->regmap, MESON_SAR_ADC_FIFO_RD, &regval);
  315. fifo_chan = FIELD_GET(MESON_SAR_ADC_FIFO_RD_CHAN_ID_MASK, regval);
  316. if (fifo_chan != chan->address) {
  317. dev_err(dev, "ADC FIFO entry belongs to channel %d instead of %lu\n",
  318. fifo_chan, chan->address);
  319. return -EINVAL;
  320. }
  321. fifo_val = FIELD_GET(MESON_SAR_ADC_FIFO_RD_SAMPLE_VALUE_MASK, regval);
  322. fifo_val &= GENMASK(priv->param->resolution - 1, 0);
  323. *val = meson_sar_adc_calib_val(indio_dev, fifo_val);
  324. return 0;
  325. }
  326. static void meson_sar_adc_set_averaging(struct iio_dev *indio_dev,
  327. const struct iio_chan_spec *chan,
  328. enum meson_sar_adc_avg_mode mode,
  329. enum meson_sar_adc_num_samples samples)
  330. {
  331. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  332. int val, address = chan->address;
  333. val = samples << MESON_SAR_ADC_AVG_CNTL_NUM_SAMPLES_SHIFT(address);
  334. regmap_update_bits(priv->regmap, MESON_SAR_ADC_AVG_CNTL,
  335. MESON_SAR_ADC_AVG_CNTL_NUM_SAMPLES_MASK(address),
  336. val);
  337. val = mode << MESON_SAR_ADC_AVG_CNTL_AVG_MODE_SHIFT(address);
  338. regmap_update_bits(priv->regmap, MESON_SAR_ADC_AVG_CNTL,
  339. MESON_SAR_ADC_AVG_CNTL_AVG_MODE_MASK(address), val);
  340. }
  341. static void meson_sar_adc_enable_channel(struct iio_dev *indio_dev,
  342. const struct iio_chan_spec *chan)
  343. {
  344. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  345. u32 regval;
  346. /*
  347. * the SAR ADC engine allows sampling multiple channels at the same
  348. * time. to keep it simple we're only working with one *internal*
  349. * channel, which starts counting at index 0 (which means: count = 1).
  350. */
  351. regval = FIELD_PREP(MESON_SAR_ADC_CHAN_LIST_MAX_INDEX_MASK, 0);
  352. regmap_update_bits(priv->regmap, MESON_SAR_ADC_CHAN_LIST,
  353. MESON_SAR_ADC_CHAN_LIST_MAX_INDEX_MASK, regval);
  354. /* map channel index 0 to the channel which we want to read */
  355. regval = FIELD_PREP(MESON_SAR_ADC_CHAN_LIST_ENTRY_MASK(0),
  356. chan->address);
  357. regmap_update_bits(priv->regmap, MESON_SAR_ADC_CHAN_LIST,
  358. MESON_SAR_ADC_CHAN_LIST_ENTRY_MASK(0), regval);
  359. regval = FIELD_PREP(MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_MUX_MASK,
  360. chan->address);
  361. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DETECT_IDLE_SW,
  362. MESON_SAR_ADC_DETECT_IDLE_SW_DETECT_MUX_MASK,
  363. regval);
  364. regval = FIELD_PREP(MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_MUX_SEL_MASK,
  365. chan->address);
  366. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DETECT_IDLE_SW,
  367. MESON_SAR_ADC_DETECT_IDLE_SW_IDLE_MUX_SEL_MASK,
  368. regval);
  369. if (chan->address == MESON_SAR_ADC_VOLTAGE_AND_TEMP_CHANNEL) {
  370. if (chan->type == IIO_TEMP)
  371. regval = MESON_SAR_ADC_DELTA_10_TEMP_SEL;
  372. else
  373. regval = 0;
  374. regmap_update_bits(priv->regmap,
  375. MESON_SAR_ADC_DELTA_10,
  376. MESON_SAR_ADC_DELTA_10_TEMP_SEL, regval);
  377. }
  378. }
  379. static void meson_sar_adc_set_chan7_mux(struct iio_dev *indio_dev,
  380. enum meson_sar_adc_chan7_mux_sel sel)
  381. {
  382. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  383. u32 regval;
  384. regval = FIELD_PREP(MESON_SAR_ADC_REG3_CTRL_CHAN7_MUX_SEL_MASK, sel);
  385. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG3,
  386. MESON_SAR_ADC_REG3_CTRL_CHAN7_MUX_SEL_MASK, regval);
  387. usleep_range(10, 20);
  388. }
  389. static void meson_sar_adc_start_sample_engine(struct iio_dev *indio_dev)
  390. {
  391. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  392. reinit_completion(&priv->done);
  393. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  394. MESON_SAR_ADC_REG0_FIFO_IRQ_EN,
  395. MESON_SAR_ADC_REG0_FIFO_IRQ_EN);
  396. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  397. MESON_SAR_ADC_REG0_SAMPLE_ENGINE_ENABLE,
  398. MESON_SAR_ADC_REG0_SAMPLE_ENGINE_ENABLE);
  399. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  400. MESON_SAR_ADC_REG0_SAMPLING_START,
  401. MESON_SAR_ADC_REG0_SAMPLING_START);
  402. }
  403. static void meson_sar_adc_stop_sample_engine(struct iio_dev *indio_dev)
  404. {
  405. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  406. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  407. MESON_SAR_ADC_REG0_FIFO_IRQ_EN, 0);
  408. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  409. MESON_SAR_ADC_REG0_SAMPLING_STOP,
  410. MESON_SAR_ADC_REG0_SAMPLING_STOP);
  411. /* wait until all modules are stopped */
  412. meson_sar_adc_wait_busy_clear(indio_dev);
  413. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  414. MESON_SAR_ADC_REG0_SAMPLE_ENGINE_ENABLE, 0);
  415. }
  416. static int meson_sar_adc_lock(struct iio_dev *indio_dev)
  417. {
  418. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  419. int val, ret;
  420. mutex_lock(&indio_dev->mlock);
  421. if (priv->param->has_bl30_integration) {
  422. /* prevent BL30 from using the SAR ADC while we are using it */
  423. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELAY,
  424. MESON_SAR_ADC_DELAY_KERNEL_BUSY,
  425. MESON_SAR_ADC_DELAY_KERNEL_BUSY);
  426. udelay(1);
  427. /*
  428. * wait until BL30 releases it's lock (so we can use the SAR
  429. * ADC)
  430. */
  431. ret = regmap_read_poll_timeout_atomic(priv->regmap, MESON_SAR_ADC_DELAY, val,
  432. !(val & MESON_SAR_ADC_DELAY_BL30_BUSY),
  433. 1, 10000);
  434. if (ret) {
  435. mutex_unlock(&indio_dev->mlock);
  436. return ret;
  437. }
  438. }
  439. return 0;
  440. }
  441. static void meson_sar_adc_unlock(struct iio_dev *indio_dev)
  442. {
  443. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  444. if (priv->param->has_bl30_integration)
  445. /* allow BL30 to use the SAR ADC again */
  446. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELAY,
  447. MESON_SAR_ADC_DELAY_KERNEL_BUSY, 0);
  448. mutex_unlock(&indio_dev->mlock);
  449. }
  450. static void meson_sar_adc_clear_fifo(struct iio_dev *indio_dev)
  451. {
  452. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  453. unsigned int count, tmp;
  454. for (count = 0; count < MESON_SAR_ADC_MAX_FIFO_SIZE; count++) {
  455. if (!meson_sar_adc_get_fifo_count(indio_dev))
  456. break;
  457. regmap_read(priv->regmap, MESON_SAR_ADC_FIFO_RD, &tmp);
  458. }
  459. }
  460. static int meson_sar_adc_get_sample(struct iio_dev *indio_dev,
  461. const struct iio_chan_spec *chan,
  462. enum meson_sar_adc_avg_mode avg_mode,
  463. enum meson_sar_adc_num_samples avg_samples,
  464. int *val)
  465. {
  466. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  467. struct device *dev = indio_dev->dev.parent;
  468. int ret;
  469. if (chan->type == IIO_TEMP && !priv->temperature_sensor_calibrated)
  470. return -ENOTSUPP;
  471. ret = meson_sar_adc_lock(indio_dev);
  472. if (ret)
  473. return ret;
  474. /* clear the FIFO to make sure we're not reading old values */
  475. meson_sar_adc_clear_fifo(indio_dev);
  476. meson_sar_adc_set_averaging(indio_dev, chan, avg_mode, avg_samples);
  477. meson_sar_adc_enable_channel(indio_dev, chan);
  478. meson_sar_adc_start_sample_engine(indio_dev);
  479. ret = meson_sar_adc_read_raw_sample(indio_dev, chan, val);
  480. meson_sar_adc_stop_sample_engine(indio_dev);
  481. meson_sar_adc_unlock(indio_dev);
  482. if (ret) {
  483. dev_warn(dev, "failed to read sample for channel %lu: %d\n",
  484. chan->address, ret);
  485. return ret;
  486. }
  487. return IIO_VAL_INT;
  488. }
  489. static int meson_sar_adc_iio_info_read_raw(struct iio_dev *indio_dev,
  490. const struct iio_chan_spec *chan,
  491. int *val, int *val2, long mask)
  492. {
  493. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  494. struct device *dev = indio_dev->dev.parent;
  495. int ret;
  496. switch (mask) {
  497. case IIO_CHAN_INFO_RAW:
  498. return meson_sar_adc_get_sample(indio_dev, chan, NO_AVERAGING,
  499. ONE_SAMPLE, val);
  500. case IIO_CHAN_INFO_AVERAGE_RAW:
  501. return meson_sar_adc_get_sample(indio_dev, chan,
  502. MEAN_AVERAGING, EIGHT_SAMPLES,
  503. val);
  504. case IIO_CHAN_INFO_SCALE:
  505. if (chan->type == IIO_VOLTAGE) {
  506. ret = regulator_get_voltage(priv->vref);
  507. if (ret < 0) {
  508. dev_err(dev, "failed to get vref voltage: %d\n", ret);
  509. return ret;
  510. }
  511. *val = ret / 1000;
  512. *val2 = priv->param->resolution;
  513. return IIO_VAL_FRACTIONAL_LOG2;
  514. } else if (chan->type == IIO_TEMP) {
  515. /* SoC specific multiplier and divider */
  516. *val = priv->param->temperature_multiplier;
  517. *val2 = priv->param->temperature_divider;
  518. /* celsius to millicelsius */
  519. *val *= 1000;
  520. return IIO_VAL_FRACTIONAL;
  521. } else {
  522. return -EINVAL;
  523. }
  524. case IIO_CHAN_INFO_CALIBBIAS:
  525. *val = priv->calibbias;
  526. return IIO_VAL_INT;
  527. case IIO_CHAN_INFO_CALIBSCALE:
  528. *val = priv->calibscale / MILLION;
  529. *val2 = priv->calibscale % MILLION;
  530. return IIO_VAL_INT_PLUS_MICRO;
  531. case IIO_CHAN_INFO_OFFSET:
  532. *val = DIV_ROUND_CLOSEST(MESON_SAR_ADC_TEMP_OFFSET *
  533. priv->param->temperature_divider,
  534. priv->param->temperature_multiplier);
  535. *val -= priv->temperature_sensor_adc_val;
  536. return IIO_VAL_INT;
  537. default:
  538. return -EINVAL;
  539. }
  540. }
  541. static int meson_sar_adc_clk_init(struct iio_dev *indio_dev,
  542. void __iomem *base)
  543. {
  544. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  545. struct device *dev = indio_dev->dev.parent;
  546. struct clk_init_data init;
  547. const char *clk_parents[1];
  548. init.name = devm_kasprintf(dev, GFP_KERNEL, "%s#adc_div", dev_name(dev));
  549. if (!init.name)
  550. return -ENOMEM;
  551. init.flags = 0;
  552. init.ops = &clk_divider_ops;
  553. clk_parents[0] = __clk_get_name(priv->clkin);
  554. init.parent_names = clk_parents;
  555. init.num_parents = 1;
  556. priv->clk_div.reg = base + MESON_SAR_ADC_REG3;
  557. priv->clk_div.shift = MESON_SAR_ADC_REG3_ADC_CLK_DIV_SHIFT;
  558. priv->clk_div.width = MESON_SAR_ADC_REG3_ADC_CLK_DIV_WIDTH;
  559. priv->clk_div.hw.init = &init;
  560. priv->clk_div.flags = 0;
  561. priv->adc_div_clk = devm_clk_register(dev, &priv->clk_div.hw);
  562. if (WARN_ON(IS_ERR(priv->adc_div_clk)))
  563. return PTR_ERR(priv->adc_div_clk);
  564. init.name = devm_kasprintf(dev, GFP_KERNEL, "%s#adc_en", dev_name(dev));
  565. if (!init.name)
  566. return -ENOMEM;
  567. init.flags = CLK_SET_RATE_PARENT;
  568. init.ops = &clk_gate_ops;
  569. clk_parents[0] = __clk_get_name(priv->adc_div_clk);
  570. init.parent_names = clk_parents;
  571. init.num_parents = 1;
  572. priv->clk_gate.reg = base + MESON_SAR_ADC_REG3;
  573. priv->clk_gate.bit_idx = __ffs(MESON_SAR_ADC_REG3_CLK_EN);
  574. priv->clk_gate.hw.init = &init;
  575. priv->adc_clk = devm_clk_register(dev, &priv->clk_gate.hw);
  576. if (WARN_ON(IS_ERR(priv->adc_clk)))
  577. return PTR_ERR(priv->adc_clk);
  578. return 0;
  579. }
  580. static int meson_sar_adc_temp_sensor_init(struct iio_dev *indio_dev)
  581. {
  582. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  583. u8 *buf, trimming_bits, trimming_mask, upper_adc_val;
  584. struct device *dev = indio_dev->dev.parent;
  585. struct nvmem_cell *temperature_calib;
  586. size_t read_len;
  587. int ret;
  588. temperature_calib = devm_nvmem_cell_get(dev, "temperature_calib");
  589. if (IS_ERR(temperature_calib)) {
  590. ret = PTR_ERR(temperature_calib);
  591. /*
  592. * leave the temperature sensor disabled if no calibration data
  593. * was passed via nvmem-cells.
  594. */
  595. if (ret == -ENODEV)
  596. return 0;
  597. return dev_err_probe(dev, ret, "failed to get temperature_calib cell\n");
  598. }
  599. priv->tsc_regmap = syscon_regmap_lookup_by_phandle(dev->of_node, "amlogic,hhi-sysctrl");
  600. if (IS_ERR(priv->tsc_regmap))
  601. return dev_err_probe(dev, PTR_ERR(priv->tsc_regmap),
  602. "failed to get amlogic,hhi-sysctrl regmap\n");
  603. read_len = MESON_SAR_ADC_EFUSE_BYTES;
  604. buf = nvmem_cell_read(temperature_calib, &read_len);
  605. if (IS_ERR(buf))
  606. return dev_err_probe(dev, PTR_ERR(buf), "failed to read temperature_calib cell\n");
  607. if (read_len != MESON_SAR_ADC_EFUSE_BYTES) {
  608. kfree(buf);
  609. return dev_err_probe(dev, -EINVAL, "invalid read size of temperature_calib cell\n");
  610. }
  611. trimming_bits = priv->param->temperature_trimming_bits;
  612. trimming_mask = BIT(trimming_bits) - 1;
  613. priv->temperature_sensor_calibrated =
  614. buf[3] & MESON_SAR_ADC_EFUSE_BYTE3_IS_CALIBRATED;
  615. priv->temperature_sensor_coefficient = buf[2] & trimming_mask;
  616. upper_adc_val = FIELD_GET(MESON_SAR_ADC_EFUSE_BYTE3_UPPER_ADC_VAL,
  617. buf[3]);
  618. priv->temperature_sensor_adc_val = buf[2];
  619. priv->temperature_sensor_adc_val |= upper_adc_val << BITS_PER_BYTE;
  620. priv->temperature_sensor_adc_val >>= trimming_bits;
  621. kfree(buf);
  622. return 0;
  623. }
  624. static int meson_sar_adc_init(struct iio_dev *indio_dev)
  625. {
  626. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  627. struct device *dev = indio_dev->dev.parent;
  628. int regval, i, ret;
  629. /*
  630. * make sure we start at CH7 input since the other muxes are only used
  631. * for internal calibration.
  632. */
  633. meson_sar_adc_set_chan7_mux(indio_dev, CHAN7_MUX_CH7_INPUT);
  634. if (priv->param->has_bl30_integration) {
  635. /*
  636. * leave sampling delay and the input clocks as configured by
  637. * BL30 to make sure BL30 gets the values it expects when
  638. * reading the temperature sensor.
  639. */
  640. regmap_read(priv->regmap, MESON_SAR_ADC_REG3, &regval);
  641. if (regval & MESON_SAR_ADC_REG3_BL30_INITIALIZED)
  642. return 0;
  643. }
  644. meson_sar_adc_stop_sample_engine(indio_dev);
  645. /*
  646. * disable this bit as seems to be only relevant for Meson6 (based
  647. * on the vendor driver), which we don't support at the moment.
  648. */
  649. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  650. MESON_SAR_ADC_REG0_ADC_TEMP_SEN_SEL, 0);
  651. /* disable all channels by default */
  652. regmap_write(priv->regmap, MESON_SAR_ADC_CHAN_LIST, 0x0);
  653. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG3,
  654. MESON_SAR_ADC_REG3_CTRL_SAMPLING_CLOCK_PHASE, 0);
  655. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG3,
  656. MESON_SAR_ADC_REG3_CNTL_USE_SC_DLY,
  657. MESON_SAR_ADC_REG3_CNTL_USE_SC_DLY);
  658. /* delay between two samples = (10+1) * 1uS */
  659. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELAY,
  660. MESON_SAR_ADC_DELAY_INPUT_DLY_CNT_MASK,
  661. FIELD_PREP(MESON_SAR_ADC_DELAY_SAMPLE_DLY_CNT_MASK,
  662. 10));
  663. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELAY,
  664. MESON_SAR_ADC_DELAY_SAMPLE_DLY_SEL_MASK,
  665. FIELD_PREP(MESON_SAR_ADC_DELAY_SAMPLE_DLY_SEL_MASK,
  666. 0));
  667. /* delay between two samples = (10+1) * 1uS */
  668. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELAY,
  669. MESON_SAR_ADC_DELAY_INPUT_DLY_CNT_MASK,
  670. FIELD_PREP(MESON_SAR_ADC_DELAY_INPUT_DLY_CNT_MASK,
  671. 10));
  672. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELAY,
  673. MESON_SAR_ADC_DELAY_INPUT_DLY_SEL_MASK,
  674. FIELD_PREP(MESON_SAR_ADC_DELAY_INPUT_DLY_SEL_MASK,
  675. 1));
  676. /*
  677. * set up the input channel muxes in MESON_SAR_ADC_CHAN_10_SW
  678. * (0 = SAR_ADC_CH0, 1 = SAR_ADC_CH1)
  679. */
  680. regval = FIELD_PREP(MESON_SAR_ADC_CHAN_10_SW_CHAN0_MUX_SEL_MASK, 0);
  681. regmap_update_bits(priv->regmap, MESON_SAR_ADC_CHAN_10_SW,
  682. MESON_SAR_ADC_CHAN_10_SW_CHAN0_MUX_SEL_MASK,
  683. regval);
  684. regval = FIELD_PREP(MESON_SAR_ADC_CHAN_10_SW_CHAN1_MUX_SEL_MASK, 1);
  685. regmap_update_bits(priv->regmap, MESON_SAR_ADC_CHAN_10_SW,
  686. MESON_SAR_ADC_CHAN_10_SW_CHAN1_MUX_SEL_MASK,
  687. regval);
  688. /*
  689. * set up the input channel muxes in MESON_SAR_ADC_AUX_SW
  690. * (2 = SAR_ADC_CH2, 3 = SAR_ADC_CH3, ...) and enable
  691. * MESON_SAR_ADC_AUX_SW_YP_DRIVE_SW and
  692. * MESON_SAR_ADC_AUX_SW_XP_DRIVE_SW like the vendor driver.
  693. */
  694. regval = 0;
  695. for (i = 2; i <= 7; i++)
  696. regval |= i << MESON_SAR_ADC_AUX_SW_MUX_SEL_CHAN_SHIFT(i);
  697. regval |= MESON_SAR_ADC_AUX_SW_YP_DRIVE_SW;
  698. regval |= MESON_SAR_ADC_AUX_SW_XP_DRIVE_SW;
  699. regmap_write(priv->regmap, MESON_SAR_ADC_AUX_SW, regval);
  700. if (priv->temperature_sensor_calibrated) {
  701. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELTA_10,
  702. MESON_SAR_ADC_DELTA_10_TS_REVE1,
  703. MESON_SAR_ADC_DELTA_10_TS_REVE1);
  704. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELTA_10,
  705. MESON_SAR_ADC_DELTA_10_TS_REVE0,
  706. MESON_SAR_ADC_DELTA_10_TS_REVE0);
  707. /*
  708. * set bits [3:0] of the TSC (temperature sensor coefficient)
  709. * to get the correct values when reading the temperature.
  710. */
  711. regval = FIELD_PREP(MESON_SAR_ADC_DELTA_10_TS_C_MASK,
  712. priv->temperature_sensor_coefficient);
  713. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELTA_10,
  714. MESON_SAR_ADC_DELTA_10_TS_C_MASK, regval);
  715. if (priv->param->temperature_trimming_bits == 5) {
  716. if (priv->temperature_sensor_coefficient & BIT(4))
  717. regval = MESON_HHI_DPLL_TOP_0_TSC_BIT4;
  718. else
  719. regval = 0;
  720. /*
  721. * bit [4] (the 5th bit when starting to count at 1)
  722. * of the TSC is located in the HHI register area.
  723. */
  724. regmap_update_bits(priv->tsc_regmap,
  725. MESON_HHI_DPLL_TOP_0,
  726. MESON_HHI_DPLL_TOP_0_TSC_BIT4,
  727. regval);
  728. }
  729. } else {
  730. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELTA_10,
  731. MESON_SAR_ADC_DELTA_10_TS_REVE1, 0);
  732. regmap_update_bits(priv->regmap, MESON_SAR_ADC_DELTA_10,
  733. MESON_SAR_ADC_DELTA_10_TS_REVE0, 0);
  734. }
  735. ret = clk_set_parent(priv->adc_sel_clk, priv->clkin);
  736. if (ret)
  737. return dev_err_probe(dev, ret, "failed to set adc parent to clkin\n");
  738. ret = clk_set_rate(priv->adc_clk, priv->param->clock_rate);
  739. if (ret)
  740. return dev_err_probe(dev, ret, "failed to set adc clock rate\n");
  741. return 0;
  742. }
  743. static void meson_sar_adc_set_bandgap(struct iio_dev *indio_dev, bool on_off)
  744. {
  745. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  746. const struct meson_sar_adc_param *param = priv->param;
  747. u32 enable_mask;
  748. if (param->bandgap_reg == MESON_SAR_ADC_REG11)
  749. enable_mask = MESON_SAR_ADC_REG11_BANDGAP_EN;
  750. else
  751. enable_mask = MESON_SAR_ADC_DELTA_10_TS_VBG_EN;
  752. regmap_update_bits(priv->regmap, param->bandgap_reg, enable_mask,
  753. on_off ? enable_mask : 0);
  754. }
  755. static int meson_sar_adc_hw_enable(struct iio_dev *indio_dev)
  756. {
  757. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  758. struct device *dev = indio_dev->dev.parent;
  759. int ret;
  760. u32 regval;
  761. ret = meson_sar_adc_lock(indio_dev);
  762. if (ret)
  763. goto err_lock;
  764. ret = regulator_enable(priv->vref);
  765. if (ret < 0) {
  766. dev_err(dev, "failed to enable vref regulator\n");
  767. goto err_vref;
  768. }
  769. ret = clk_prepare_enable(priv->core_clk);
  770. if (ret) {
  771. dev_err(dev, "failed to enable core clk\n");
  772. goto err_core_clk;
  773. }
  774. regval = FIELD_PREP(MESON_SAR_ADC_REG0_FIFO_CNT_IRQ_MASK, 1);
  775. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG0,
  776. MESON_SAR_ADC_REG0_FIFO_CNT_IRQ_MASK, regval);
  777. meson_sar_adc_set_bandgap(indio_dev, true);
  778. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG3,
  779. MESON_SAR_ADC_REG3_ADC_EN,
  780. MESON_SAR_ADC_REG3_ADC_EN);
  781. udelay(5);
  782. ret = clk_prepare_enable(priv->adc_clk);
  783. if (ret) {
  784. dev_err(dev, "failed to enable adc clk\n");
  785. goto err_adc_clk;
  786. }
  787. meson_sar_adc_unlock(indio_dev);
  788. return 0;
  789. err_adc_clk:
  790. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG3,
  791. MESON_SAR_ADC_REG3_ADC_EN, 0);
  792. meson_sar_adc_set_bandgap(indio_dev, false);
  793. clk_disable_unprepare(priv->core_clk);
  794. err_core_clk:
  795. regulator_disable(priv->vref);
  796. err_vref:
  797. meson_sar_adc_unlock(indio_dev);
  798. err_lock:
  799. return ret;
  800. }
  801. static int meson_sar_adc_hw_disable(struct iio_dev *indio_dev)
  802. {
  803. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  804. int ret;
  805. ret = meson_sar_adc_lock(indio_dev);
  806. if (ret)
  807. return ret;
  808. clk_disable_unprepare(priv->adc_clk);
  809. regmap_update_bits(priv->regmap, MESON_SAR_ADC_REG3,
  810. MESON_SAR_ADC_REG3_ADC_EN, 0);
  811. meson_sar_adc_set_bandgap(indio_dev, false);
  812. clk_disable_unprepare(priv->core_clk);
  813. regulator_disable(priv->vref);
  814. meson_sar_adc_unlock(indio_dev);
  815. return 0;
  816. }
  817. static irqreturn_t meson_sar_adc_irq(int irq, void *data)
  818. {
  819. struct iio_dev *indio_dev = data;
  820. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  821. unsigned int cnt, threshold;
  822. u32 regval;
  823. regmap_read(priv->regmap, MESON_SAR_ADC_REG0, &regval);
  824. cnt = FIELD_GET(MESON_SAR_ADC_REG0_FIFO_COUNT_MASK, regval);
  825. threshold = FIELD_GET(MESON_SAR_ADC_REG0_FIFO_CNT_IRQ_MASK, regval);
  826. if (cnt < threshold)
  827. return IRQ_NONE;
  828. complete(&priv->done);
  829. return IRQ_HANDLED;
  830. }
  831. static int meson_sar_adc_calib(struct iio_dev *indio_dev)
  832. {
  833. struct meson_sar_adc_priv *priv = iio_priv(indio_dev);
  834. int ret, nominal0, nominal1, value0, value1;
  835. /* use points 25% and 75% for calibration */
  836. nominal0 = (1 << priv->param->resolution) / 4;
  837. nominal1 = (1 << priv->param->resolution) * 3 / 4;
  838. meson_sar_adc_set_chan7_mux(indio_dev, CHAN7_MUX_VDD_DIV4);
  839. usleep_range(10, 20);
  840. ret = meson_sar_adc_get_sample(indio_dev,
  841. &indio_dev->channels[7],
  842. MEAN_AVERAGING, EIGHT_SAMPLES, &value0);
  843. if (ret < 0)
  844. goto out;
  845. meson_sar_adc_set_chan7_mux(indio_dev, CHAN7_MUX_VDD_MUL3_DIV4);
  846. usleep_range(10, 20);
  847. ret = meson_sar_adc_get_sample(indio_dev,
  848. &indio_dev->channels[7],
  849. MEAN_AVERAGING, EIGHT_SAMPLES, &value1);
  850. if (ret < 0)
  851. goto out;
  852. if (value1 <= value0) {
  853. ret = -EINVAL;
  854. goto out;
  855. }
  856. priv->calibscale = div_s64((nominal1 - nominal0) * (s64)MILLION,
  857. value1 - value0);
  858. priv->calibbias = nominal0 - div_s64((s64)value0 * priv->calibscale,
  859. MILLION);
  860. ret = 0;
  861. out:
  862. meson_sar_adc_set_chan7_mux(indio_dev, CHAN7_MUX_CH7_INPUT);
  863. return ret;
  864. }
  865. static const struct iio_info meson_sar_adc_iio_info = {
  866. .read_raw = meson_sar_adc_iio_info_read_raw,
  867. };
  868. static const struct meson_sar_adc_param meson_sar_adc_meson8_param = {
  869. .has_bl30_integration = false,
  870. .clock_rate = 1150000,
  871. .bandgap_reg = MESON_SAR_ADC_DELTA_10,
  872. .regmap_config = &meson_sar_adc_regmap_config_meson8,
  873. .resolution = 10,
  874. .temperature_trimming_bits = 4,
  875. .temperature_multiplier = 18 * 10000,
  876. .temperature_divider = 1024 * 10 * 85,
  877. };
  878. static const struct meson_sar_adc_param meson_sar_adc_meson8b_param = {
  879. .has_bl30_integration = false,
  880. .clock_rate = 1150000,
  881. .bandgap_reg = MESON_SAR_ADC_DELTA_10,
  882. .regmap_config = &meson_sar_adc_regmap_config_meson8,
  883. .resolution = 10,
  884. .temperature_trimming_bits = 5,
  885. .temperature_multiplier = 10,
  886. .temperature_divider = 32,
  887. };
  888. static const struct meson_sar_adc_param meson_sar_adc_gxbb_param = {
  889. .has_bl30_integration = true,
  890. .clock_rate = 1200000,
  891. .bandgap_reg = MESON_SAR_ADC_REG11,
  892. .regmap_config = &meson_sar_adc_regmap_config_gxbb,
  893. .resolution = 10,
  894. };
  895. static const struct meson_sar_adc_param meson_sar_adc_gxl_param = {
  896. .has_bl30_integration = true,
  897. .clock_rate = 1200000,
  898. .bandgap_reg = MESON_SAR_ADC_REG11,
  899. .regmap_config = &meson_sar_adc_regmap_config_gxbb,
  900. .resolution = 12,
  901. };
  902. static const struct meson_sar_adc_param meson_sar_adc_g12a_param = {
  903. .has_bl30_integration = false,
  904. .clock_rate = 1200000,
  905. .bandgap_reg = MESON_SAR_ADC_REG11,
  906. .regmap_config = &meson_sar_adc_regmap_config_gxbb,
  907. .resolution = 12,
  908. };
  909. static const struct meson_sar_adc_data meson_sar_adc_meson8_data = {
  910. .param = &meson_sar_adc_meson8_param,
  911. .name = "meson-meson8-saradc",
  912. };
  913. static const struct meson_sar_adc_data meson_sar_adc_meson8b_data = {
  914. .param = &meson_sar_adc_meson8b_param,
  915. .name = "meson-meson8b-saradc",
  916. };
  917. static const struct meson_sar_adc_data meson_sar_adc_meson8m2_data = {
  918. .param = &meson_sar_adc_meson8b_param,
  919. .name = "meson-meson8m2-saradc",
  920. };
  921. static const struct meson_sar_adc_data meson_sar_adc_gxbb_data = {
  922. .param = &meson_sar_adc_gxbb_param,
  923. .name = "meson-gxbb-saradc",
  924. };
  925. static const struct meson_sar_adc_data meson_sar_adc_gxl_data = {
  926. .param = &meson_sar_adc_gxl_param,
  927. .name = "meson-gxl-saradc",
  928. };
  929. static const struct meson_sar_adc_data meson_sar_adc_gxm_data = {
  930. .param = &meson_sar_adc_gxl_param,
  931. .name = "meson-gxm-saradc",
  932. };
  933. static const struct meson_sar_adc_data meson_sar_adc_axg_data = {
  934. .param = &meson_sar_adc_gxl_param,
  935. .name = "meson-axg-saradc",
  936. };
  937. static const struct meson_sar_adc_data meson_sar_adc_g12a_data = {
  938. .param = &meson_sar_adc_g12a_param,
  939. .name = "meson-g12a-saradc",
  940. };
  941. static const struct of_device_id meson_sar_adc_of_match[] = {
  942. {
  943. .compatible = "amlogic,meson8-saradc",
  944. .data = &meson_sar_adc_meson8_data,
  945. }, {
  946. .compatible = "amlogic,meson8b-saradc",
  947. .data = &meson_sar_adc_meson8b_data,
  948. }, {
  949. .compatible = "amlogic,meson8m2-saradc",
  950. .data = &meson_sar_adc_meson8m2_data,
  951. }, {
  952. .compatible = "amlogic,meson-gxbb-saradc",
  953. .data = &meson_sar_adc_gxbb_data,
  954. }, {
  955. .compatible = "amlogic,meson-gxl-saradc",
  956. .data = &meson_sar_adc_gxl_data,
  957. }, {
  958. .compatible = "amlogic,meson-gxm-saradc",
  959. .data = &meson_sar_adc_gxm_data,
  960. }, {
  961. .compatible = "amlogic,meson-axg-saradc",
  962. .data = &meson_sar_adc_axg_data,
  963. }, {
  964. .compatible = "amlogic,meson-g12a-saradc",
  965. .data = &meson_sar_adc_g12a_data,
  966. },
  967. { /* sentinel */ }
  968. };
  969. MODULE_DEVICE_TABLE(of, meson_sar_adc_of_match);
  970. static int meson_sar_adc_probe(struct platform_device *pdev)
  971. {
  972. const struct meson_sar_adc_data *match_data;
  973. struct meson_sar_adc_priv *priv;
  974. struct device *dev = &pdev->dev;
  975. struct iio_dev *indio_dev;
  976. void __iomem *base;
  977. int irq, ret;
  978. indio_dev = devm_iio_device_alloc(dev, sizeof(*priv));
  979. if (!indio_dev)
  980. return dev_err_probe(dev, -ENOMEM, "failed allocating iio device\n");
  981. priv = iio_priv(indio_dev);
  982. init_completion(&priv->done);
  983. match_data = of_device_get_match_data(dev);
  984. if (!match_data)
  985. return dev_err_probe(dev, -ENODEV, "failed to get match data\n");
  986. priv->param = match_data->param;
  987. indio_dev->name = match_data->name;
  988. indio_dev->modes = INDIO_DIRECT_MODE;
  989. indio_dev->info = &meson_sar_adc_iio_info;
  990. base = devm_platform_ioremap_resource(pdev, 0);
  991. if (IS_ERR(base))
  992. return PTR_ERR(base);
  993. priv->regmap = devm_regmap_init_mmio(dev, base, priv->param->regmap_config);
  994. if (IS_ERR(priv->regmap))
  995. return PTR_ERR(priv->regmap);
  996. irq = irq_of_parse_and_map(dev->of_node, 0);
  997. if (!irq)
  998. return -EINVAL;
  999. ret = devm_request_irq(dev, irq, meson_sar_adc_irq, IRQF_SHARED, dev_name(dev), indio_dev);
  1000. if (ret)
  1001. return ret;
  1002. priv->clkin = devm_clk_get(dev, "clkin");
  1003. if (IS_ERR(priv->clkin))
  1004. return dev_err_probe(dev, PTR_ERR(priv->clkin), "failed to get clkin\n");
  1005. priv->core_clk = devm_clk_get(dev, "core");
  1006. if (IS_ERR(priv->core_clk))
  1007. return dev_err_probe(dev, PTR_ERR(priv->core_clk), "failed to get core clk\n");
  1008. priv->adc_clk = devm_clk_get_optional(dev, "adc_clk");
  1009. if (IS_ERR(priv->adc_clk))
  1010. return dev_err_probe(dev, PTR_ERR(priv->adc_clk), "failed to get adc clk\n");
  1011. priv->adc_sel_clk = devm_clk_get_optional(dev, "adc_sel");
  1012. if (IS_ERR(priv->adc_sel_clk))
  1013. return dev_err_probe(dev, PTR_ERR(priv->adc_sel_clk), "failed to get adc_sel clk\n");
  1014. /* on pre-GXBB SoCs the SAR ADC itself provides the ADC clock: */
  1015. if (!priv->adc_clk) {
  1016. ret = meson_sar_adc_clk_init(indio_dev, base);
  1017. if (ret)
  1018. return ret;
  1019. }
  1020. priv->vref = devm_regulator_get(dev, "vref");
  1021. if (IS_ERR(priv->vref))
  1022. return dev_err_probe(dev, PTR_ERR(priv->vref), "failed to get vref regulator\n");
  1023. priv->calibscale = MILLION;
  1024. if (priv->param->temperature_trimming_bits) {
  1025. ret = meson_sar_adc_temp_sensor_init(indio_dev);
  1026. if (ret)
  1027. return ret;
  1028. }
  1029. if (priv->temperature_sensor_calibrated) {
  1030. indio_dev->channels = meson_sar_adc_and_temp_iio_channels;
  1031. indio_dev->num_channels =
  1032. ARRAY_SIZE(meson_sar_adc_and_temp_iio_channels);
  1033. } else {
  1034. indio_dev->channels = meson_sar_adc_iio_channels;
  1035. indio_dev->num_channels =
  1036. ARRAY_SIZE(meson_sar_adc_iio_channels);
  1037. }
  1038. ret = meson_sar_adc_init(indio_dev);
  1039. if (ret)
  1040. goto err;
  1041. ret = meson_sar_adc_hw_enable(indio_dev);
  1042. if (ret)
  1043. goto err;
  1044. ret = meson_sar_adc_calib(indio_dev);
  1045. if (ret)
  1046. dev_warn(dev, "calibration failed\n");
  1047. platform_set_drvdata(pdev, indio_dev);
  1048. ret = iio_device_register(indio_dev);
  1049. if (ret)
  1050. goto err_hw;
  1051. return 0;
  1052. err_hw:
  1053. meson_sar_adc_hw_disable(indio_dev);
  1054. err:
  1055. return ret;
  1056. }
  1057. static int meson_sar_adc_remove(struct platform_device *pdev)
  1058. {
  1059. struct iio_dev *indio_dev = platform_get_drvdata(pdev);
  1060. iio_device_unregister(indio_dev);
  1061. return meson_sar_adc_hw_disable(indio_dev);
  1062. }
  1063. static int meson_sar_adc_suspend(struct device *dev)
  1064. {
  1065. struct iio_dev *indio_dev = dev_get_drvdata(dev);
  1066. return meson_sar_adc_hw_disable(indio_dev);
  1067. }
  1068. static int meson_sar_adc_resume(struct device *dev)
  1069. {
  1070. struct iio_dev *indio_dev = dev_get_drvdata(dev);
  1071. return meson_sar_adc_hw_enable(indio_dev);
  1072. }
  1073. static DEFINE_SIMPLE_DEV_PM_OPS(meson_sar_adc_pm_ops,
  1074. meson_sar_adc_suspend, meson_sar_adc_resume);
  1075. static struct platform_driver meson_sar_adc_driver = {
  1076. .probe = meson_sar_adc_probe,
  1077. .remove = meson_sar_adc_remove,
  1078. .driver = {
  1079. .name = "meson-saradc",
  1080. .of_match_table = meson_sar_adc_of_match,
  1081. .pm = pm_sleep_ptr(&meson_sar_adc_pm_ops),
  1082. },
  1083. };
  1084. module_platform_driver(meson_sar_adc_driver);
  1085. MODULE_AUTHOR("Martin Blumenstingl <[email protected]>");
  1086. MODULE_DESCRIPTION("Amlogic Meson SAR ADC driver");
  1087. MODULE_LICENSE("GPL v2");