Linux Audio

Check our new training course

Loading...
Note: File does not exist in v3.1.
   1// SPDX-License-Identifier: GPL-2.0
   2/*
   3 * ad2s1210.c support for the ADI Resolver to Digital Converters: AD2S1210
   4 *
   5 * Copyright (c) 2010-2010 Analog Devices Inc.
   6 * Copyright (c) 2023 BayLibre, SAS
   7 *
   8 * Device register to IIO ABI mapping:
   9 *
  10 * Register                    | Addr | IIO ABI (sysfs)
  11 * ----------------------------|------|-------------------------------------------
  12 * DOS Overrange Threshold     | 0x89 | events/in_altvoltage0_thresh_rising_value
  13 * DOS Mismatch Threshold      | 0x8A | events/in_altvoltage0_mag_rising_value
  14 * DOS Reset Maximum Threshold | 0x8B | events/in_altvoltage0_mag_rising_reset_max
  15 * DOS Reset Minimum Threshold | 0x8C | events/in_altvoltage0_mag_rising_reset_min
  16 * LOT High Threshold          | 0x8D | events/in_angl1_thresh_rising_value
  17 * LOT Low Threshold [1]       | 0x8E | events/in_angl1_thresh_rising_hysteresis
  18 * Excitation Frequency        | 0x91 | out_altvoltage0_frequency
  19 * Control                     | 0x92 | *as bit fields*
  20 *   Phase lock range          | D5   | events/in_phase0_mag_rising_value
  21 *   Hysteresis                | D4   | in_angl0_hysteresis
  22 *   Encoder resolution        | D3:2 | *not implemented*
  23 *   Resolution                | D1:0 | *device tree: assigned-resolution-bits*
  24 * Soft Reset                  | 0xF0 | [2]
  25 * Fault                       | 0xFF | *not implemented*
  26 *
  27 * [1]: The value written to the LOT low register is high value minus the
  28 * hysteresis.
  29 * [2]: Soft reset is performed when `out_altvoltage0_frequency` is written.
  30 *
  31 * Fault to event mapping:
  32 *
  33 * Fault                                   |    | Channel     | Type   | Direction
  34 * ----------------------------------------|----|---------------------------------
  35 * Sine/cosine inputs clipped [3]          | D7 | altvoltage1 | mag    | either
  36 * Sine/cosine inputs below LOS            | D6 | altvoltage0 | thresh | falling
  37 * Sine/cosine inputs exceed DOS overrange | D5 | altvoltage0 | thresh | rising
  38 * Sine/cosine inputs exceed DOS mismatch  | D4 | altvoltage0 | mag    | rising
  39 * Tracking error exceeds LOT              | D3 | angl1       | thresh | rising
  40 * Velocity exceeds maximum tracking rate  | D2 | anglvel0    | mag    | rising
  41 * Phase error exceeds phase lock range    | D1 | phase0      | mag    | rising
  42 * Configuration parity error              | D0 | *writes to kernel log*
  43 *
  44 * [3]: The chip does not differentiate between fault on sine vs. cosine so
  45 * there will also be an event on the altvoltage2 channel.
  46 */
  47
  48#include <linux/bitfield.h>
  49#include <linux/bits.h>
  50#include <linux/cleanup.h>
  51#include <linux/clk.h>
  52#include <linux/delay.h>
  53#include <linux/device.h>
  54#include <linux/gpio/consumer.h>
  55#include <linux/module.h>
  56#include <linux/mutex.h>
  57#include <linux/regmap.h>
  58#include <linux/slab.h>
  59#include <linux/spi/spi.h>
  60#include <linux/sysfs.h>
  61#include <linux/types.h>
  62
  63#include <linux/iio/buffer.h>
  64#include <linux/iio/events.h>
  65#include <linux/iio/iio.h>
  66#include <linux/iio/sysfs.h>
  67#include <linux/iio/trigger_consumer.h>
  68#include <linux/iio/triggered_buffer.h>
  69
  70/* control register flags */
  71#define AD2S1210_ADDRESS_DATA		BIT(7)
  72#define AD2S1210_PHASE_LOCK_RANGE_44	BIT(5)
  73#define AD2S1210_ENABLE_HYSTERESIS	BIT(4)
  74#define AD2S1210_SET_ENRES		GENMASK(3, 2)
  75#define AD2S1210_SET_RES		GENMASK(1, 0)
  76
  77/* fault register flags */
  78#define AD2S1210_FAULT_CLIP		BIT(7)
  79#define AD2S1210_FAULT_LOS		BIT(6)
  80#define AD2S1210_FAULT_DOS_OVR		BIT(5)
  81#define AD2S1210_FAULT_DOS_MIS		BIT(4)
  82#define AD2S1210_FAULT_LOT		BIT(3)
  83#define AD2S1210_FAULT_VELOCITY		BIT(2)
  84#define AD2S1210_FAULT_PHASE		BIT(1)
  85#define AD2S1210_FAULT_CONFIG_PARITY	BIT(0)
  86
  87#define AD2S1210_REG_POSITION_MSB	0x80
  88#define AD2S1210_REG_POSITION_LSB	0x81
  89#define AD2S1210_REG_VELOCITY_MSB	0x82
  90#define AD2S1210_REG_VELOCITY_LSB	0x83
  91#define AD2S1210_REG_LOS_THRD		0x88
  92#define AD2S1210_REG_DOS_OVR_THRD	0x89
  93#define AD2S1210_REG_DOS_MIS_THRD	0x8A
  94#define AD2S1210_REG_DOS_RST_MAX_THRD	0x8B
  95#define AD2S1210_REG_DOS_RST_MIN_THRD	0x8C
  96#define AD2S1210_REG_LOT_HIGH_THRD	0x8D
  97#define AD2S1210_REG_LOT_LOW_THRD	0x8E
  98#define AD2S1210_REG_EXCIT_FREQ		0x91
  99#define AD2S1210_REG_CONTROL		0x92
 100#define AD2S1210_REG_SOFT_RESET		0xF0
 101#define AD2S1210_REG_FAULT		0xFF
 102
 103#define AD2S1210_MIN_CLKIN	6144000
 104#define AD2S1210_MAX_CLKIN	10240000
 105#define AD2S1210_MIN_EXCIT	2000
 106#define AD2S1210_DEF_EXCIT	10000
 107#define AD2S1210_MAX_EXCIT	20000
 108#define AD2S1210_MIN_FCW	0x4
 109#define AD2S1210_MAX_FCW	0x50
 110
 111/* 44 degrees ~= 0.767945 radians */
 112#define PHASE_44_DEG_TO_RAD_INT 0
 113#define PHASE_44_DEG_TO_RAD_MICRO 767945
 114/* 360 degrees ~= 6.283185 radians */
 115#define PHASE_360_DEG_TO_RAD_INT 6
 116#define PHASE_360_DEG_TO_RAD_MICRO 283185
 117
 118/* Threshold voltage registers have 1 LSB == 38 mV */
 119#define THRESHOLD_MILLIVOLT_PER_LSB 38
 120/* max voltage for threshold registers is 0x7F * 38 mV */
 121#define THRESHOLD_RANGE_STR "[0 38 4826]"
 122
 123#define FAULT_ONESHOT(bit, new, old) (new & bit && !(old & bit))
 124
 125enum ad2s1210_mode {
 126	MOD_POS = 0b00,
 127	MOD_VEL = 0b01,
 128	MOD_RESERVED = 0b10,
 129	MOD_CONFIG = 0b11,
 130};
 131
 132enum ad2s1210_resolution {
 133	AD2S1210_RES_10 = 0b00,
 134	AD2S1210_RES_12 = 0b01,
 135	AD2S1210_RES_14 = 0b10,
 136	AD2S1210_RES_16 = 0b11,
 137};
 138
 139struct ad2s1210_state {
 140	struct mutex lock;
 141	struct spi_device *sdev;
 142	/** GPIO pin connected to SAMPLE line. */
 143	struct gpio_desc *sample_gpio;
 144	/** GPIO pins connected to A0 and A1 lines (optional). */
 145	struct gpio_descs *mode_gpios;
 146	/** Used to access config registers. */
 147	struct regmap *regmap;
 148	/** The external oscillator frequency in Hz. */
 149	unsigned long clkin_hz;
 150	/** Available raw hysteresis values based on resolution. */
 151	int hysteresis_available[2];
 152	/* adi,fixed-mode property - only valid when mode_gpios == NULL. */
 153	enum ad2s1210_mode fixed_mode;
 154	/** The selected resolution */
 155	enum ad2s1210_resolution resolution;
 156	/** Copy of fault register from the previous read. */
 157	u8 prev_fault_flags;
 158	/** For reading raw sample value via SPI. */
 159	struct {
 160		__be16 raw;
 161		u8 fault;
 162	} sample __aligned(IIO_DMA_MINALIGN);
 163	/** Scan buffer */
 164	struct {
 165		__be16 chan[2];
 166		/* Ensure timestamp is naturally aligned. */
 167		s64 timestamp __aligned(8);
 168	} scan;
 169	/** SPI transmit buffer. */
 170	u8 rx[2];
 171	/** SPI receive buffer. */
 172	u8 tx[2];
 173};
 174
 175static int ad2s1210_set_mode(struct ad2s1210_state *st, enum ad2s1210_mode mode)
 176{
 177	struct gpio_descs *gpios = st->mode_gpios;
 178	DECLARE_BITMAP(bitmap, 2);
 179
 180	if (!gpios)
 181		return mode == st->fixed_mode ? 0 : -EOPNOTSUPP;
 182
 183	bitmap[0] = mode;
 184
 185	return gpiod_set_array_value(gpios->ndescs, gpios->desc, gpios->info,
 186				     bitmap);
 187}
 188
 189/*
 190 * Writes the given data to the given register address.
 191 *
 192 * If the mode is configurable, the device will first be placed in
 193 * configuration mode.
 194 */
 195static int ad2s1210_regmap_reg_write(void *context, unsigned int reg,
 196				     unsigned int val)
 197{
 198	struct ad2s1210_state *st = context;
 199	struct spi_transfer xfers[] = {
 200		{
 201			.len = 1,
 202			.rx_buf = &st->rx[0],
 203			.tx_buf = &st->tx[0],
 204			.cs_change = 1,
 205		}, {
 206			.len = 1,
 207			.rx_buf = &st->rx[1],
 208			.tx_buf = &st->tx[1],
 209		},
 210	};
 211	int ret;
 212
 213	/* values can only be 7 bits, the MSB indicates an address */
 214	if (val & ~0x7F)
 215		return -EINVAL;
 216
 217	st->tx[0] = reg;
 218	st->tx[1] = val;
 219
 220	ret = ad2s1210_set_mode(st, MOD_CONFIG);
 221	if (ret < 0)
 222		return ret;
 223
 224	ret = spi_sync_transfer(st->sdev, xfers, ARRAY_SIZE(xfers));
 225	if (ret < 0)
 226		return ret;
 227
 228	/* soft reset also clears the fault register */
 229	if (reg == AD2S1210_REG_SOFT_RESET)
 230		st->prev_fault_flags = 0;
 231
 232	return 0;
 233}
 234
 235/*
 236 * Reads value from one of the registers.
 237 *
 238 * If the mode is configurable, the device will first be placed in
 239 * configuration mode.
 240 */
 241static int ad2s1210_regmap_reg_read(void *context, unsigned int reg,
 242				    unsigned int *val)
 243{
 244	struct ad2s1210_state *st = context;
 245	struct spi_transfer xfers[] = {
 246		{
 247			.len = 1,
 248			.rx_buf = &st->rx[0],
 249			.tx_buf = &st->tx[0],
 250			.cs_change = 1,
 251		}, {
 252			.len = 1,
 253			.rx_buf = &st->rx[1],
 254			.tx_buf = &st->tx[1],
 255		},
 256	};
 257	int ret;
 258
 259	ret = ad2s1210_set_mode(st, MOD_CONFIG);
 260	if (ret < 0)
 261		return ret;
 262
 263	st->tx[0] = reg;
 264	/*
 265	 * Must be valid register address here otherwise this could write data.
 266	 * It doesn't matter which one as long as reading doesn't have side-
 267	 * effects.
 268	 */
 269	st->tx[1] = AD2S1210_REG_CONTROL;
 270
 271	ret = spi_sync_transfer(st->sdev, xfers, ARRAY_SIZE(xfers));
 272	if (ret < 0)
 273		return ret;
 274
 275	/* reading the fault register also clears it */
 276	if (reg == AD2S1210_REG_FAULT)
 277		st->prev_fault_flags = 0;
 278
 279	/*
 280	 * If the D7 bit is set on any read/write register, it indicates a
 281	 * parity error. The fault register is read-only and the D7 bit means
 282	 * something else there.
 283	 */
 284	if ((reg > AD2S1210_REG_VELOCITY_LSB && reg != AD2S1210_REG_FAULT)
 285	     && st->rx[1] & AD2S1210_ADDRESS_DATA)
 286		return -EBADMSG;
 287
 288	*val = st->rx[1];
 289
 290	return 0;
 291}
 292
 293/*
 294 * Toggles the SAMPLE line on the AD2S1210 to latch in the current position,
 295 * velocity, and faults.
 296 *
 297 * Must be called with lock held.
 298 */
 299static void ad2s1210_toggle_sample_line(struct ad2s1210_state *st)
 300{
 301	/*
 302	 * Datasheet specifies minimum hold time t16 = 2 * tck + 20 ns. So the
 303	 * longest time needed is when CLKIN is 6.144 MHz, in which case t16
 304	 * ~= 350 ns. The same delay is also needed before re-asserting the
 305	 * SAMPLE line.
 306	 */
 307	gpiod_set_value(st->sample_gpio, 1);
 308	ndelay(350);
 309	gpiod_set_value(st->sample_gpio, 0);
 310	ndelay(350);
 311}
 312
 313/*
 314 * Sets the excitation frequency and performs software reset.
 315 *
 316 * Must be called with lock held.
 317 */
 318static int ad2s1210_reinit_excitation_frequency(struct ad2s1210_state *st,
 319						u16 fexcit)
 320{
 321	/* Map resolution to settle time in milliseconds. */
 322	static const int track_time_ms[] = { 10, 20, 25, 60 };
 323	unsigned int ignored;
 324	int ret;
 325	u8 fcw;
 326
 327	fcw = fexcit * (1 << 15) / st->clkin_hz;
 328	if (fcw < AD2S1210_MIN_FCW || fcw > AD2S1210_MAX_FCW)
 329		return -ERANGE;
 330
 331	ret = regmap_write(st->regmap, AD2S1210_REG_EXCIT_FREQ, fcw);
 332	if (ret < 0)
 333		return ret;
 334
 335	/*
 336	 * Software reset reinitializes the excitation frequency output.
 337	 * It does not reset any of the configuration registers.
 338	 */
 339	ret = regmap_write(st->regmap, AD2S1210_REG_SOFT_RESET, 0);
 340	if (ret < 0)
 341		return ret;
 342
 343	/*
 344	 * Soft reset always triggers some faults due the change in the output
 345	 * signal so clear the faults too. We need to delay for some time
 346	 * (what datasheet calls t[track]) to allow things to settle before
 347	 * clearing the faults.
 348	 */
 349	msleep(track_time_ms[st->resolution] * 8192000 / st->clkin_hz);
 350
 351	/* Reading the fault register clears the faults. */
 352	ret = regmap_read(st->regmap, AD2S1210_REG_FAULT, &ignored);
 353	if (ret < 0)
 354		return ret;
 355
 356	/* Have to toggle sample line to get fault output pins to reset. */
 357	ad2s1210_toggle_sample_line(st);
 358
 359	return 0;
 360}
 361
 362static void ad2s1210_push_events(struct iio_dev *indio_dev,
 363				 u8 flags, s64 timestamp)
 364{
 365	struct ad2s1210_state *st = iio_priv(indio_dev);
 366
 367	/* Sine/cosine inputs clipped */
 368	if (FAULT_ONESHOT(AD2S1210_FAULT_CLIP, flags, st->prev_fault_flags)) {
 369		/*
 370		 * The chip does not differentiate between fault on sine vs.
 371		 * cosine channel so we just send an event on both channels.
 372		 */
 373		iio_push_event(indio_dev,
 374			       IIO_UNMOD_EVENT_CODE(IIO_ALTVOLTAGE, 1,
 375						    IIO_EV_TYPE_MAG,
 376						    IIO_EV_DIR_EITHER),
 377			       timestamp);
 378		iio_push_event(indio_dev,
 379			       IIO_UNMOD_EVENT_CODE(IIO_ALTVOLTAGE, 2,
 380						    IIO_EV_TYPE_MAG,
 381						    IIO_EV_DIR_EITHER),
 382			       timestamp);
 383	}
 384
 385	/* Sine/cosine inputs below LOS threshold */
 386	if (FAULT_ONESHOT(AD2S1210_FAULT_LOS, flags, st->prev_fault_flags))
 387		iio_push_event(indio_dev,
 388			       IIO_UNMOD_EVENT_CODE(IIO_ALTVOLTAGE, 0,
 389						    IIO_EV_TYPE_THRESH,
 390						    IIO_EV_DIR_FALLING),
 391			       timestamp);
 392
 393	/* Sine/cosine inputs exceed DOS overrange threshold */
 394	if (FAULT_ONESHOT(AD2S1210_FAULT_DOS_OVR, flags, st->prev_fault_flags))
 395		iio_push_event(indio_dev,
 396			       IIO_UNMOD_EVENT_CODE(IIO_ALTVOLTAGE, 0,
 397						    IIO_EV_TYPE_THRESH,
 398						    IIO_EV_DIR_RISING),
 399			       timestamp);
 400
 401	/* Sine/cosine inputs exceed DOS mismatch threshold */
 402	if (FAULT_ONESHOT(AD2S1210_FAULT_DOS_MIS, flags, st->prev_fault_flags))
 403		iio_push_event(indio_dev,
 404			       IIO_UNMOD_EVENT_CODE(IIO_ALTVOLTAGE, 0,
 405						    IIO_EV_TYPE_MAG,
 406						    IIO_EV_DIR_RISING),
 407			       timestamp);
 408
 409	/* Tracking error exceeds LOT threshold */
 410	if (FAULT_ONESHOT(AD2S1210_FAULT_LOT, flags, st->prev_fault_flags))
 411		iio_push_event(indio_dev,
 412			       IIO_UNMOD_EVENT_CODE(IIO_ANGL, 1,
 413						    IIO_EV_TYPE_THRESH,
 414						    IIO_EV_DIR_RISING),
 415			       timestamp);
 416
 417	/* Velocity exceeds maximum tracking rate */
 418	if (FAULT_ONESHOT(AD2S1210_FAULT_VELOCITY, flags, st->prev_fault_flags))
 419		iio_push_event(indio_dev,
 420			       IIO_UNMOD_EVENT_CODE(IIO_ANGL_VEL, 0,
 421						    IIO_EV_TYPE_THRESH,
 422						    IIO_EV_DIR_RISING),
 423			       timestamp);
 424
 425	/* Phase error exceeds phase lock range */
 426	if (FAULT_ONESHOT(AD2S1210_FAULT_PHASE, flags, st->prev_fault_flags))
 427		iio_push_event(indio_dev,
 428			       IIO_UNMOD_EVENT_CODE(IIO_PHASE, 0,
 429						    IIO_EV_TYPE_MAG,
 430						    IIO_EV_DIR_RISING),
 431			       timestamp);
 432
 433	/* Configuration parity error */
 434	if (FAULT_ONESHOT(AD2S1210_FAULT_CONFIG_PARITY, flags,
 435			  st->prev_fault_flags))
 436		/*
 437		 * Userspace should also get notified of this via error return
 438		 * when trying to write to any attribute that writes a register.
 439		 */
 440		dev_err_ratelimited(&indio_dev->dev,
 441				    "Configuration parity error\n");
 442
 443	st->prev_fault_flags = flags;
 444}
 445
 446static int ad2s1210_single_conversion(struct iio_dev *indio_dev,
 447				      struct iio_chan_spec const *chan,
 448				      int *val)
 449{
 450	struct ad2s1210_state *st = iio_priv(indio_dev);
 451	s64 timestamp;
 452	int ret;
 453
 454	guard(mutex)(&st->lock);
 455
 456	ad2s1210_toggle_sample_line(st);
 457	timestamp = iio_get_time_ns(indio_dev);
 458
 459	if (st->fixed_mode == MOD_CONFIG) {
 460		unsigned int reg_val;
 461
 462		switch (chan->type) {
 463		case IIO_ANGL:
 464			ret = regmap_bulk_read(st->regmap,
 465					       AD2S1210_REG_POSITION_MSB,
 466					       &st->sample.raw, 2);
 467			if (ret < 0)
 468				return ret;
 469
 470			break;
 471		case IIO_ANGL_VEL:
 472			ret = regmap_bulk_read(st->regmap,
 473					       AD2S1210_REG_VELOCITY_MSB,
 474					       &st->sample.raw, 2);
 475			if (ret < 0)
 476				return ret;
 477
 478			break;
 479		default:
 480			return -EINVAL;
 481		}
 482
 483		ret = regmap_read(st->regmap, AD2S1210_REG_FAULT, &reg_val);
 484		if (ret < 0)
 485			return ret;
 486
 487		st->sample.fault = reg_val;
 488	} else {
 489		switch (chan->type) {
 490		case IIO_ANGL:
 491			ret = ad2s1210_set_mode(st, MOD_POS);
 492			break;
 493		case IIO_ANGL_VEL:
 494			ret = ad2s1210_set_mode(st, MOD_VEL);
 495			break;
 496		default:
 497			return -EINVAL;
 498		}
 499		if (ret < 0)
 500			return ret;
 501
 502		ret = spi_read(st->sdev, &st->sample, 3);
 503		if (ret < 0)
 504			return ret;
 505	}
 506
 507	switch (chan->type) {
 508	case IIO_ANGL:
 509		*val = be16_to_cpu(st->sample.raw);
 510		ret = IIO_VAL_INT;
 511		break;
 512	case IIO_ANGL_VEL:
 513		*val = (s16)be16_to_cpu(st->sample.raw);
 514		ret = IIO_VAL_INT;
 515		break;
 516	default:
 517		return -EINVAL;
 518	}
 519
 520	ad2s1210_push_events(indio_dev, st->sample.fault, timestamp);
 521
 522	return ret;
 523}
 524
 525static int ad2s1210_get_hysteresis(struct ad2s1210_state *st, int *val)
 526{
 527	int ret;
 528
 529	guard(mutex)(&st->lock);
 530	ret = regmap_test_bits(st->regmap, AD2S1210_REG_CONTROL,
 531			       AD2S1210_ENABLE_HYSTERESIS);
 532	if (ret < 0)
 533		return ret;
 534
 535	*val = ret << (2 * (AD2S1210_RES_16 - st->resolution));
 536	return IIO_VAL_INT;
 537}
 538
 539static int ad2s1210_set_hysteresis(struct ad2s1210_state *st, int val)
 540{
 541	guard(mutex)(&st->lock);
 542	return regmap_update_bits(st->regmap, AD2S1210_REG_CONTROL,
 543				  AD2S1210_ENABLE_HYSTERESIS,
 544				  val ? AD2S1210_ENABLE_HYSTERESIS : 0);
 545}
 546
 547static int ad2s1210_get_phase_lock_range(struct ad2s1210_state *st,
 548					 int *val, int *val2)
 549{
 550	int ret;
 551
 552	guard(mutex)(&st->lock);
 553	ret = regmap_test_bits(st->regmap, AD2S1210_REG_CONTROL,
 554			       AD2S1210_PHASE_LOCK_RANGE_44);
 555	if (ret < 0)
 556		return ret;
 557
 558	if (ret) {
 559		/* 44 degrees as radians */
 560		*val = PHASE_44_DEG_TO_RAD_INT;
 561		*val2 = PHASE_44_DEG_TO_RAD_MICRO;
 562	} else {
 563		/* 360 degrees as radians */
 564		*val = PHASE_360_DEG_TO_RAD_INT;
 565		*val2 = PHASE_360_DEG_TO_RAD_MICRO;
 566	}
 567
 568	return IIO_VAL_INT_PLUS_MICRO;
 569}
 570
 571static int ad2s1210_set_phase_lock_range(struct ad2s1210_state *st,
 572					 int val, int val2)
 573{
 574	int deg;
 575
 576	/* convert radians to degrees - only two allowable values */
 577	if (val == PHASE_44_DEG_TO_RAD_INT && val2 == PHASE_44_DEG_TO_RAD_MICRO)
 578		deg = 44;
 579	else if (val == PHASE_360_DEG_TO_RAD_INT &&
 580		 val2 == PHASE_360_DEG_TO_RAD_MICRO)
 581		deg = 360;
 582	else
 583		return -EINVAL;
 584
 585	guard(mutex)(&st->lock);
 586	return regmap_update_bits(st->regmap, AD2S1210_REG_CONTROL,
 587				  AD2S1210_PHASE_LOCK_RANGE_44,
 588				  deg == 44 ? AD2S1210_PHASE_LOCK_RANGE_44 : 0);
 589}
 590
 591/* map resolution to microradians/LSB for LOT registers */
 592static const int ad2s1210_lot_threshold_urad_per_lsb[] = {
 593	6184, /* 10-bit: ~0.35 deg/LSB, 45 deg max */
 594	2473, /* 12-bit: ~0.14 deg/LSB, 18 deg max */
 595	1237, /* 14-bit: ~0.07 deg/LSB, 9 deg max */
 596	1237, /* 16-bit: same as 14-bit */
 597};
 598
 599static int ad2s1210_get_voltage_threshold(struct ad2s1210_state *st,
 600					  unsigned int reg, int *val)
 601{
 602	unsigned int reg_val;
 603	int ret;
 604
 605	guard(mutex)(&st->lock);
 606	ret = regmap_read(st->regmap, reg, &reg_val);
 607	if (ret < 0)
 608		return ret;
 609
 610	*val = reg_val * THRESHOLD_MILLIVOLT_PER_LSB;
 611	return IIO_VAL_INT;
 612}
 613
 614static int ad2s1210_set_voltage_threshold(struct ad2s1210_state *st,
 615					  unsigned int reg, int val)
 616{
 617	unsigned int reg_val;
 618
 619	reg_val = val / THRESHOLD_MILLIVOLT_PER_LSB;
 620
 621	guard(mutex)(&st->lock);
 622	return regmap_write(st->regmap, reg, reg_val);
 623}
 624
 625static int ad2s1210_get_lot_high_threshold(struct ad2s1210_state *st,
 626					   int *val, int *val2)
 627{
 628	unsigned int reg_val;
 629	int ret;
 630
 631	guard(mutex)(&st->lock);
 632	ret = regmap_read(st->regmap, AD2S1210_REG_LOT_HIGH_THRD, &reg_val);
 633	if (ret < 0)
 634		return ret;
 635
 636	*val = 0;
 637	*val2 = reg_val * ad2s1210_lot_threshold_urad_per_lsb[st->resolution];
 638	return IIO_VAL_INT_PLUS_MICRO;
 639}
 640
 641static int ad2s1210_set_lot_high_threshold(struct ad2s1210_state *st,
 642					   int val, int val2)
 643{
 644	unsigned int high_reg_val, low_reg_val, hysteresis;
 645	int ret;
 646
 647	/* all valid values are between 0 and pi/4 radians */
 648	if (val != 0)
 649		return -EINVAL;
 650
 651	guard(mutex)(&st->lock);
 652	/*
 653	 * We need to read both high and low registers first so we can preserve
 654	 * the hysteresis.
 655	 */
 656	ret = regmap_read(st->regmap, AD2S1210_REG_LOT_HIGH_THRD, &high_reg_val);
 657	if (ret < 0)
 658		return ret;
 659
 660	ret = regmap_read(st->regmap, AD2S1210_REG_LOT_LOW_THRD, &low_reg_val);
 661	if (ret < 0)
 662		return ret;
 663
 664	hysteresis = high_reg_val - low_reg_val;
 665	high_reg_val = val2 / ad2s1210_lot_threshold_urad_per_lsb[st->resolution];
 666	low_reg_val = high_reg_val - hysteresis;
 667
 668	ret = regmap_write(st->regmap, AD2S1210_REG_LOT_HIGH_THRD, high_reg_val);
 669	if (ret < 0)
 670		return ret;
 671
 672	return regmap_write(st->regmap, AD2S1210_REG_LOT_LOW_THRD, low_reg_val);
 673}
 674
 675static int ad2s1210_get_lot_low_threshold(struct ad2s1210_state *st,
 676					  int *val, int *val2)
 677{
 678	unsigned int high_reg_val, low_reg_val;
 679	int ret;
 680
 681	guard(mutex)(&st->lock);
 682
 683	ret = regmap_read(st->regmap, AD2S1210_REG_LOT_HIGH_THRD, &high_reg_val);
 684	if (ret < 0)
 685		return ret;
 686
 687	ret = regmap_read(st->regmap, AD2S1210_REG_LOT_LOW_THRD, &low_reg_val);
 688	if (ret < 0)
 689		return ret;
 690
 691	/* sysfs value is hysteresis rather than actual low value */
 692	*val = 0;
 693	*val2 = (high_reg_val - low_reg_val) *
 694		ad2s1210_lot_threshold_urad_per_lsb[st->resolution];
 695	return IIO_VAL_INT_PLUS_MICRO;
 696}
 697
 698static int ad2s1210_set_lot_low_threshold(struct ad2s1210_state *st,
 699					  int val, int val2)
 700{
 701	unsigned int reg_val, hysteresis;
 702	int ret;
 703
 704	/* all valid values are between 0 and pi/4 radians */
 705	if (val != 0)
 706		return -EINVAL;
 707
 708	hysteresis = val2 / ad2s1210_lot_threshold_urad_per_lsb[st->resolution];
 709
 710	guard(mutex)(&st->lock);
 711
 712	ret = regmap_read(st->regmap, AD2S1210_REG_LOT_HIGH_THRD, &reg_val);
 713	if (ret < 0)
 714		return ret;
 715
 716	return regmap_write(st->regmap, AD2S1210_REG_LOT_LOW_THRD,
 717			   reg_val - hysteresis);
 718}
 719
 720static int ad2s1210_get_excitation_frequency(struct ad2s1210_state *st, int *val)
 721{
 722	unsigned int reg_val;
 723	int ret;
 724
 725	guard(mutex)(&st->lock);
 726
 727	ret = regmap_read(st->regmap, AD2S1210_REG_EXCIT_FREQ, &reg_val);
 728	if (ret < 0)
 729		return ret;
 730
 731	*val = reg_val * st->clkin_hz / (1 << 15);
 732	return IIO_VAL_INT;
 733}
 734
 735static int ad2s1210_set_excitation_frequency(struct ad2s1210_state *st, int val)
 736{
 737	if (val < AD2S1210_MIN_EXCIT || val > AD2S1210_MAX_EXCIT)
 738		return -EINVAL;
 739
 740	guard(mutex)(&st->lock);
 741	return ad2s1210_reinit_excitation_frequency(st, val);
 742}
 743
 744static const int ad2s1210_velocity_scale[] = {
 745	17089132, /* 8.192MHz / (2*pi * 2500 / 2^15) */
 746	42722830, /* 8.192MHz / (2*pi * 1000 / 2^15) */
 747	85445659, /* 8.192MHz / (2*pi * 500 / 2^15) */
 748	341782638, /* 8.192MHz / (2*pi * 125 / 2^15) */
 749};
 750
 751static int ad2s1210_read_raw(struct iio_dev *indio_dev,
 752			     struct iio_chan_spec const *chan,
 753			     int *val,
 754			     int *val2,
 755			     long mask)
 756{
 757	struct ad2s1210_state *st = iio_priv(indio_dev);
 758
 759	switch (mask) {
 760	case IIO_CHAN_INFO_RAW:
 761		return ad2s1210_single_conversion(indio_dev, chan, val);
 762	case IIO_CHAN_INFO_SCALE:
 763		switch (chan->type) {
 764		case IIO_ANGL:
 765			/* approx 0.3 arc min converted to radians */
 766			*val = 0;
 767			*val2 = 95874;
 768			return IIO_VAL_INT_PLUS_NANO;
 769		case IIO_ANGL_VEL:
 770			*val = st->clkin_hz;
 771			*val2 = ad2s1210_velocity_scale[st->resolution];
 772			return IIO_VAL_FRACTIONAL;
 773		default:
 774			return -EINVAL;
 775		}
 776	case IIO_CHAN_INFO_FREQUENCY:
 777		switch (chan->type) {
 778		case IIO_ALTVOLTAGE:
 779			return ad2s1210_get_excitation_frequency(st, val);
 780		default:
 781			return -EINVAL;
 782		}
 783	case IIO_CHAN_INFO_HYSTERESIS:
 784		switch (chan->type) {
 785		case IIO_ANGL:
 786			return ad2s1210_get_hysteresis(st, val);
 787		default:
 788			return -EINVAL;
 789		}
 790	default:
 791		return -EINVAL;
 792	}
 793}
 794
 795static int ad2s1210_read_avail(struct iio_dev *indio_dev,
 796			       struct iio_chan_spec const *chan,
 797			       const int **vals, int *type,
 798			       int *length, long mask)
 799{
 800	static const int excitation_frequency_available[] = {
 801		AD2S1210_MIN_EXCIT,
 802		250, /* step */
 803		AD2S1210_MAX_EXCIT,
 804	};
 805
 806	struct ad2s1210_state *st = iio_priv(indio_dev);
 807
 808	switch (mask) {
 809	case IIO_CHAN_INFO_FREQUENCY:
 810		switch (chan->type) {
 811		case IIO_ALTVOLTAGE:
 812			*type = IIO_VAL_INT;
 813			*vals = excitation_frequency_available;
 814			return IIO_AVAIL_RANGE;
 815		default:
 816			return -EINVAL;
 817		}
 818	case IIO_CHAN_INFO_HYSTERESIS:
 819		switch (chan->type) {
 820		case IIO_ANGL:
 821			*vals = st->hysteresis_available;
 822			*type = IIO_VAL_INT;
 823			*length = ARRAY_SIZE(st->hysteresis_available);
 824			return IIO_AVAIL_LIST;
 825		default:
 826			return -EINVAL;
 827		}
 828	default:
 829		return -EINVAL;
 830	}
 831}
 832
 833static int ad2s1210_write_raw(struct iio_dev *indio_dev,
 834			      struct iio_chan_spec const *chan,
 835			      int val, int val2, long mask)
 836{
 837	struct ad2s1210_state *st = iio_priv(indio_dev);
 838
 839	switch (mask) {
 840	case IIO_CHAN_INFO_FREQUENCY:
 841		switch (chan->type) {
 842		case IIO_ALTVOLTAGE:
 843			return ad2s1210_set_excitation_frequency(st, val);
 844		default:
 845			return -EINVAL;
 846		}
 847	case IIO_CHAN_INFO_HYSTERESIS:
 848		switch (chan->type) {
 849		case IIO_ANGL:
 850			return ad2s1210_set_hysteresis(st, val);
 851		default:
 852			return -EINVAL;
 853		}
 854	default:
 855		return -EINVAL;
 856	}
 857}
 858
 859static const struct iio_event_spec ad2s1210_position_event_spec[] = {
 860	{
 861		/* Tracking error exceeds LOT threshold fault. */
 862		.type = IIO_EV_TYPE_THRESH,
 863		.dir = IIO_EV_DIR_RISING,
 864		.mask_separate =
 865			/* Loss of tracking high threshold. */
 866			BIT(IIO_EV_INFO_VALUE) |
 867			/* Loss of tracking low threshold. */
 868			BIT(IIO_EV_INFO_HYSTERESIS),
 869	},
 870};
 871
 872static const struct iio_event_spec ad2s1210_velocity_event_spec[] = {
 873	{
 874		/* Velocity exceeds maximum tracking rate fault. */
 875		.type = IIO_EV_TYPE_MAG,
 876		.dir = IIO_EV_DIR_RISING,
 877	},
 878};
 879
 880static const struct iio_event_spec ad2s1210_phase_event_spec[] = {
 881	{
 882		/* Phase error fault. */
 883		.type = IIO_EV_TYPE_MAG,
 884		.dir = IIO_EV_DIR_RISING,
 885		/* Phase lock range. */
 886		.mask_separate = BIT(IIO_EV_INFO_VALUE),
 887	},
 888};
 889
 890static const struct iio_event_spec ad2s1210_monitor_signal_event_spec[] = {
 891	{
 892		/* Sine/cosine below LOS threshold fault. */
 893		.type = IIO_EV_TYPE_THRESH,
 894		.dir = IIO_EV_DIR_FALLING,
 895		/* Loss of signal threshold. */
 896		.mask_separate = BIT(IIO_EV_INFO_VALUE),
 897	},
 898	{
 899		/* Sine/cosine DOS overrange fault.*/
 900		.type = IIO_EV_TYPE_THRESH,
 901		.dir = IIO_EV_DIR_RISING,
 902		/* Degredation of signal overrange threshold. */
 903		.mask_separate = BIT(IIO_EV_INFO_VALUE),
 904	},
 905	{
 906		/* Sine/cosine DOS mismatch fault.*/
 907		.type = IIO_EV_TYPE_MAG,
 908		.dir = IIO_EV_DIR_RISING,
 909		.mask_separate = BIT(IIO_EV_INFO_VALUE),
 910	},
 911};
 912
 913static const struct iio_event_spec ad2s1210_sin_cos_event_spec[] = {
 914	{
 915		/* Sine/cosine clipping fault. */
 916		.type = IIO_EV_TYPE_MAG,
 917		.dir = IIO_EV_DIR_EITHER,
 918	},
 919};
 920
 921static const struct iio_chan_spec ad2s1210_channels[] = {
 922	{
 923		.type = IIO_ANGL,
 924		.indexed = 1,
 925		.channel = 0,
 926		.scan_index = 0,
 927		.scan_type = {
 928			.sign = 'u',
 929			.realbits = 16,
 930			.storagebits = 16,
 931			.endianness = IIO_BE,
 932		},
 933		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
 934				      BIT(IIO_CHAN_INFO_SCALE) |
 935				      BIT(IIO_CHAN_INFO_HYSTERESIS),
 936		.info_mask_separate_available =
 937					BIT(IIO_CHAN_INFO_HYSTERESIS),
 938	}, {
 939		.type = IIO_ANGL_VEL,
 940		.indexed = 1,
 941		.channel = 0,
 942		.scan_index = 1,
 943		.scan_type = {
 944			.sign = 's',
 945			.realbits = 16,
 946			.storagebits = 16,
 947			.endianness = IIO_BE,
 948		},
 949		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
 950				      BIT(IIO_CHAN_INFO_SCALE),
 951		.event_spec = ad2s1210_velocity_event_spec,
 952		.num_event_specs = ARRAY_SIZE(ad2s1210_velocity_event_spec),
 953	},
 954	IIO_CHAN_SOFT_TIMESTAMP(2),
 955	{
 956		/* used to configure LOT thresholds and get tracking error */
 957		.type = IIO_ANGL,
 958		.indexed = 1,
 959		.channel = 1,
 960		.scan_index = -1,
 961		.event_spec = ad2s1210_position_event_spec,
 962		.num_event_specs = ARRAY_SIZE(ad2s1210_position_event_spec),
 963	},
 964	{
 965		/* used to configure phase lock range and get phase lock error */
 966		.type = IIO_PHASE,
 967		.indexed = 1,
 968		.channel = 0,
 969		.scan_index = -1,
 970		.event_spec = ad2s1210_phase_event_spec,
 971		.num_event_specs = ARRAY_SIZE(ad2s1210_phase_event_spec),
 972	}, {
 973		/* excitation frequency output */
 974		.type = IIO_ALTVOLTAGE,
 975		.indexed = 1,
 976		.channel = 0,
 977		.output = 1,
 978		.scan_index = -1,
 979		.info_mask_separate = BIT(IIO_CHAN_INFO_FREQUENCY),
 980		.info_mask_separate_available = BIT(IIO_CHAN_INFO_FREQUENCY),
 981	}, {
 982		/* monitor signal */
 983		.type = IIO_ALTVOLTAGE,
 984		.indexed = 1,
 985		.channel = 0,
 986		.scan_index = -1,
 987		.event_spec = ad2s1210_monitor_signal_event_spec,
 988		.num_event_specs = ARRAY_SIZE(ad2s1210_monitor_signal_event_spec),
 989	}, {
 990		/* sine input */
 991		.type = IIO_ALTVOLTAGE,
 992		.indexed = 1,
 993		.channel = 1,
 994		.scan_index = -1,
 995		.event_spec = ad2s1210_sin_cos_event_spec,
 996		.num_event_specs = ARRAY_SIZE(ad2s1210_sin_cos_event_spec),
 997	}, {
 998		/* cosine input */
 999		.type = IIO_ALTVOLTAGE,
1000		.indexed = 1,
1001		.channel = 2,
1002		.scan_index = -1,
1003		.event_spec = ad2s1210_sin_cos_event_spec,
1004		.num_event_specs = ARRAY_SIZE(ad2s1210_sin_cos_event_spec),
1005	},
1006};
1007
1008static ssize_t event_attr_voltage_reg_show(struct device *dev,
1009					   struct device_attribute *attr,
1010					   char *buf)
1011{
1012	struct ad2s1210_state *st = iio_priv(dev_to_iio_dev(dev));
1013	struct iio_dev_attr *iattr = to_iio_dev_attr(attr);
1014	unsigned int value;
1015	int ret;
1016
1017	guard(mutex)(&st->lock);
1018	ret = regmap_read(st->regmap, iattr->address, &value);
1019	if (ret < 0)
1020		return ret;
1021
1022	return sprintf(buf, "%d\n", value * THRESHOLD_MILLIVOLT_PER_LSB);
1023}
1024
1025static ssize_t event_attr_voltage_reg_store(struct device *dev,
1026					    struct device_attribute *attr,
1027					    const char *buf, size_t len)
1028{
1029	struct ad2s1210_state *st = iio_priv(dev_to_iio_dev(dev));
1030	struct iio_dev_attr *iattr = to_iio_dev_attr(attr);
1031	u16 data;
1032	int ret;
1033
1034	ret = kstrtou16(buf, 10, &data);
1035	if (ret)
1036		return -EINVAL;
1037
1038	guard(mutex)(&st->lock);
1039	ret = regmap_write(st->regmap, iattr->address,
1040			   data / THRESHOLD_MILLIVOLT_PER_LSB);
1041	if (ret < 0)
1042		return ret;
1043
1044	return len;
1045}
1046
1047static ssize_t
1048in_angl1_thresh_rising_value_available_show(struct device *dev,
1049					    struct device_attribute *attr,
1050					    char *buf)
1051{
1052	struct ad2s1210_state *st = iio_priv(dev_to_iio_dev(dev));
1053	int step = ad2s1210_lot_threshold_urad_per_lsb[st->resolution];
1054
1055	return sysfs_emit(buf, "[0 0.%06d 0.%06d]\n", step, step * 0x7F);
1056}
1057
1058static ssize_t
1059in_angl1_thresh_rising_hysteresis_available_show(struct device *dev,
1060						 struct device_attribute *attr,
1061						 char *buf)
1062{
1063	struct ad2s1210_state *st = iio_priv(dev_to_iio_dev(dev));
1064	int step = ad2s1210_lot_threshold_urad_per_lsb[st->resolution];
1065
1066	return sysfs_emit(buf, "[0 0.%06d 0.%06d]\n", step, step * 0x7F);
1067}
1068
1069static IIO_CONST_ATTR(in_phase0_mag_rising_value_available,
1070		      __stringify(PHASE_44_DEG_TO_RAD_INT) "."
1071		      __stringify(PHASE_44_DEG_TO_RAD_MICRO) " "
1072		      __stringify(PHASE_360_DEG_TO_RAD_INT) "."
1073		      __stringify(PHASE_360_DEG_TO_RAD_MICRO));
1074static IIO_CONST_ATTR(in_altvoltage0_thresh_falling_value_available,
1075		      THRESHOLD_RANGE_STR);
1076static IIO_CONST_ATTR(in_altvoltage0_thresh_rising_value_available,
1077		      THRESHOLD_RANGE_STR);
1078static IIO_CONST_ATTR(in_altvoltage0_mag_rising_value_available,
1079		      THRESHOLD_RANGE_STR);
1080static IIO_DEVICE_ATTR(in_altvoltage0_mag_rising_reset_max, 0644,
1081		       event_attr_voltage_reg_show, event_attr_voltage_reg_store,
1082		       AD2S1210_REG_DOS_RST_MAX_THRD);
1083static IIO_CONST_ATTR(in_altvoltage0_mag_rising_reset_max_available, THRESHOLD_RANGE_STR);
1084static IIO_DEVICE_ATTR(in_altvoltage0_mag_rising_reset_min, 0644,
1085		       event_attr_voltage_reg_show, event_attr_voltage_reg_store,
1086		       AD2S1210_REG_DOS_RST_MIN_THRD);
1087static IIO_CONST_ATTR(in_altvoltage0_mag_rising_reset_min_available, THRESHOLD_RANGE_STR);
1088static IIO_DEVICE_ATTR_RO(in_angl1_thresh_rising_value_available, 0);
1089static IIO_DEVICE_ATTR_RO(in_angl1_thresh_rising_hysteresis_available, 0);
1090
1091static struct attribute *ad2s1210_event_attributes[] = {
1092	&iio_const_attr_in_phase0_mag_rising_value_available.dev_attr.attr,
1093	&iio_const_attr_in_altvoltage0_thresh_falling_value_available.dev_attr.attr,
1094	&iio_const_attr_in_altvoltage0_thresh_rising_value_available.dev_attr.attr,
1095	&iio_const_attr_in_altvoltage0_mag_rising_value_available.dev_attr.attr,
1096	&iio_dev_attr_in_altvoltage0_mag_rising_reset_max.dev_attr.attr,
1097	&iio_const_attr_in_altvoltage0_mag_rising_reset_max_available.dev_attr.attr,
1098	&iio_dev_attr_in_altvoltage0_mag_rising_reset_min.dev_attr.attr,
1099	&iio_const_attr_in_altvoltage0_mag_rising_reset_min_available.dev_attr.attr,
1100	&iio_dev_attr_in_angl1_thresh_rising_value_available.dev_attr.attr,
1101	&iio_dev_attr_in_angl1_thresh_rising_hysteresis_available.dev_attr.attr,
1102	NULL,
1103};
1104
1105static const struct attribute_group ad2s1210_event_attribute_group = {
1106	.attrs = ad2s1210_event_attributes,
1107};
1108
1109static int ad2s1210_initial(struct ad2s1210_state *st)
1110{
1111	unsigned int data;
1112	int ret;
1113
1114	guard(mutex)(&st->lock);
1115
1116	/* Use default config register value plus resolution from devicetree. */
1117	data = FIELD_PREP(AD2S1210_PHASE_LOCK_RANGE_44, 1);
1118	data |= FIELD_PREP(AD2S1210_ENABLE_HYSTERESIS, 1);
1119	data |= FIELD_PREP(AD2S1210_SET_ENRES, 0x3);
1120	data |= FIELD_PREP(AD2S1210_SET_RES, st->resolution);
1121
1122	ret = regmap_write(st->regmap, AD2S1210_REG_CONTROL, data);
1123	if (ret < 0)
1124		return ret;
1125
1126	return ad2s1210_reinit_excitation_frequency(st, AD2S1210_DEF_EXCIT);
1127}
1128
1129static int ad2s1210_read_label(struct iio_dev *indio_dev,
1130			       struct iio_chan_spec const *chan,
1131			       char *label)
1132{
1133	if (chan->type == IIO_ANGL) {
1134		if (chan->channel == 0)
1135			return sprintf(label, "position\n");
1136		if (chan->channel == 1)
1137			return sprintf(label, "tracking error\n");
1138	}
1139	if (chan->type == IIO_ANGL_VEL)
1140		return sprintf(label, "velocity\n");
1141	if (chan->type == IIO_PHASE)
1142		return sprintf(label, "synthetic reference\n");
1143	if (chan->type == IIO_ALTVOLTAGE) {
1144		if (chan->output)
1145			return sprintf(label, "excitation\n");
1146		if (chan->channel == 0)
1147			return sprintf(label, "monitor signal\n");
1148		if (chan->channel == 1)
1149			return sprintf(label, "cosine\n");
1150		if (chan->channel == 2)
1151			return sprintf(label, "sine\n");
1152	}
1153
1154	return -EINVAL;
1155}
1156
1157static int ad2s1210_read_event_value(struct iio_dev *indio_dev,
1158				     const struct iio_chan_spec *chan,
1159				     enum iio_event_type type,
1160				     enum iio_event_direction dir,
1161				     enum iio_event_info info,
1162				     int *val, int *val2)
1163{
1164	struct ad2s1210_state *st = iio_priv(indio_dev);
1165
1166	switch (chan->type) {
1167	case IIO_ANGL:
1168		switch (info) {
1169		case IIO_EV_INFO_VALUE:
1170			return ad2s1210_get_lot_high_threshold(st, val, val2);
1171		case IIO_EV_INFO_HYSTERESIS:
1172			return ad2s1210_get_lot_low_threshold(st, val, val2);
1173		default:
1174			return -EINVAL;
1175		}
1176	case IIO_ALTVOLTAGE:
1177		if (chan->output)
1178			return -EINVAL;
1179		if (type == IIO_EV_TYPE_THRESH && dir == IIO_EV_DIR_FALLING)
1180			return ad2s1210_get_voltage_threshold(st,
1181						AD2S1210_REG_LOS_THRD, val);
1182		if (type == IIO_EV_TYPE_THRESH && dir == IIO_EV_DIR_RISING)
1183			return ad2s1210_get_voltage_threshold(st,
1184						AD2S1210_REG_DOS_OVR_THRD, val);
1185		if (type == IIO_EV_TYPE_MAG)
1186			return ad2s1210_get_voltage_threshold(st,
1187						AD2S1210_REG_DOS_MIS_THRD, val);
1188		return -EINVAL;
1189	case IIO_PHASE:
1190		return ad2s1210_get_phase_lock_range(st, val, val2);
1191	default:
1192		return -EINVAL;
1193	}
1194}
1195
1196static int ad2s1210_write_event_value(struct iio_dev *indio_dev,
1197				      const struct iio_chan_spec *chan,
1198				      enum iio_event_type type,
1199				      enum iio_event_direction dir,
1200				      enum iio_event_info info,
1201				      int val, int val2)
1202{
1203	struct ad2s1210_state *st = iio_priv(indio_dev);
1204
1205	switch (chan->type) {
1206	case IIO_ANGL:
1207		switch (info) {
1208		case IIO_EV_INFO_VALUE:
1209			return ad2s1210_set_lot_high_threshold(st, val, val2);
1210		case IIO_EV_INFO_HYSTERESIS:
1211			return ad2s1210_set_lot_low_threshold(st, val, val2);
1212		default:
1213			return -EINVAL;
1214		}
1215	case IIO_ALTVOLTAGE:
1216		if (chan->output)
1217			return -EINVAL;
1218		if (type == IIO_EV_TYPE_THRESH && dir == IIO_EV_DIR_FALLING)
1219			return ad2s1210_set_voltage_threshold(st,
1220						AD2S1210_REG_LOS_THRD, val);
1221		if (type == IIO_EV_TYPE_THRESH && dir == IIO_EV_DIR_RISING)
1222			return ad2s1210_set_voltage_threshold(st,
1223						AD2S1210_REG_DOS_OVR_THRD, val);
1224		if (type == IIO_EV_TYPE_MAG)
1225			return ad2s1210_set_voltage_threshold(st,
1226						AD2S1210_REG_DOS_MIS_THRD, val);
1227		return -EINVAL;
1228	case IIO_PHASE:
1229		return ad2s1210_set_phase_lock_range(st, val, val2);
1230	default:
1231		return -EINVAL;
1232	}
1233}
1234
1235static int ad2s1210_read_event_label(struct iio_dev *indio_dev,
1236				     struct iio_chan_spec const *chan,
1237				     enum iio_event_type type,
1238				     enum iio_event_direction dir,
1239				     char *label)
1240{
1241	if (chan->type == IIO_ANGL)
1242		return sprintf(label, "LOT\n");
1243	if (chan->type == IIO_ANGL_VEL)
1244		return sprintf(label, "max tracking rate\n");
1245	if (chan->type == IIO_PHASE)
1246		return sprintf(label, "phase lock\n");
1247	if (chan->type == IIO_ALTVOLTAGE) {
1248		if (chan->channel == 0) {
1249			if (type == IIO_EV_TYPE_THRESH &&
1250			    dir == IIO_EV_DIR_FALLING)
1251				return sprintf(label, "LOS\n");
1252			if (type == IIO_EV_TYPE_THRESH &&
1253			    dir == IIO_EV_DIR_RISING)
1254				return sprintf(label, "DOS overrange\n");
1255			if (type == IIO_EV_TYPE_MAG)
1256				return sprintf(label, "DOS mismatch\n");
1257		}
1258		if (chan->channel == 1 || chan->channel == 2)
1259			return sprintf(label, "clipped\n");
1260	}
1261
1262	return -EINVAL;
1263}
1264
1265static int ad2s1210_debugfs_reg_access(struct iio_dev *indio_dev,
1266				       unsigned int reg, unsigned int writeval,
1267				       unsigned int *readval)
1268{
1269	struct ad2s1210_state *st = iio_priv(indio_dev);
1270
1271	guard(mutex)(&st->lock);
1272
1273	if (readval)
1274		return regmap_read(st->regmap, reg, readval);
1275
1276	return regmap_write(st->regmap, reg, writeval);
1277}
1278
1279static irqreturn_t ad2s1210_trigger_handler(int irq, void *p)
1280{
1281	struct iio_poll_func *pf = p;
1282	struct iio_dev *indio_dev = pf->indio_dev;
1283	struct ad2s1210_state *st = iio_priv(indio_dev);
1284	size_t chan = 0;
1285	int ret;
1286
1287	guard(mutex)(&st->lock);
1288
1289	memset(&st->scan, 0, sizeof(st->scan));
1290	ad2s1210_toggle_sample_line(st);
1291
1292	if (test_bit(0, indio_dev->active_scan_mask)) {
1293		if (st->fixed_mode == MOD_CONFIG) {
1294			ret = regmap_bulk_read(st->regmap,
1295					       AD2S1210_REG_POSITION_MSB,
1296					       &st->sample.raw, 2);
1297			if (ret < 0)
1298				goto error_ret;
1299		} else {
1300			ret = ad2s1210_set_mode(st, MOD_POS);
1301			if (ret < 0)
1302				goto error_ret;
1303
1304			ret = spi_read(st->sdev, &st->sample, 3);
1305			if (ret < 0)
1306				goto error_ret;
1307		}
1308
1309		memcpy(&st->scan.chan[chan++], &st->sample.raw, 2);
1310	}
1311
1312	if (test_bit(1, indio_dev->active_scan_mask)) {
1313		if (st->fixed_mode == MOD_CONFIG) {
1314			ret = regmap_bulk_read(st->regmap,
1315					       AD2S1210_REG_VELOCITY_MSB,
1316					       &st->sample.raw, 2);
1317			if (ret < 0)
1318				goto error_ret;
1319		} else {
1320			ret = ad2s1210_set_mode(st, MOD_VEL);
1321			if (ret < 0)
1322				goto error_ret;
1323
1324			ret = spi_read(st->sdev, &st->sample, 3);
1325			if (ret < 0)
1326				goto error_ret;
1327		}
1328
1329		memcpy(&st->scan.chan[chan++], &st->sample.raw, 2);
1330	}
1331
1332	if (st->fixed_mode == MOD_CONFIG) {
1333		unsigned int reg_val;
1334
1335		ret = regmap_read(st->regmap, AD2S1210_REG_FAULT, &reg_val);
1336		if (ret < 0)
1337			return ret;
1338
1339		st->sample.fault = reg_val;
1340	}
1341
1342	ad2s1210_push_events(indio_dev, st->sample.fault, pf->timestamp);
1343	iio_push_to_buffers_with_timestamp(indio_dev, &st->scan, pf->timestamp);
1344
1345error_ret:
1346	iio_trigger_notify_done(indio_dev->trig);
1347
1348	return IRQ_HANDLED;
1349}
1350
1351static const struct iio_info ad2s1210_info = {
1352	.event_attrs = &ad2s1210_event_attribute_group,
1353	.read_raw = ad2s1210_read_raw,
1354	.read_avail = ad2s1210_read_avail,
1355	.write_raw = ad2s1210_write_raw,
1356	.read_label = ad2s1210_read_label,
1357	.read_event_value = ad2s1210_read_event_value,
1358	.write_event_value = ad2s1210_write_event_value,
1359	.read_event_label = ad2s1210_read_event_label,
1360	.debugfs_reg_access = &ad2s1210_debugfs_reg_access,
1361};
1362
1363static int ad2s1210_setup_properties(struct ad2s1210_state *st)
1364{
1365	struct device *dev = &st->sdev->dev;
1366	const char *str_val;
1367	u32 val;
1368	int ret;
1369
1370	ret = device_property_read_string(dev, "adi,fixed-mode", &str_val);
1371	if (ret == -EINVAL)
1372		st->fixed_mode = -1;
1373	else if (ret < 0)
1374		return dev_err_probe(dev, ret,
1375			"failed to read adi,fixed-mode property\n");
1376	else {
1377		if (strcmp(str_val, "config"))
1378			return dev_err_probe(dev, -EINVAL,
1379				"only adi,fixed-mode=\"config\" is supported\n");
1380
1381		st->fixed_mode = MOD_CONFIG;
1382	}
1383
1384	ret = device_property_read_u32(dev, "assigned-resolution-bits", &val);
1385	if (ret < 0)
1386		return dev_err_probe(dev, ret,
1387			"failed to read assigned-resolution-bits property\n");
1388
1389	if (val < 10 || val > 16)
1390		return dev_err_probe(dev, -EINVAL,
1391				     "resolution out of range: %u\n", val);
1392
1393	st->resolution = (val - 10) >> 1;
1394	/*
1395	 * These are values that correlate to the hysteresis bit in the Control
1396	 * register. 0 = disabled, 1 = enabled. When enabled, the actual
1397	 * hysteresis is +/- 1 LSB of the raw position value. Which bit is the
1398	 * LSB depends on the specified resolution.
1399	 */
1400	st->hysteresis_available[0] = 0;
1401	st->hysteresis_available[1] = 1 << (2 * (AD2S1210_RES_16 -
1402						 st->resolution));
1403
1404	return 0;
1405}
1406
1407static int ad2s1210_setup_clocks(struct ad2s1210_state *st)
1408{
1409	struct device *dev = &st->sdev->dev;
1410	struct clk *clk;
1411
1412	clk = devm_clk_get_enabled(dev, NULL);
1413	if (IS_ERR(clk))
1414		return dev_err_probe(dev, PTR_ERR(clk), "failed to get clock\n");
1415
1416	st->clkin_hz = clk_get_rate(clk);
1417	if (st->clkin_hz < AD2S1210_MIN_CLKIN || st->clkin_hz > AD2S1210_MAX_CLKIN)
1418		return dev_err_probe(dev, -EINVAL,
1419				     "clock frequency out of range: %lu\n",
1420				     st->clkin_hz);
1421
1422	return 0;
1423}
1424
1425static int ad2s1210_setup_gpios(struct ad2s1210_state *st)
1426{
1427	struct device *dev = &st->sdev->dev;
1428	struct gpio_descs *resolution_gpios;
1429	struct gpio_desc *reset_gpio;
1430	DECLARE_BITMAP(bitmap, 2);
1431	int ret;
1432
1433	/* should not be sampling on startup */
1434	st->sample_gpio = devm_gpiod_get(dev, "sample", GPIOD_OUT_LOW);
1435	if (IS_ERR(st->sample_gpio))
1436		return dev_err_probe(dev, PTR_ERR(st->sample_gpio),
1437				     "failed to request sample GPIO\n");
1438
1439	/* both pins high means that we start in config mode */
1440	st->mode_gpios = devm_gpiod_get_array_optional(dev, "mode",
1441						       GPIOD_OUT_HIGH);
1442	if (IS_ERR(st->mode_gpios))
1443		return dev_err_probe(dev, PTR_ERR(st->mode_gpios),
1444				     "failed to request mode GPIOs\n");
1445
1446	if (!st->mode_gpios && st->fixed_mode == -1)
1447		return dev_err_probe(dev, -EINVAL,
1448			"must specify either adi,fixed-mode or mode-gpios\n");
1449
1450	if (st->mode_gpios && st->fixed_mode != -1)
1451		return dev_err_probe(dev, -EINVAL,
1452			"must specify only one of adi,fixed-mode or mode-gpios\n");
1453
1454	if (st->mode_gpios && st->mode_gpios->ndescs != 2)
1455		return dev_err_probe(dev, -EINVAL,
1456				     "requires exactly 2 mode-gpios\n");
1457
1458	/*
1459	 * If resolution gpios are provided, they get set to the required
1460	 * resolution, otherwise it is assumed the RES0 and RES1 pins are
1461	 * hard-wired to match the resolution indicated in the devicetree.
1462	 */
1463	resolution_gpios = devm_gpiod_get_array_optional(dev, "resolution",
1464							 GPIOD_ASIS);
1465	if (IS_ERR(resolution_gpios))
1466		return dev_err_probe(dev, PTR_ERR(resolution_gpios),
1467				     "failed to request resolution GPIOs\n");
1468
1469	if (resolution_gpios) {
1470		if (resolution_gpios->ndescs != 2)
1471			return dev_err_probe(dev, -EINVAL,
1472				      "requires exactly 2 resolution-gpios\n");
1473
1474		bitmap[0] = st->resolution;
1475
1476		ret = gpiod_set_array_value(resolution_gpios->ndescs,
1477					    resolution_gpios->desc,
1478					    resolution_gpios->info,
1479					    bitmap);
1480		if (ret < 0)
1481			return dev_err_probe(dev, ret,
1482					     "failed to set resolution gpios\n");
1483	}
1484
1485	/* If the optional reset GPIO is present, toggle it to do a hard reset. */
1486	reset_gpio = devm_gpiod_get_optional(dev, "reset", GPIOD_OUT_HIGH);
1487	if (IS_ERR(reset_gpio))
1488		return dev_err_probe(dev, PTR_ERR(reset_gpio),
1489				     "failed to request reset GPIO\n");
1490
1491	if (reset_gpio) {
1492		udelay(10);
1493		gpiod_set_value(reset_gpio, 0);
1494	}
1495
1496	return 0;
1497}
1498
1499static const struct regmap_range ad2s1210_regmap_readable_ranges[] = {
1500	regmap_reg_range(AD2S1210_REG_POSITION_MSB, AD2S1210_REG_VELOCITY_LSB),
1501	regmap_reg_range(AD2S1210_REG_LOS_THRD, AD2S1210_REG_LOT_LOW_THRD),
1502	regmap_reg_range(AD2S1210_REG_EXCIT_FREQ, AD2S1210_REG_CONTROL),
1503	regmap_reg_range(AD2S1210_REG_FAULT, AD2S1210_REG_FAULT),
1504};
1505
1506static const struct regmap_access_table ad2s1210_regmap_rd_table = {
1507	.yes_ranges = ad2s1210_regmap_readable_ranges,
1508	.n_yes_ranges = ARRAY_SIZE(ad2s1210_regmap_readable_ranges),
1509};
1510
1511static const struct regmap_range ad2s1210_regmap_writeable_ranges[] = {
1512	regmap_reg_range(AD2S1210_REG_LOS_THRD, AD2S1210_REG_LOT_LOW_THRD),
1513	regmap_reg_range(AD2S1210_REG_EXCIT_FREQ, AD2S1210_REG_CONTROL),
1514	regmap_reg_range(AD2S1210_REG_SOFT_RESET, AD2S1210_REG_SOFT_RESET),
1515	regmap_reg_range(AD2S1210_REG_FAULT, AD2S1210_REG_FAULT),
1516};
1517
1518static const struct regmap_access_table ad2s1210_regmap_wr_table = {
1519	.yes_ranges = ad2s1210_regmap_writeable_ranges,
1520	.n_yes_ranges = ARRAY_SIZE(ad2s1210_regmap_writeable_ranges),
1521};
1522
1523static int ad2s1210_setup_regmap(struct ad2s1210_state *st)
1524{
1525	struct device *dev = &st->sdev->dev;
1526	const struct regmap_config config = {
1527		.reg_bits = 8,
1528		.val_bits = 8,
1529		.disable_locking = true,
1530		.reg_read = ad2s1210_regmap_reg_read,
1531		.reg_write = ad2s1210_regmap_reg_write,
1532		.rd_table = &ad2s1210_regmap_rd_table,
1533		.wr_table = &ad2s1210_regmap_wr_table,
1534		.can_sleep = true,
1535	};
1536
1537	st->regmap = devm_regmap_init(dev, NULL, st, &config);
1538	if (IS_ERR(st->regmap))
1539		return dev_err_probe(dev, PTR_ERR(st->regmap),
1540				     "failed to allocate register map\n");
1541
1542	return 0;
1543}
1544
1545static int ad2s1210_probe(struct spi_device *spi)
1546{
1547	struct iio_dev *indio_dev;
1548	struct ad2s1210_state *st;
1549	int ret;
1550
1551	indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st));
1552	if (!indio_dev)
1553		return -ENOMEM;
1554	st = iio_priv(indio_dev);
1555
1556	mutex_init(&st->lock);
1557	st->sdev = spi;
1558
1559	ret = ad2s1210_setup_properties(st);
1560	if (ret < 0)
1561		return ret;
1562
1563	ret = ad2s1210_setup_clocks(st);
1564	if (ret < 0)
1565		return ret;
1566
1567	ret = ad2s1210_setup_gpios(st);
1568	if (ret < 0)
1569		return ret;
1570
1571	ret = ad2s1210_setup_regmap(st);
1572	if (ret < 0)
1573		return ret;
1574
1575	ret = ad2s1210_initial(st);
1576	if (ret < 0)
1577		return ret;
1578
1579	indio_dev->info = &ad2s1210_info;
1580	indio_dev->modes = INDIO_DIRECT_MODE;
1581	indio_dev->channels = ad2s1210_channels;
1582	indio_dev->num_channels = ARRAY_SIZE(ad2s1210_channels);
1583	indio_dev->name = spi_get_device_id(spi)->name;
1584
1585	ret = devm_iio_triggered_buffer_setup(&spi->dev, indio_dev,
1586					      &iio_pollfunc_store_time,
1587					      &ad2s1210_trigger_handler, NULL);
1588	if (ret < 0)
1589		return dev_err_probe(&spi->dev, ret,
1590				     "iio triggered buffer setup failed\n");
1591
1592	return devm_iio_device_register(&spi->dev, indio_dev);
1593}
1594
1595static const struct of_device_id ad2s1210_of_match[] = {
1596	{ .compatible = "adi,ad2s1210", },
1597	{ }
1598};
1599MODULE_DEVICE_TABLE(of, ad2s1210_of_match);
1600
1601static const struct spi_device_id ad2s1210_id[] = {
1602	{ "ad2s1210" },
1603	{}
1604};
1605MODULE_DEVICE_TABLE(spi, ad2s1210_id);
1606
1607static struct spi_driver ad2s1210_driver = {
1608	.driver = {
1609		.name = "ad2s1210",
1610		.of_match_table = ad2s1210_of_match,
1611	},
1612	.probe = ad2s1210_probe,
1613	.id_table = ad2s1210_id,
1614};
1615module_spi_driver(ad2s1210_driver);
1616
1617MODULE_AUTHOR("Graff Yang <graff.yang@gmail.com>");
1618MODULE_DESCRIPTION("Analog Devices AD2S1210 Resolver to Digital SPI driver");
1619MODULE_LICENSE("GPL v2");