Skip to content

Commit

Permalink
staging: iio: resolver: ad2s1210: clear faults after soft reset
Browse files Browse the repository at this point in the history
When a software reset is performed on the AD2S1210 to make the selected
excitation frequency take effect, it always triggers faults on the
input signals because the output signal is interrupted momentarily.
So we need to clear the faults after the software reset to avoid
triggering fault events the next time a sample is read.

The datasheet specifies a time t[track] in Table 27 that specifies the
settle time in milliseconds after a reset depending on the selected
resolution. This is used in the driver to add an appropriate delay.

Signed-off-by: David Lechner <[email protected]>
  • Loading branch information
dlech committed Oct 31, 2023
1 parent 62011c6 commit 0179029
Showing 1 changed file with 24 additions and 1 deletion.
25 changes: 24 additions & 1 deletion drivers/staging/iio/resolver/ad2s1210.c
Original file line number Diff line number Diff line change
Expand Up @@ -314,6 +314,9 @@ static void ad2s1210_toggle_sample_line(struct ad2s1210_state *st)
static int ad2s1210_reinit_excitation_frequency(struct ad2s1210_state *st,
u16 fexcit)
{
/* Map resolution to settle time in milliseconds. */
static const int track_time_ms[] = { 10, 20, 25, 60 };
unsigned int ignored;
int ret;
u8 fcw;

Expand All @@ -329,7 +332,27 @@ static int ad2s1210_reinit_excitation_frequency(struct ad2s1210_state *st,
* Software reset reinitializes the excitation frequency output.
* It does not reset any of the configuration registers.
*/
return regmap_write(st->regmap, AD2S1210_REG_SOFT_RESET, 0);
ret = regmap_write(st->regmap, AD2S1210_REG_SOFT_RESET, 0);
if (ret < 0)
return ret;

/*
* Soft reset always triggers some faults due the change in the output
* signal so clear the faults too. We need to delay for some time
* (what datasheet calls t[track]) to allow things to settle before
* clearing the faults.
*/
msleep(track_time_ms[st->resolution] * 8192000 / st->clkin_hz);

/* Reading the fault register clears the faults. */
ret = regmap_read(st->regmap, AD2S1210_REG_FAULT, &ignored);
if (ret < 0)
return ret;

/* Have to toggle sample line to get fault output pins to reset. */
ad2s1210_toggle_sample_line(st);

return 0;
}

static void ad2s1210_push_events(struct iio_dev *indio_dev,
Expand Down

0 comments on commit 0179029

Please sign in to comment.