18a5f0b6fSArnaud Pouliquen // SPDX-License-Identifier: GPL-2.0
28a5f0b6fSArnaud Pouliquen /*
38a5f0b6fSArnaud Pouliquen * Generic sigma delta modulator driver
48a5f0b6fSArnaud Pouliquen *
58a5f0b6fSArnaud Pouliquen * Copyright (C) 2017, STMicroelectronics - All Rights Reserved
68a5f0b6fSArnaud Pouliquen * Author: Arnaud Pouliquen <arnaud.pouliquen@st.com>.
78a5f0b6fSArnaud Pouliquen */
88a5f0b6fSArnaud Pouliquen
98a5f0b6fSArnaud Pouliquen #include <linux/iio/iio.h>
108a5f0b6fSArnaud Pouliquen #include <linux/iio/triggered_buffer.h>
118a5f0b6fSArnaud Pouliquen #include <linux/module.h>
12*34eb7366SJonathan Cameron #include <linux/mod_devicetable.h>
13*34eb7366SJonathan Cameron #include <linux/platform_device.h>
148a5f0b6fSArnaud Pouliquen
158a5f0b6fSArnaud Pouliquen static const struct iio_info iio_sd_mod_iio_info;
168a5f0b6fSArnaud Pouliquen
178a5f0b6fSArnaud Pouliquen static const struct iio_chan_spec iio_sd_mod_ch = {
188a5f0b6fSArnaud Pouliquen .type = IIO_VOLTAGE,
198a5f0b6fSArnaud Pouliquen .indexed = 1,
208a5f0b6fSArnaud Pouliquen .scan_type = {
218a5f0b6fSArnaud Pouliquen .sign = 'u',
228a5f0b6fSArnaud Pouliquen .realbits = 1,
238a5f0b6fSArnaud Pouliquen .shift = 0,
248a5f0b6fSArnaud Pouliquen },
258a5f0b6fSArnaud Pouliquen };
268a5f0b6fSArnaud Pouliquen
iio_sd_mod_probe(struct platform_device * pdev)278a5f0b6fSArnaud Pouliquen static int iio_sd_mod_probe(struct platform_device *pdev)
288a5f0b6fSArnaud Pouliquen {
298a5f0b6fSArnaud Pouliquen struct device *dev = &pdev->dev;
308a5f0b6fSArnaud Pouliquen struct iio_dev *iio;
318a5f0b6fSArnaud Pouliquen
328a5f0b6fSArnaud Pouliquen iio = devm_iio_device_alloc(dev, 0);
338a5f0b6fSArnaud Pouliquen if (!iio)
348a5f0b6fSArnaud Pouliquen return -ENOMEM;
358a5f0b6fSArnaud Pouliquen
368a5f0b6fSArnaud Pouliquen iio->name = dev_name(dev);
378a5f0b6fSArnaud Pouliquen iio->info = &iio_sd_mod_iio_info;
388a5f0b6fSArnaud Pouliquen iio->modes = INDIO_BUFFER_HARDWARE;
398a5f0b6fSArnaud Pouliquen
408a5f0b6fSArnaud Pouliquen iio->num_channels = 1;
418a5f0b6fSArnaud Pouliquen iio->channels = &iio_sd_mod_ch;
428a5f0b6fSArnaud Pouliquen
438a5f0b6fSArnaud Pouliquen platform_set_drvdata(pdev, iio);
448a5f0b6fSArnaud Pouliquen
458a5f0b6fSArnaud Pouliquen return devm_iio_device_register(&pdev->dev, iio);
468a5f0b6fSArnaud Pouliquen }
478a5f0b6fSArnaud Pouliquen
488a5f0b6fSArnaud Pouliquen static const struct of_device_id sd_adc_of_match[] = {
498a5f0b6fSArnaud Pouliquen { .compatible = "sd-modulator" },
508a5f0b6fSArnaud Pouliquen { .compatible = "ads1201" },
518a5f0b6fSArnaud Pouliquen { }
528a5f0b6fSArnaud Pouliquen };
538a5f0b6fSArnaud Pouliquen MODULE_DEVICE_TABLE(of, sd_adc_of_match);
548a5f0b6fSArnaud Pouliquen
558a5f0b6fSArnaud Pouliquen static struct platform_driver iio_sd_mod_adc = {
568a5f0b6fSArnaud Pouliquen .driver = {
578a5f0b6fSArnaud Pouliquen .name = "iio_sd_adc_mod",
58*34eb7366SJonathan Cameron .of_match_table = sd_adc_of_match,
598a5f0b6fSArnaud Pouliquen },
608a5f0b6fSArnaud Pouliquen .probe = iio_sd_mod_probe,
618a5f0b6fSArnaud Pouliquen };
628a5f0b6fSArnaud Pouliquen
638a5f0b6fSArnaud Pouliquen module_platform_driver(iio_sd_mod_adc);
648a5f0b6fSArnaud Pouliquen
658a5f0b6fSArnaud Pouliquen MODULE_DESCRIPTION("Basic sigma delta modulator");
668a5f0b6fSArnaud Pouliquen MODULE_AUTHOR("Arnaud Pouliquen <arnaud.pouliquen@st.com>");
678a5f0b6fSArnaud Pouliquen MODULE_LICENSE("GPL v2");
68