Lines Matching full:madc

4  * TWL4030 MADC module driver-This driver monitors the real time
11 * Based on twl4030-madc.c
57 #define TWL4030_MADC_MADCON (1 << 0) /* MADC power on */
58 #define TWL4030_MADC_BUSY (1 << 0) /* MADC busy */
59 /* MADC conversion completion */
61 /* MADC SWx start conversion */
119 * struct twl4030_madc_request - madc request packet for channel conversion
154 * struct twl4030_madc_data - a container for madc info
155 * @dev: Pointer to device structure for madc
157 * @usb3v1: Pointer to bias regulator for madc
160 * @imr: Interrupt mask register of MADC
161 * @isr: Interrupt status register of MADC
179 struct twl4030_madc_data *madc = iio_priv(iio_dev); in twl4030_madc_read() local
183 req.method = madc->use_second_irq ? TWL4030_MADC_SW2 : TWL4030_MADC_SW1; in twl4030_madc_read()
268 * of different conversion methods supported by MADC.
297 * @madc: pointer to struct twl4030_madc_data
302 static int twl4030_madc_channel_raw_read(struct twl4030_madc_data *madc, u8 reg) in twl4030_madc_channel_raw_read() argument
312 dev_err(madc->dev, "unable to read register 0x%X\n", reg); in twl4030_madc_channel_raw_read()
365 * @madc - pointer to twl4030_madc_data struct
373 static int twl4030_madc_read_channels(struct twl4030_madc_data *madc, in twl4030_madc_read_channels() argument
384 buf[i] = twl4030_madc_channel_raw_read(madc, reg); in twl4030_madc_read_channels()
386 dev_err(madc->dev, "Unable to read register 0x%X\n", in twl4030_madc_read_channels()
398 dev_err(madc->dev, "err reading current\n"); in twl4030_madc_read_channels()
408 dev_err(madc->dev, "err reading temperature\n"); in twl4030_madc_read_channels()
436 * @madc - pointer to twl4030_madc_data struct
442 static int twl4030_madc_disable_irq(struct twl4030_madc_data *madc, u8 id) in twl4030_madc_disable_irq() argument
447 ret = twl_i2c_read_u8(TWL4030_MODULE_MADC, &val, madc->imr); in twl4030_madc_disable_irq()
449 dev_err(madc->dev, "unable to read imr register 0x%X\n", in twl4030_madc_disable_irq()
450 madc->imr); in twl4030_madc_disable_irq()
454 ret = twl_i2c_write_u8(TWL4030_MODULE_MADC, val, madc->imr); in twl4030_madc_disable_irq()
456 dev_err(madc->dev, in twl4030_madc_disable_irq()
457 "unable to write imr register 0x%X\n", madc->imr); in twl4030_madc_disable_irq()
466 struct twl4030_madc_data *madc = _madc; in twl4030_madc_threaded_irq_handler() local
472 mutex_lock(&madc->lock); in twl4030_madc_threaded_irq_handler()
473 ret = twl_i2c_read_u8(TWL4030_MODULE_MADC, &isr_val, madc->isr); in twl4030_madc_threaded_irq_handler()
475 dev_err(madc->dev, "unable to read isr register 0x%X\n", in twl4030_madc_threaded_irq_handler()
476 madc->isr); in twl4030_madc_threaded_irq_handler()
479 ret = twl_i2c_read_u8(TWL4030_MODULE_MADC, &imr_val, madc->imr); in twl4030_madc_threaded_irq_handler()
481 dev_err(madc->dev, "unable to read imr register 0x%X\n", in twl4030_madc_threaded_irq_handler()
482 madc->imr); in twl4030_madc_threaded_irq_handler()
489 ret = twl4030_madc_disable_irq(madc, i); in twl4030_madc_threaded_irq_handler()
491 dev_dbg(madc->dev, "Disable interrupt failed %d\n", i); in twl4030_madc_threaded_irq_handler()
492 madc->requests[i].result_pending = true; in twl4030_madc_threaded_irq_handler()
495 r = &madc->requests[i]; in twl4030_madc_threaded_irq_handler()
501 twl4030_madc_read_channels(madc, method->rbase, in twl4030_madc_threaded_irq_handler()
507 mutex_unlock(&madc->lock); in twl4030_madc_threaded_irq_handler()
517 r = &madc->requests[i]; in twl4030_madc_threaded_irq_handler()
522 twl4030_madc_read_channels(madc, method->rbase, in twl4030_madc_threaded_irq_handler()
528 mutex_unlock(&madc->lock); in twl4030_madc_threaded_irq_handler()
534 * Function which enables the madc conversion
536 * @madc - pointer to twl4030_madc_data struct
541 static int twl4030_madc_start_conversion(struct twl4030_madc_data *madc, in twl4030_madc_start_conversion() argument
554 dev_err(madc->dev, "unable to write ctrl register 0x%X\n", in twl4030_madc_start_conversion()
564 * @madc - pointer to twl4030_madc_data struct
569 static int twl4030_madc_wait_conversion_ready(struct twl4030_madc_data *madc, in twl4030_madc_wait_conversion_ready() argument
582 dev_err(madc->dev, in twl4030_madc_wait_conversion_ready()
591 dev_err(madc->dev, "conversion timeout!\n"); in twl4030_madc_wait_conversion_ready()
669 * @madc: pointer to twl4030_madc_data struct
678 static int twl4030_madc_set_current_generator(struct twl4030_madc_data *madc, in twl4030_madc_set_current_generator() argument
688 dev_err(madc->dev, "unable to read BCICTL1 reg 0x%X", in twl4030_madc_set_current_generator()
702 dev_err(madc->dev, "unable to write BCICTL1 reg 0x%X\n", in twl4030_madc_set_current_generator()
711 * Function that sets MADC software power on bit to enable MADC
712 * @madc - pointer to twl4030_madc_data struct
713 * @on - Enable or disable MADC software power on bit.
716 static int twl4030_madc_set_power(struct twl4030_madc_data *madc, int on) in twl4030_madc_set_power() argument
724 dev_err(madc->dev, "unable to read madc ctrl1 reg 0x%X\n", in twl4030_madc_set_power()
734 dev_err(madc->dev, "unable to write madc ctrl1 reg 0x%X\n", in twl4030_madc_set_power()
743 * Initialize MADC and request for threaded irq
747 struct twl4030_madc_data *madc; in twl4030_madc_probe() local
759 iio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(*madc)); in twl4030_madc_probe()
765 madc = iio_priv(iio_dev); in twl4030_madc_probe()
766 madc->dev = &pdev->dev; in twl4030_madc_probe()
780 madc->use_second_irq = (pdata->irq_line != 1); in twl4030_madc_probe()
782 madc->use_second_irq = of_property_read_bool(np, in twl4030_madc_probe()
783 "ti,system-uses-second-madc-irq"); in twl4030_madc_probe()
785 madc->imr = madc->use_second_irq ? TWL4030_MADC_IMR2 : in twl4030_madc_probe()
787 madc->isr = madc->use_second_irq ? TWL4030_MADC_ISR2 : in twl4030_madc_probe()
790 ret = twl4030_madc_set_power(madc, 1); in twl4030_madc_probe()
793 ret = twl4030_madc_set_current_generator(madc, 0, 1); in twl4030_madc_probe()
813 /* Check that MADC clock is on */ in twl4030_madc_probe()
821 /* If MADC clk is not on, turn it on */ in twl4030_madc_probe()
835 mutex_init(&madc->lock); in twl4030_madc_probe()
841 "twl4030_madc", madc); in twl4030_madc_probe()
846 twl4030_madc = madc; in twl4030_madc_probe()
848 /* Configure MADC[3:6] */ in twl4030_madc_probe()
865 /* Enable 3v1 bias regulator for MADC[3:6] */ in twl4030_madc_probe()
866 madc->usb3v1 = devm_regulator_get(madc->dev, "vusb3v1"); in twl4030_madc_probe()
867 if (IS_ERR(madc->usb3v1)) { in twl4030_madc_probe()
872 ret = regulator_enable(madc->usb3v1); in twl4030_madc_probe()
874 dev_err(madc->dev, "could not enable 3v1 bias regulator\n"); in twl4030_madc_probe()
887 regulator_disable(madc->usb3v1); in twl4030_madc_probe()
889 twl4030_madc_set_current_generator(madc, 0, 0); in twl4030_madc_probe()
891 twl4030_madc_set_power(madc, 0); in twl4030_madc_probe()
898 struct twl4030_madc_data *madc = iio_priv(iio_dev); in twl4030_madc_remove() local
902 twl4030_madc_set_current_generator(madc, 0, 0); in twl4030_madc_remove()
903 twl4030_madc_set_power(madc, 0); in twl4030_madc_remove()
905 regulator_disable(madc->usb3v1); in twl4030_madc_remove()
912 { .compatible = "ti,twl4030-madc", },