xref: /openbmc/linux/drivers/iio/adc/sd_adc_modulator.c (revision 4b4193256c8d3bc3a5397b5cd9494c2ad386317d)
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