Lines Matching refs:iadc
126 static int iadc_read(struct iadc_chip *iadc, u16 offset, u8 *data) in iadc_read() argument
131 ret = regmap_read(iadc->regmap, iadc->base + offset, &val); in iadc_read()
139 static int iadc_write(struct iadc_chip *iadc, u16 offset, u8 data) in iadc_write() argument
141 return regmap_write(iadc->regmap, iadc->base + offset, data); in iadc_write()
144 static int iadc_reset(struct iadc_chip *iadc) in iadc_reset() argument
149 ret = iadc_write(iadc, IADC_SEC_ACCESS, IADC_SEC_ACCESS_DATA); in iadc_reset()
153 ret = iadc_read(iadc, IADC_PERH_RESET_CTL3, &data); in iadc_reset()
157 ret = iadc_write(iadc, IADC_SEC_ACCESS, IADC_SEC_ACCESS_DATA); in iadc_reset()
163 return iadc_write(iadc, IADC_PERH_RESET_CTL3, data); in iadc_reset()
166 static int iadc_set_state(struct iadc_chip *iadc, bool state) in iadc_set_state() argument
168 return iadc_write(iadc, IADC_EN_CTL1, state ? IADC_EN_CTL1_SET : 0); in iadc_set_state()
171 static void iadc_status_show(struct iadc_chip *iadc) in iadc_status_show() argument
176 ret = iadc_read(iadc, IADC_MODE_CTL, &mode); in iadc_status_show()
180 ret = iadc_read(iadc, IADC_DIG_PARAM, &dig); in iadc_status_show()
184 ret = iadc_read(iadc, IADC_CH_SEL_CTL, &chan); in iadc_status_show()
188 ret = iadc_read(iadc, IADC_CONV_REQ, &req); in iadc_status_show()
192 ret = iadc_read(iadc, IADC_STATUS1, &sta1); in iadc_status_show()
196 ret = iadc_read(iadc, IADC_EN_CTL1, &en); in iadc_status_show()
200 dev_err(iadc->dev, in iadc_status_show()
205 static int iadc_configure(struct iadc_chip *iadc, int channel) in iadc_configure() argument
212 ret = iadc_write(iadc, IADC_MODE_CTL, mode); in iadc_configure()
217 ret = iadc_write(iadc, IADC_CH_SEL_CTL, channel); in iadc_configure()
223 ret = iadc_write(iadc, IADC_DIG_PARAM, decim); in iadc_configure()
228 ret = iadc_write(iadc, IADC_HW_SETTLE_DELAY, IADC_DEF_HW_SETTLE_TIME); in iadc_configure()
232 ret = iadc_write(iadc, IADC_FAST_AVG_CTL, IADC_DEF_AVG_SAMPLES); in iadc_configure()
237 ret = iadc_write(iadc, IADC_FAST_AVG_EN, IADC_FAST_AVG_EN_SET); in iadc_configure()
239 ret = iadc_write(iadc, IADC_FAST_AVG_EN, 0); in iadc_configure()
244 if (!iadc->poll_eoc) in iadc_configure()
245 reinit_completion(&iadc->complete); in iadc_configure()
247 ret = iadc_set_state(iadc, true); in iadc_configure()
252 return iadc_write(iadc, IADC_CONV_REQ, IADC_CONV_REQ_SET); in iadc_configure()
255 static int iadc_poll_wait_eoc(struct iadc_chip *iadc, unsigned int interval_us) in iadc_poll_wait_eoc() argument
264 ret = iadc_read(iadc, IADC_STATUS1, &sta1); in iadc_poll_wait_eoc()
275 iadc_status_show(iadc); in iadc_poll_wait_eoc()
280 static int iadc_read_result(struct iadc_chip *iadc, u16 *data) in iadc_read_result() argument
282 return regmap_bulk_read(iadc->regmap, iadc->base + IADC_DATA, data, 2); in iadc_read_result()
285 static int iadc_do_conversion(struct iadc_chip *iadc, int chan, u16 *data) in iadc_do_conversion() argument
290 ret = iadc_configure(iadc, chan); in iadc_do_conversion()
296 if (iadc->poll_eoc) { in iadc_do_conversion()
297 ret = iadc_poll_wait_eoc(iadc, wait); in iadc_do_conversion()
299 ret = wait_for_completion_timeout(&iadc->complete, in iadc_do_conversion()
305 ret = iadc_poll_wait_eoc(iadc, IADC_CONV_TIME_MIN_US); in iadc_do_conversion()
309 ret = iadc_read_result(iadc, data); in iadc_do_conversion()
311 iadc_set_state(iadc, false); in iadc_do_conversion()
313 dev_err(iadc->dev, "conversion failed\n"); in iadc_do_conversion()
322 struct iadc_chip *iadc = iio_priv(indio_dev); in iadc_read_raw() local
329 mutex_lock(&iadc->lock); in iadc_read_raw()
330 ret = iadc_do_conversion(iadc, chan->channel, &adc_raw); in iadc_read_raw()
331 mutex_unlock(&iadc->lock); in iadc_read_raw()
335 vsense_raw = adc_raw - iadc->offset[chan->channel]; in iadc_read_raw()
338 vsense_uv /= (s32)iadc->gain - iadc->offset[chan->channel]; in iadc_read_raw()
340 isense_ua = vsense_uv / iadc->rsense[chan->channel]; in iadc_read_raw()
342 dev_dbg(iadc->dev, "off %d gain %d adc %d %duV I %duA\n", in iadc_read_raw()
343 iadc->offset[chan->channel], iadc->gain, in iadc_read_raw()
363 struct iadc_chip *iadc = dev_id; in iadc_isr() local
365 complete(&iadc->complete); in iadc_isr()
370 static int iadc_update_offset(struct iadc_chip *iadc) in iadc_update_offset() argument
374 ret = iadc_do_conversion(iadc, IADC_GAIN_17P857MV, &iadc->gain); in iadc_update_offset()
378 ret = iadc_do_conversion(iadc, IADC_INT_OFFSET_CSP2_CSN2, in iadc_update_offset()
379 &iadc->offset[IADC_INT_RSENSE]); in iadc_update_offset()
383 if (iadc->gain == iadc->offset[IADC_INT_RSENSE]) { in iadc_update_offset()
384 dev_err(iadc->dev, "error: internal offset == gain %d\n", in iadc_update_offset()
385 iadc->gain); in iadc_update_offset()
389 ret = iadc_do_conversion(iadc, IADC_EXT_OFFSET_CSP_CSN, in iadc_update_offset()
390 &iadc->offset[IADC_EXT_RSENSE]); in iadc_update_offset()
394 if (iadc->gain == iadc->offset[IADC_EXT_RSENSE]) { in iadc_update_offset()
395 dev_err(iadc->dev, "error: external offset == gain %d\n", in iadc_update_offset()
396 iadc->gain); in iadc_update_offset()
403 static int iadc_version_check(struct iadc_chip *iadc) in iadc_version_check() argument
408 ret = iadc_read(iadc, IADC_PERPH_TYPE, &val); in iadc_version_check()
413 dev_err(iadc->dev, "%d is not ADC\n", val); in iadc_version_check()
417 ret = iadc_read(iadc, IADC_PERPH_SUBTYPE, &val); in iadc_version_check()
422 dev_err(iadc->dev, "%d is not IADC\n", val); in iadc_version_check()
426 ret = iadc_read(iadc, IADC_REVISION2, &val); in iadc_version_check()
431 dev_err(iadc->dev, "revision %d not supported\n", val); in iadc_version_check()
438 static int iadc_rsense_read(struct iadc_chip *iadc, struct device_node *node) in iadc_rsense_read() argument
444 &iadc->rsense[IADC_EXT_RSENSE]); in iadc_rsense_read()
446 iadc->rsense[IADC_EXT_RSENSE] = IADC_INT_RSENSE_IDEAL_VALUE; in iadc_rsense_read()
448 if (!iadc->rsense[IADC_EXT_RSENSE]) { in iadc_rsense_read()
449 dev_err(iadc->dev, "external resistor can't be zero Ohms"); in iadc_rsense_read()
453 ret = iadc_read(iadc, IADC_NOMINAL_RSENSE, &deviation); in iadc_rsense_read()
470 iadc->rsense[IADC_INT_RSENSE] = int_sense; in iadc_rsense_read()
498 struct iadc_chip *iadc; in iadc_probe() local
502 indio_dev = devm_iio_device_alloc(dev, sizeof(*iadc)); in iadc_probe()
506 iadc = iio_priv(indio_dev); in iadc_probe()
507 iadc->dev = dev; in iadc_probe()
509 iadc->regmap = dev_get_regmap(dev->parent, NULL); in iadc_probe()
510 if (!iadc->regmap) in iadc_probe()
513 init_completion(&iadc->complete); in iadc_probe()
514 mutex_init(&iadc->lock); in iadc_probe()
520 iadc->base = res; in iadc_probe()
522 ret = iadc_version_check(iadc); in iadc_probe()
526 ret = iadc_rsense_read(iadc, node); in iadc_probe()
530 dev_dbg(iadc->dev, "sense resistors %d and %d micro Ohm\n", in iadc_probe()
531 iadc->rsense[IADC_INT_RSENSE], in iadc_probe()
532 iadc->rsense[IADC_EXT_RSENSE]); in iadc_probe()
539 iadc->poll_eoc = true; in iadc_probe()
541 ret = iadc_reset(iadc); in iadc_probe()
547 if (!iadc->poll_eoc) { in iadc_probe()
549 "spmi-iadc", iadc); in iadc_probe()
555 device_init_wakeup(iadc->dev, 1); in iadc_probe()
558 ret = iadc_update_offset(iadc); in iadc_probe()