Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   1) // SPDX-License-Identifier: GPL-2.0-only
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   3)  * Copyright (C) 2013 Oskar Andero <oskar.andero@gmail.com>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   4)  * Copyright (C) 2014 Rose Technology
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   5)  * 	   Allan Bendorff Jensen <abj@rosetechnology.dk>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   6)  *	   Soren Andersen <san@rosetechnology.dk>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   7)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   8)  * Driver for following ADC chips from Microchip Technology's:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300   9)  * 10 Bit converter
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  10)  * MCP3001
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  11)  * MCP3002
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  12)  * MCP3004
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  13)  * MCP3008
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  14)  * ------------
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  15)  * 12 bit converter
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  16)  * MCP3201
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  17)  * MCP3202
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  18)  * MCP3204
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  19)  * MCP3208
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  20)  * ------------
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  21)  * 13 bit converter
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  22)  * MCP3301
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  23)  * ------------
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  24)  * 22 bit converter
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  25)  * MCP3550
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  26)  * MCP3551
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  27)  * MCP3553
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  28)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  29)  * Datasheet can be found here:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  30)  * https://ww1.microchip.com/downloads/en/DeviceDoc/21293C.pdf  mcp3001
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  31)  * https://ww1.microchip.com/downloads/en/DeviceDoc/21294E.pdf  mcp3002
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  32)  * https://ww1.microchip.com/downloads/en/DeviceDoc/21295d.pdf  mcp3004/08
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  33)  * http://ww1.microchip.com/downloads/en/DeviceDoc/21290D.pdf  mcp3201
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  34)  * http://ww1.microchip.com/downloads/en/DeviceDoc/21034D.pdf  mcp3202
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  35)  * http://ww1.microchip.com/downloads/en/DeviceDoc/21298c.pdf  mcp3204/08
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  36)  * https://ww1.microchip.com/downloads/en/DeviceDoc/21700E.pdf  mcp3301
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  37)  * http://ww1.microchip.com/downloads/en/DeviceDoc/21950D.pdf  mcp3550/1/3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  38)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  39) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  40) #include <linux/err.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  41) #include <linux/delay.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  42) #include <linux/spi/spi.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  43) #include <linux/module.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  44) #include <linux/mod_devicetable.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  45) #include <linux/iio/iio.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  46) #include <linux/regulator/consumer.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  47) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  48) enum {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  49) 	mcp3001,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  50) 	mcp3002,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  51) 	mcp3004,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  52) 	mcp3008,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  53) 	mcp3201,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  54) 	mcp3202,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  55) 	mcp3204,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  56) 	mcp3208,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  57) 	mcp3301,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  58) 	mcp3550_50,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  59) 	mcp3550_60,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  60) 	mcp3551,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  61) 	mcp3553,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  62) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  63) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  64) struct mcp320x_chip_info {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  65) 	const struct iio_chan_spec *channels;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  66) 	unsigned int num_channels;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  67) 	unsigned int resolution;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  68) 	unsigned int conv_time; /* usec */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  69) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  70) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  71) /**
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  72)  * struct mcp320x - Microchip SPI ADC instance
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  73)  * @spi: SPI slave (parent of the IIO device)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  74)  * @msg: SPI message to select a channel and receive a value from the ADC
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  75)  * @transfer: SPI transfers used by @msg
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  76)  * @start_conv_msg: SPI message to start a conversion by briefly asserting CS
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  77)  * @start_conv_transfer: SPI transfer used by @start_conv_msg
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  78)  * @reg: regulator generating Vref
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  79)  * @lock: protects read sequences
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  80)  * @chip_info: ADC properties
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  81)  * @tx_buf: buffer for @transfer[0] (not used on single-channel converters)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  82)  * @rx_buf: buffer for @transfer[1]
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  83)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  84) struct mcp320x {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  85) 	struct spi_device *spi;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  86) 	struct spi_message msg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  87) 	struct spi_transfer transfer[2];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  88) 	struct spi_message start_conv_msg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  89) 	struct spi_transfer start_conv_transfer;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  90) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  91) 	struct regulator *reg;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  92) 	struct mutex lock;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  93) 	const struct mcp320x_chip_info *chip_info;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  94) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  95) 	u8 tx_buf ____cacheline_aligned;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  96) 	u8 rx_buf[4];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  97) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  98) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  99) static int mcp320x_channel_to_tx_data(int device_index,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 100) 			const unsigned int channel, bool differential)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 101) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 102) 	int start_bit = 1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 103) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 104) 	switch (device_index) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 105) 	case mcp3002:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 106) 	case mcp3202:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 107) 		return ((start_bit << 4) | (!differential << 3) |
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 108) 							(channel << 2));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 109) 	case mcp3004:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 110) 	case mcp3204:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 111) 	case mcp3008:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 112) 	case mcp3208:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 113) 		return ((start_bit << 6) | (!differential << 5) |
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 114) 							(channel << 2));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 115) 	default:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 116) 		return -EINVAL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 117) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 118) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 119) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 120) static int mcp320x_adc_conversion(struct mcp320x *adc, u8 channel,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 121) 				  bool differential, int device_index, int *val)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 122) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 123) 	int ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 124) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 125) 	if (adc->chip_info->conv_time) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 126) 		ret = spi_sync(adc->spi, &adc->start_conv_msg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 127) 		if (ret < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 128) 			return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 129) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 130) 		usleep_range(adc->chip_info->conv_time,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 131) 			     adc->chip_info->conv_time + 100);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 132) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 133) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 134) 	memset(&adc->rx_buf, 0, sizeof(adc->rx_buf));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 135) 	if (adc->chip_info->num_channels > 1)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 136) 		adc->tx_buf = mcp320x_channel_to_tx_data(device_index, channel,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 137) 							 differential);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 138) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 139) 	ret = spi_sync(adc->spi, &adc->msg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 140) 	if (ret < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 141) 		return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 142) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 143) 	switch (device_index) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 144) 	case mcp3001:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 145) 		*val = (adc->rx_buf[0] << 5 | adc->rx_buf[1] >> 3);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 146) 		return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 147) 	case mcp3002:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 148) 	case mcp3004:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 149) 	case mcp3008:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 150) 		*val = (adc->rx_buf[0] << 2 | adc->rx_buf[1] >> 6);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 151) 		return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 152) 	case mcp3201:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 153) 		*val = (adc->rx_buf[0] << 7 | adc->rx_buf[1] >> 1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 154) 		return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 155) 	case mcp3202:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 156) 	case mcp3204:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 157) 	case mcp3208:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 158) 		*val = (adc->rx_buf[0] << 4 | adc->rx_buf[1] >> 4);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 159) 		return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 160) 	case mcp3301:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 161) 		*val = sign_extend32((adc->rx_buf[0] & 0x1f) << 8
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 162) 				    | adc->rx_buf[1], 12);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 163) 		return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 164) 	case mcp3550_50:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 165) 	case mcp3550_60:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 166) 	case mcp3551:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 167) 	case mcp3553: {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 168) 		u32 raw = be32_to_cpup((__be32 *)adc->rx_buf);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 169) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 170) 		if (!(adc->spi->mode & SPI_CPOL))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 171) 			raw <<= 1; /* strip Data Ready bit in SPI mode 0,0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 172) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 173) 		/*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 174) 		 * If the input is within -vref and vref, bit 21 is the sign.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 175) 		 * Up to 12% overrange or underrange are allowed, in which case
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 176) 		 * bit 23 is the sign and bit 0 to 21 is the value.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 177) 		 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 178) 		raw >>= 8;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 179) 		if (raw & BIT(22) && raw & BIT(23))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 180) 			return -EIO; /* cannot have overrange AND underrange */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 181) 		else if (raw & BIT(22))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 182) 			raw &= ~BIT(22); /* overrange */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 183) 		else if (raw & BIT(23) || raw & BIT(21))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 184) 			raw |= GENMASK(31, 22); /* underrange or negative */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 185) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 186) 		*val = (s32)raw;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 187) 		return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 188) 		}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 189) 	default:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 190) 		return -EINVAL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 191) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 192) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 193) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 194) static int mcp320x_read_raw(struct iio_dev *indio_dev,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 195) 			    struct iio_chan_spec const *channel, int *val,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 196) 			    int *val2, long mask)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 197) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 198) 	struct mcp320x *adc = iio_priv(indio_dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 199) 	int ret = -EINVAL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 200) 	int device_index = 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 201) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 202) 	mutex_lock(&adc->lock);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 203) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 204) 	device_index = spi_get_device_id(adc->spi)->driver_data;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 205) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 206) 	switch (mask) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 207) 	case IIO_CHAN_INFO_RAW:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 208) 		ret = mcp320x_adc_conversion(adc, channel->address,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 209) 			channel->differential, device_index, val);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 210) 		if (ret < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 211) 			goto out;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 212) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 213) 		ret = IIO_VAL_INT;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 214) 		break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 215) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 216) 	case IIO_CHAN_INFO_SCALE:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 217) 		ret = regulator_get_voltage(adc->reg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 218) 		if (ret < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 219) 			goto out;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 220) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 221) 		/* convert regulator output voltage to mV */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 222) 		*val = ret / 1000;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 223) 		*val2 = adc->chip_info->resolution;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 224) 		ret = IIO_VAL_FRACTIONAL_LOG2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 225) 		break;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 226) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 227) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 228) out:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 229) 	mutex_unlock(&adc->lock);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 230) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 231) 	return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 232) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 233) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 234) #define MCP320X_VOLTAGE_CHANNEL(num)				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 235) 	{							\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 236) 		.type = IIO_VOLTAGE,				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 237) 		.indexed = 1,					\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 238) 		.channel = (num),				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 239) 		.address = (num),				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 240) 		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),	\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 241) 		.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 242) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 243) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 244) #define MCP320X_VOLTAGE_CHANNEL_DIFF(chan1, chan2)		\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 245) 	{							\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 246) 		.type = IIO_VOLTAGE,				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 247) 		.indexed = 1,					\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 248) 		.channel = (chan1),				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 249) 		.channel2 = (chan2),				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 250) 		.address = (chan1),				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 251) 		.differential = 1,				\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 252) 		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),	\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 253) 		.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 254) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 255) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 256) static const struct iio_chan_spec mcp3201_channels[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 257) 	MCP320X_VOLTAGE_CHANNEL_DIFF(0, 1),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 258) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 259) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 260) static const struct iio_chan_spec mcp3202_channels[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 261) 	MCP320X_VOLTAGE_CHANNEL(0),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 262) 	MCP320X_VOLTAGE_CHANNEL(1),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 263) 	MCP320X_VOLTAGE_CHANNEL_DIFF(0, 1),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 264) 	MCP320X_VOLTAGE_CHANNEL_DIFF(1, 0),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 265) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 266) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 267) static const struct iio_chan_spec mcp3204_channels[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 268) 	MCP320X_VOLTAGE_CHANNEL(0),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 269) 	MCP320X_VOLTAGE_CHANNEL(1),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 270) 	MCP320X_VOLTAGE_CHANNEL(2),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 271) 	MCP320X_VOLTAGE_CHANNEL(3),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 272) 	MCP320X_VOLTAGE_CHANNEL_DIFF(0, 1),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 273) 	MCP320X_VOLTAGE_CHANNEL_DIFF(1, 0),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 274) 	MCP320X_VOLTAGE_CHANNEL_DIFF(2, 3),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 275) 	MCP320X_VOLTAGE_CHANNEL_DIFF(3, 2),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 276) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 277) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 278) static const struct iio_chan_spec mcp3208_channels[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 279) 	MCP320X_VOLTAGE_CHANNEL(0),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 280) 	MCP320X_VOLTAGE_CHANNEL(1),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 281) 	MCP320X_VOLTAGE_CHANNEL(2),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 282) 	MCP320X_VOLTAGE_CHANNEL(3),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 283) 	MCP320X_VOLTAGE_CHANNEL(4),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 284) 	MCP320X_VOLTAGE_CHANNEL(5),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 285) 	MCP320X_VOLTAGE_CHANNEL(6),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 286) 	MCP320X_VOLTAGE_CHANNEL(7),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 287) 	MCP320X_VOLTAGE_CHANNEL_DIFF(0, 1),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 288) 	MCP320X_VOLTAGE_CHANNEL_DIFF(1, 0),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 289) 	MCP320X_VOLTAGE_CHANNEL_DIFF(2, 3),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 290) 	MCP320X_VOLTAGE_CHANNEL_DIFF(3, 2),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 291) 	MCP320X_VOLTAGE_CHANNEL_DIFF(4, 5),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 292) 	MCP320X_VOLTAGE_CHANNEL_DIFF(5, 4),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 293) 	MCP320X_VOLTAGE_CHANNEL_DIFF(6, 7),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 294) 	MCP320X_VOLTAGE_CHANNEL_DIFF(7, 6),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 295) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 296) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 297) static const struct iio_info mcp320x_info = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 298) 	.read_raw = mcp320x_read_raw,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 299) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 300) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 301) static const struct mcp320x_chip_info mcp320x_chip_infos[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 302) 	[mcp3001] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 303) 		.channels = mcp3201_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 304) 		.num_channels = ARRAY_SIZE(mcp3201_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 305) 		.resolution = 10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 306) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 307) 	[mcp3002] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 308) 		.channels = mcp3202_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 309) 		.num_channels = ARRAY_SIZE(mcp3202_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 310) 		.resolution = 10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 311) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 312) 	[mcp3004] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 313) 		.channels = mcp3204_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 314) 		.num_channels = ARRAY_SIZE(mcp3204_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 315) 		.resolution = 10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 316) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 317) 	[mcp3008] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 318) 		.channels = mcp3208_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 319) 		.num_channels = ARRAY_SIZE(mcp3208_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 320) 		.resolution = 10
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 321) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 322) 	[mcp3201] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 323) 		.channels = mcp3201_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 324) 		.num_channels = ARRAY_SIZE(mcp3201_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 325) 		.resolution = 12
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 326) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 327) 	[mcp3202] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 328) 		.channels = mcp3202_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 329) 		.num_channels = ARRAY_SIZE(mcp3202_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 330) 		.resolution = 12
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 331) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 332) 	[mcp3204] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 333) 		.channels = mcp3204_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 334) 		.num_channels = ARRAY_SIZE(mcp3204_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 335) 		.resolution = 12
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 336) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 337) 	[mcp3208] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 338) 		.channels = mcp3208_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 339) 		.num_channels = ARRAY_SIZE(mcp3208_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 340) 		.resolution = 12
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 341) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 342) 	[mcp3301] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 343) 		.channels = mcp3201_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 344) 		.num_channels = ARRAY_SIZE(mcp3201_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 345) 		.resolution = 13
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 346) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 347) 	[mcp3550_50] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 348) 		.channels = mcp3201_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 349) 		.num_channels = ARRAY_SIZE(mcp3201_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 350) 		.resolution = 21,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 351) 		/* 2% max deviation + 144 clock periods to exit shutdown */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 352) 		.conv_time = 80000 * 1.02 + 144000 / 102.4,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 353) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 354) 	[mcp3550_60] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 355) 		.channels = mcp3201_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 356) 		.num_channels = ARRAY_SIZE(mcp3201_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 357) 		.resolution = 21,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 358) 		.conv_time = 66670 * 1.02 + 144000 / 122.88,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 359) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 360) 	[mcp3551] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 361) 		.channels = mcp3201_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 362) 		.num_channels = ARRAY_SIZE(mcp3201_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 363) 		.resolution = 21,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 364) 		.conv_time = 73100 * 1.02 + 144000 / 112.64,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 365) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 366) 	[mcp3553] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 367) 		.channels = mcp3201_channels,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 368) 		.num_channels = ARRAY_SIZE(mcp3201_channels),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 369) 		.resolution = 21,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 370) 		.conv_time = 16670 * 1.02 + 144000 / 122.88,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 371) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 372) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 373) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 374) static int mcp320x_probe(struct spi_device *spi)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 375) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 376) 	struct iio_dev *indio_dev;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 377) 	struct mcp320x *adc;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 378) 	const struct mcp320x_chip_info *chip_info;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 379) 	int ret, device_index;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 380) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 381) 	indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*adc));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 382) 	if (!indio_dev)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 383) 		return -ENOMEM;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 384) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 385) 	adc = iio_priv(indio_dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 386) 	adc->spi = spi;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 387) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 388) 	indio_dev->name = spi_get_device_id(spi)->name;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 389) 	indio_dev->modes = INDIO_DIRECT_MODE;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 390) 	indio_dev->info = &mcp320x_info;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 391) 	spi_set_drvdata(spi, indio_dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 392) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 393) 	device_index = spi_get_device_id(spi)->driver_data;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 394) 	chip_info = &mcp320x_chip_infos[device_index];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 395) 	indio_dev->channels = chip_info->channels;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 396) 	indio_dev->num_channels = chip_info->num_channels;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 397) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 398) 	adc->chip_info = chip_info;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 399) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 400) 	adc->transfer[0].tx_buf = &adc->tx_buf;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 401) 	adc->transfer[0].len = sizeof(adc->tx_buf);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 402) 	adc->transfer[1].rx_buf = adc->rx_buf;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 403) 	adc->transfer[1].len = DIV_ROUND_UP(chip_info->resolution, 8);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 404) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 405) 	if (chip_info->num_channels == 1)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 406) 		/* single-channel converters are rx only (no MOSI pin) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 407) 		spi_message_init_with_transfers(&adc->msg,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 408) 						&adc->transfer[1], 1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 409) 	else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 410) 		spi_message_init_with_transfers(&adc->msg, adc->transfer,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 411) 						ARRAY_SIZE(adc->transfer));
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 412) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 413) 	switch (device_index) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 414) 	case mcp3550_50:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 415) 	case mcp3550_60:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 416) 	case mcp3551:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 417) 	case mcp3553:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 418) 		/* rx len increases from 24 to 25 bit in SPI mode 0,0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 419) 		if (!(spi->mode & SPI_CPOL))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 420) 			adc->transfer[1].len++;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 421) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 422) 		/* conversions are started by asserting CS pin for 8 usec */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 423) 		adc->start_conv_transfer.delay.value = 8;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 424) 		adc->start_conv_transfer.delay.unit = SPI_DELAY_UNIT_USECS;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 425) 		spi_message_init_with_transfers(&adc->start_conv_msg,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 426) 						&adc->start_conv_transfer, 1);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 427) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 428) 		/*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 429) 		 * If CS was previously kept low (continuous conversion mode)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 430) 		 * and then changed to high, the chip is in shutdown.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 431) 		 * Sometimes it fails to wake from shutdown and clocks out
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 432) 		 * only 0xffffff.  The magic sequence of performing two
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 433) 		 * conversions without delay between them resets the chip
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 434) 		 * and ensures all subsequent conversions succeed.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 435) 		 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 436) 		mcp320x_adc_conversion(adc, 0, 1, device_index, &ret);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 437) 		mcp320x_adc_conversion(adc, 0, 1, device_index, &ret);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 438) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 439) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 440) 	adc->reg = devm_regulator_get(&spi->dev, "vref");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 441) 	if (IS_ERR(adc->reg))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 442) 		return PTR_ERR(adc->reg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 443) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 444) 	ret = regulator_enable(adc->reg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 445) 	if (ret < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 446) 		return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 447) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 448) 	mutex_init(&adc->lock);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 449) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 450) 	ret = iio_device_register(indio_dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 451) 	if (ret < 0)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 452) 		goto reg_disable;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 453) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 454) 	return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 455) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 456) reg_disable:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 457) 	regulator_disable(adc->reg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 458) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 459) 	return ret;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 460) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 461) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 462) static int mcp320x_remove(struct spi_device *spi)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 463) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 464) 	struct iio_dev *indio_dev = spi_get_drvdata(spi);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 465) 	struct mcp320x *adc = iio_priv(indio_dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 466) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 467) 	iio_device_unregister(indio_dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 468) 	regulator_disable(adc->reg);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 469) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 470) 	return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 471) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 472) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 473) static const struct of_device_id mcp320x_dt_ids[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 474) 	/* NOTE: The use of compatibles with no vendor prefix is deprecated. */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 475) 	{ .compatible = "mcp3001" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 476) 	{ .compatible = "mcp3002" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 477) 	{ .compatible = "mcp3004" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 478) 	{ .compatible = "mcp3008" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 479) 	{ .compatible = "mcp3201" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 480) 	{ .compatible = "mcp3202" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 481) 	{ .compatible = "mcp3204" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 482) 	{ .compatible = "mcp3208" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 483) 	{ .compatible = "mcp3301" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 484) 	{ .compatible = "microchip,mcp3001" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 485) 	{ .compatible = "microchip,mcp3002" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 486) 	{ .compatible = "microchip,mcp3004" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 487) 	{ .compatible = "microchip,mcp3008" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 488) 	{ .compatible = "microchip,mcp3201" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 489) 	{ .compatible = "microchip,mcp3202" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 490) 	{ .compatible = "microchip,mcp3204" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 491) 	{ .compatible = "microchip,mcp3208" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 492) 	{ .compatible = "microchip,mcp3301" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 493) 	{ .compatible = "microchip,mcp3550-50" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 494) 	{ .compatible = "microchip,mcp3550-60" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 495) 	{ .compatible = "microchip,mcp3551" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 496) 	{ .compatible = "microchip,mcp3553" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 497) 	{ }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 498) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 499) MODULE_DEVICE_TABLE(of, mcp320x_dt_ids);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 500) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 501) static const struct spi_device_id mcp320x_id[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 502) 	{ "mcp3001", mcp3001 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 503) 	{ "mcp3002", mcp3002 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 504) 	{ "mcp3004", mcp3004 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 505) 	{ "mcp3008", mcp3008 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 506) 	{ "mcp3201", mcp3201 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 507) 	{ "mcp3202", mcp3202 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 508) 	{ "mcp3204", mcp3204 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 509) 	{ "mcp3208", mcp3208 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 510) 	{ "mcp3301", mcp3301 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 511) 	{ "mcp3550-50", mcp3550_50 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 512) 	{ "mcp3550-60", mcp3550_60 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 513) 	{ "mcp3551", mcp3551 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 514) 	{ "mcp3553", mcp3553 },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 515) 	{ }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 516) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 517) MODULE_DEVICE_TABLE(spi, mcp320x_id);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 518) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 519) static struct spi_driver mcp320x_driver = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 520) 	.driver = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 521) 		.name = "mcp320x",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 522) 		.of_match_table = mcp320x_dt_ids,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 523) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 524) 	.probe = mcp320x_probe,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 525) 	.remove = mcp320x_remove,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 526) 	.id_table = mcp320x_id,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 527) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 528) module_spi_driver(mcp320x_driver);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 529) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 530) MODULE_AUTHOR("Oskar Andero <oskar.andero@gmail.com>");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 531) MODULE_DESCRIPTION("Microchip Technology MCP3x01/02/04/08 and MCP3550/1/3");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 532) MODULE_LICENSE("GPL v2");