iio: sx9310: Update macros declarations

Follows spec sheet for macro declarations.

Signed-off-by: Daniel Campello <campello@chromium.org>
Reviewed-by: Stephen Boyd <swboyd@chromium.org>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
This commit is contained in:
Daniel Campello 2020-08-03 17:58:02 -06:00 committed by Jonathan Cameron
parent 1d863d1341
commit d9f753f3e9

View file

@ -11,6 +11,7 @@
*/ */
#include <linux/acpi.h> #include <linux/acpi.h>
#include <linux/bitfield.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/irq.h> #include <linux/irq.h>
@ -33,45 +34,44 @@
#define SX9310_REG_IRQ_SRC 0x00 #define SX9310_REG_IRQ_SRC 0x00
#define SX9310_REG_STAT0 0x01 #define SX9310_REG_STAT0 0x01
#define SX9310_REG_STAT1 0x02 #define SX9310_REG_STAT1 0x02
#define SX9310_REG_STAT1_COMPSTAT_MASK GENMASK(3, 0)
#define SX9310_REG_IRQ_MSK 0x03 #define SX9310_REG_IRQ_MSK 0x03
#define SX9310_CONVDONE_IRQ BIT(3) #define SX9310_CONVDONE_IRQ BIT(3)
#define SX9310_FAR_IRQ BIT(5) #define SX9310_FAR_IRQ BIT(5)
#define SX9310_CLOSE_IRQ BIT(6) #define SX9310_CLOSE_IRQ BIT(6)
#define SX9310_EVENT_IRQ (SX9310_FAR_IRQ | \
SX9310_CLOSE_IRQ)
#define SX9310_REG_IRQ_FUNC 0x04 #define SX9310_REG_IRQ_FUNC 0x04
#define SX9310_REG_PROX_CTRL0 0x10 #define SX9310_REG_PROX_CTRL0 0x10
#define SX9310_REG_PROX_CTRL0_PROXSTAT2 0x10 #define SX9310_REG_PROX_CTRL0_SENSOREN_MASK GENMASK(3, 0)
#define SX9310_REG_PROX_CTRL0_EN_MASK 0x0F #define SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK GENMASK(7, 4)
#define SX9310_REG_PROX_CTRL0_SCANPERIOD_15MS 0x01
#define SX9310_REG_PROX_CTRL1 0x11 #define SX9310_REG_PROX_CTRL1 0x11
#define SX9310_REG_PROX_CTRL2 0x12 #define SX9310_REG_PROX_CTRL2 0x12
#define SX9310_REG_PROX_CTRL2_COMBMODE_ALL 0x80 #define SX9310_REG_PROX_CTRL2_COMBMODE_CS1_CS2 (0x02 << 6)
#define SX9310_REG_PROX_CTRL2_SHIELDEN_DYNAMIC 0x04 #define SX9310_REG_PROX_CTRL2_SHIELDEN_DYNAMIC (0x01 << 2)
#define SX9310_REG_PROX_CTRL3 0x13 #define SX9310_REG_PROX_CTRL3 0x13
#define SX9310_REG_PROX_CTRL3_GAIN0_X8 0x0c #define SX9310_REG_PROX_CTRL3_GAIN0_X8 (0x03 << 2)
#define SX9310_REG_PROX_CTRL3_GAIN12_X4 0x02 #define SX9310_REG_PROX_CTRL3_GAIN12_X4 0x02
#define SX9310_REG_PROX_CTRL4 0x14 #define SX9310_REG_PROX_CTRL4 0x14
#define SX9310_REG_PROX_CTRL4_RESOLUTION_FINEST 0x07 #define SX9310_REG_PROX_CTRL4_RESOLUTION_FINEST 0x07
#define SX9310_REG_PROX_CTRL5 0x15 #define SX9310_REG_PROX_CTRL5 0x15
#define SX9310_REG_PROX_CTRL5_RANGE_SMALL 0xc0 #define SX9310_REG_PROX_CTRL5_RANGE_SMALL (0x03 << 6)
#define SX9310_REG_PROX_CTRL5_STARTUPSENS_CS1 0x04 #define SX9310_REG_PROX_CTRL5_STARTUPSENS_CS1 (0x01 << 2)
#define SX9310_REG_PROX_CTRL5_RAWFILT_1P25 0x02 #define SX9310_REG_PROX_CTRL5_RAWFILT_1P25 0x02
#define SX9310_REG_PROX_CTRL6 0x16 #define SX9310_REG_PROX_CTRL6 0x16
#define SX9310_REG_PROX_CTRL6_COMP_COMMON 0x20 #define SX9310_REG_PROX_CTRL6_AVGTHRESH_DEFAULT 0x20
#define SX9310_REG_PROX_CTRL7 0x17 #define SX9310_REG_PROX_CTRL7 0x17
#define SX9310_REG_PROX_CTRL7_AVGNEGFILT_2 0x08 #define SX9310_REG_PROX_CTRL7_AVGNEGFILT_2 (0x01 << 3)
#define SX9310_REG_PROX_CTRL7_AVGPOSFILT_512 0x05 #define SX9310_REG_PROX_CTRL7_AVGPOSFILT_512 0x05
#define SX9310_REG_PROX_CTRL8 0x18 #define SX9310_REG_PROX_CTRL8 0x18
#define SX9310_REG_PROX_CTRL9 0x19 #define SX9310_REG_PROX_CTRL9 0x19
#define SX9310_REG_PROX_CTRL8_9_PTHRESH12_28 0x40 #define SX9310_REG_PROX_CTRL8_9_PTHRESH_28 (0x08 << 3)
#define SX9310_REG_PROX_CTRL8_9_PTHRESH_96 0x88 #define SX9310_REG_PROX_CTRL8_9_PTHRESH_96 (0x11 << 3)
#define SX9310_REG_PROX_CTRL8_9_BODYTHRESH_900 0x03 #define SX9310_REG_PROX_CTRL8_9_BODYTHRESH_900 0x03
#define SX9310_REG_PROX_CTRL8_9_BODYTHRESH_1500 0x05 #define SX9310_REG_PROX_CTRL8_9_BODYTHRESH_1500 0x05
#define SX9310_REG_PROX_CTRL10 0x1a #define SX9310_REG_PROX_CTRL10 0x1a
#define SX9310_REG_PROX_CTRL10_HYST_6PCT 0x10 #define SX9310_REG_PROX_CTRL10_HYST_6PCT (0x01 << 4)
#define SX9310_REG_PROX_CTRL10_CLOSE_DEBOUNCE_8 0x12 #define SX9310_REG_PROX_CTRL10_FAR_DEBOUNCE_2 0x01
#define SX9310_REG_PROX_CTRL10_FAR_DEBOUNCE_8 0x03
#define SX9310_REG_PROX_CTRL11 0x1b #define SX9310_REG_PROX_CTRL11 0x1b
#define SX9310_REG_PROX_CTRL12 0x1c #define SX9310_REG_PROX_CTRL12 0x1c
#define SX9310_REG_PROX_CTRL13 0x1d #define SX9310_REG_PROX_CTRL13 0x1d
@ -82,8 +82,8 @@
#define SX9310_REG_PROX_CTRL18 0x22 #define SX9310_REG_PROX_CTRL18 0x22
#define SX9310_REG_PROX_CTRL19 0x23 #define SX9310_REG_PROX_CTRL19 0x23
#define SX9310_REG_SAR_CTRL0 0x2a #define SX9310_REG_SAR_CTRL0 0x2a
#define SX9310_REG_SAR_CTRL0_SARDEB_4_SAMPLES 0x40 #define SX9310_REG_SAR_CTRL0_SARDEB_4_SAMPLES (0x02 << 5)
#define SX9310_REG_SAR_CTRL0_SARHYST_8 0x10 #define SX9310_REG_SAR_CTRL0_SARHYST_8 (0x02 << 3)
#define SX9310_REG_SAR_CTRL1 0x2b #define SX9310_REG_SAR_CTRL1 0x2b
/* Each increment of the slope register is 0.0078125. */ /* Each increment of the slope register is 0.0078125. */
#define SX9310_REG_SAR_CTRL1_SLOPE(_hnslope) (_hnslope / 78125) #define SX9310_REG_SAR_CTRL1_SLOPE(_hnslope) (_hnslope / 78125)
@ -107,7 +107,7 @@
#define SX9310_REG_SAR_MSB 0x39 #define SX9310_REG_SAR_MSB 0x39
#define SX9310_REG_SAR_LSB 0x3a #define SX9310_REG_SAR_LSB 0x3a
#define SX9310_REG_I2CADDR 0x40 #define SX9310_REG_I2C_ADDR 0x40
#define SX9310_REG_PAUSE 0x41 #define SX9310_REG_PAUSE 0x41
#define SX9310_REG_WHOAMI 0x42 #define SX9310_REG_WHOAMI 0x42
#define SX9310_WHOAMI_VALUE 0x01 #define SX9310_WHOAMI_VALUE 0x01
@ -116,14 +116,9 @@
#define SX9310_REG_RESET 0x7f #define SX9310_REG_RESET 0x7f
#define SX9310_SOFT_RESET 0xde #define SX9310_SOFT_RESET 0xde
#define SX9310_SCAN_PERIOD_MASK GENMASK(7, 4)
#define SX9310_SCAN_PERIOD_SHIFT 4
#define SX9310_COMPSTAT_MASK GENMASK(3, 0)
/* 4 hardware channels, as defined in STAT0: COMB, CS2, CS1 and CS0. */ /* 4 hardware channels, as defined in STAT0: COMB, CS2, CS1 and CS0. */
#define SX9310_NUM_CHANNELS 4 #define SX9310_NUM_CHANNELS 4
#define SX9310_CHAN_ENABLED_MASK GENMASK(3, 0)
struct sx9310_data { struct sx9310_data {
/* Serialize access to registers and channel configuration */ /* Serialize access to registers and channel configuration */
@ -251,7 +246,7 @@ static const struct regmap_range sx9310_readable_reg_ranges[] = {
regmap_reg_range(SX9310_REG_PROX_CTRL0, SX9310_REG_PROX_CTRL19), regmap_reg_range(SX9310_REG_PROX_CTRL0, SX9310_REG_PROX_CTRL19),
regmap_reg_range(SX9310_REG_SAR_CTRL0, SX9310_REG_SAR_CTRL2), regmap_reg_range(SX9310_REG_SAR_CTRL0, SX9310_REG_SAR_CTRL2),
regmap_reg_range(SX9310_REG_SENSOR_SEL, SX9310_REG_SAR_LSB), regmap_reg_range(SX9310_REG_SENSOR_SEL, SX9310_REG_SAR_LSB),
regmap_reg_range(SX9310_REG_I2CADDR, SX9310_REG_WHOAMI), regmap_reg_range(SX9310_REG_I2C_ADDR, SX9310_REG_WHOAMI),
regmap_reg_range(SX9310_REG_RESET, SX9310_REG_RESET), regmap_reg_range(SX9310_REG_RESET, SX9310_REG_RESET),
}; };
@ -292,7 +287,7 @@ static int sx9310_update_chan_en(struct sx9310_data *data,
if ((data->chan_read | data->chan_event) != (chan_read | chan_event)) { if ((data->chan_read | data->chan_event) != (chan_read | chan_event)) {
ret = regmap_update_bits(data->regmap, SX9310_REG_PROX_CTRL0, ret = regmap_update_bits(data->regmap, SX9310_REG_PROX_CTRL0,
SX9310_CHAN_ENABLED_MASK, SX9310_REG_PROX_CTRL0_SENSOREN_MASK,
chan_read | chan_event); chan_read | chan_event);
if (ret) if (ret)
return ret; return ret;
@ -361,7 +356,7 @@ static int sx9310_wait_for_sample(struct sx9310_data *data)
if (ret < 0) if (ret < 0)
return ret; return ret;
val = (val & SX9310_SCAN_PERIOD_MASK) >> SX9310_SCAN_PERIOD_SHIFT; val = FIELD_GET(SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK, val);
msleep(sx9310_scan_period_table[val]); msleep(sx9310_scan_period_table[val]);
@ -435,7 +430,7 @@ static int sx9310_read_samp_freq(struct sx9310_data *data, int *val, int *val2)
if (ret < 0) if (ret < 0)
return ret; return ret;
regval = (regval & SX9310_SCAN_PERIOD_MASK) >> SX9310_SCAN_PERIOD_SHIFT; regval = FIELD_GET(SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK, regval);
*val = sx9310_samp_freq_table[regval].val; *val = sx9310_samp_freq_table[regval].val;
*val2 = sx9310_samp_freq_table[regval].val2; *val2 = sx9310_samp_freq_table[regval].val2;
@ -482,9 +477,10 @@ static int sx9310_set_samp_freq(struct sx9310_data *data, int val, int val2)
mutex_lock(&data->mutex); mutex_lock(&data->mutex);
ret = regmap_update_bits(data->regmap, SX9310_REG_PROX_CTRL0, ret = regmap_update_bits(
SX9310_SCAN_PERIOD_MASK, data->regmap, SX9310_REG_PROX_CTRL0,
i << SX9310_SCAN_PERIOD_SHIFT); SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK,
FIELD_PREP(SX9310_REG_PROX_CTRL0_SCANPERIOD_MASK, i));
mutex_unlock(&data->mutex); mutex_unlock(&data->mutex);
@ -572,7 +568,7 @@ static irqreturn_t sx9310_irq_thread_handler(int irq, void *private)
goto out; goto out;
} }
if (val & SX9310_EVENT_IRQ) if (val & (SX9310_FAR_IRQ | SX9310_CLOSE_IRQ))
sx9310_push_events(indio_dev); sx9310_push_events(indio_dev);
if (val & SX9310_CONVDONE_IRQ) if (val & SX9310_CONVDONE_IRQ)
@ -600,6 +596,7 @@ static int sx9310_write_event_config(struct iio_dev *indio_dev,
enum iio_event_direction dir, int state) enum iio_event_direction dir, int state)
{ {
struct sx9310_data *data = iio_priv(indio_dev); struct sx9310_data *data = iio_priv(indio_dev);
unsigned int eventirq = SX9310_FAR_IRQ | SX9310_CLOSE_IRQ;
int ret; int ret;
/* If the state hasn't changed, there's nothing to do. */ /* If the state hasn't changed, there's nothing to do. */
@ -612,7 +609,7 @@ static int sx9310_write_event_config(struct iio_dev *indio_dev,
if (ret < 0) if (ret < 0)
goto out_unlock; goto out_unlock;
if (!(data->chan_event & ~BIT(chan->channel))) { if (!(data->chan_event & ~BIT(chan->channel))) {
ret = sx9310_enable_irq(data, SX9310_EVENT_IRQ); ret = sx9310_enable_irq(data, eventirq);
if (ret < 0) if (ret < 0)
sx9310_put_event_channel(data, chan->channel); sx9310_put_event_channel(data, chan->channel);
} }
@ -621,7 +618,7 @@ static int sx9310_write_event_config(struct iio_dev *indio_dev,
if (ret < 0) if (ret < 0)
goto out_unlock; goto out_unlock;
if (!data->chan_event) { if (!data->chan_event) {
ret = sx9310_disable_irq(data, SX9310_EVENT_IRQ); ret = sx9310_disable_irq(data, eventirq);
if (ret < 0) if (ret < 0)
sx9310_get_event_channel(data, chan->channel); sx9310_get_event_channel(data, chan->channel);
} }
@ -744,53 +741,46 @@ struct sx9310_reg_default {
u8 def; u8 def;
}; };
#define SX_INIT(_reg, _def) \
{ \
.reg = SX9310_REG_##_reg, \
.def = _def, \
}
static const struct sx9310_reg_default sx9310_default_regs[] = { static const struct sx9310_reg_default sx9310_default_regs[] = {
SX_INIT(IRQ_MSK, 0x00), { SX9310_REG_IRQ_MSK, 0x00 },
SX_INIT(IRQ_FUNC, 0x00), { SX9310_REG_IRQ_FUNC, 0x00 },
/* /*
* The lower 4 bits should not be set as it enable sensors measurements. * The lower 4 bits should not be set as it enable sensors measurements.
* Turning the detection on before the configuration values are set to * Turning the detection on before the configuration values are set to
* good values can cause the device to return erroneous readings. * good values can cause the device to return erroneous readings.
*/ */
SX_INIT(PROX_CTRL0, SX9310_REG_PROX_CTRL0_PROXSTAT2), { SX9310_REG_PROX_CTRL0, SX9310_REG_PROX_CTRL0_SCANPERIOD_15MS },
SX_INIT(PROX_CTRL1, 0x00), { SX9310_REG_PROX_CTRL1, 0x00 },
SX_INIT(PROX_CTRL2, SX9310_REG_PROX_CTRL2_COMBMODE_ALL | { SX9310_REG_PROX_CTRL2, SX9310_REG_PROX_CTRL2_COMBMODE_CS1_CS2 |
SX9310_REG_PROX_CTRL2_SHIELDEN_DYNAMIC), SX9310_REG_PROX_CTRL2_SHIELDEN_DYNAMIC },
SX_INIT(PROX_CTRL3, SX9310_REG_PROX_CTRL3_GAIN0_X8 | { SX9310_REG_PROX_CTRL3, SX9310_REG_PROX_CTRL3_GAIN0_X8 |
SX9310_REG_PROX_CTRL3_GAIN12_X4), SX9310_REG_PROX_CTRL3_GAIN12_X4 },
SX_INIT(PROX_CTRL4, SX9310_REG_PROX_CTRL4_RESOLUTION_FINEST), { SX9310_REG_PROX_CTRL4, SX9310_REG_PROX_CTRL4_RESOLUTION_FINEST },
SX_INIT(PROX_CTRL5, SX9310_REG_PROX_CTRL5_RANGE_SMALL | { SX9310_REG_PROX_CTRL5, SX9310_REG_PROX_CTRL5_RANGE_SMALL |
SX9310_REG_PROX_CTRL5_STARTUPSENS_CS1 | SX9310_REG_PROX_CTRL5_STARTUPSENS_CS1 |
SX9310_REG_PROX_CTRL5_RAWFILT_1P25), SX9310_REG_PROX_CTRL5_RAWFILT_1P25 },
SX_INIT(PROX_CTRL6, SX9310_REG_PROX_CTRL6_COMP_COMMON), { SX9310_REG_PROX_CTRL6, SX9310_REG_PROX_CTRL6_AVGTHRESH_DEFAULT },
SX_INIT(PROX_CTRL7, SX9310_REG_PROX_CTRL7_AVGNEGFILT_2 | { SX9310_REG_PROX_CTRL7, SX9310_REG_PROX_CTRL7_AVGNEGFILT_2 |
SX9310_REG_PROX_CTRL7_AVGPOSFILT_512), SX9310_REG_PROX_CTRL7_AVGPOSFILT_512 },
SX_INIT(PROX_CTRL8, SX9310_REG_PROX_CTRL8_9_PTHRESH_96 | { SX9310_REG_PROX_CTRL8, SX9310_REG_PROX_CTRL8_9_PTHRESH_96 |
SX9310_REG_PROX_CTRL8_9_BODYTHRESH_1500), SX9310_REG_PROX_CTRL8_9_BODYTHRESH_1500 },
SX_INIT(PROX_CTRL9, SX9310_REG_PROX_CTRL8_9_PTHRESH12_28 | { SX9310_REG_PROX_CTRL9, SX9310_REG_PROX_CTRL8_9_PTHRESH_28 |
SX9310_REG_PROX_CTRL8_9_BODYTHRESH_900), SX9310_REG_PROX_CTRL8_9_BODYTHRESH_900 },
SX_INIT(PROX_CTRL10, SX9310_REG_PROX_CTRL10_HYST_6PCT | { SX9310_REG_PROX_CTRL10, SX9310_REG_PROX_CTRL10_HYST_6PCT |
SX9310_REG_PROX_CTRL10_CLOSE_DEBOUNCE_8 | SX9310_REG_PROX_CTRL10_FAR_DEBOUNCE_2 },
SX9310_REG_PROX_CTRL10_FAR_DEBOUNCE_8), { SX9310_REG_PROX_CTRL11, 0x00 },
SX_INIT(PROX_CTRL11, 0x00), { SX9310_REG_PROX_CTRL12, 0x00 },
SX_INIT(PROX_CTRL12, 0x00), { SX9310_REG_PROX_CTRL13, 0x00 },
SX_INIT(PROX_CTRL13, 0x00), { SX9310_REG_PROX_CTRL14, 0x00 },
SX_INIT(PROX_CTRL14, 0x00), { SX9310_REG_PROX_CTRL15, 0x00 },
SX_INIT(PROX_CTRL15, 0x00), { SX9310_REG_PROX_CTRL16, 0x00 },
SX_INIT(PROX_CTRL16, 0x00), { SX9310_REG_PROX_CTRL17, 0x00 },
SX_INIT(PROX_CTRL17, 0x00), { SX9310_REG_PROX_CTRL18, 0x00 },
SX_INIT(PROX_CTRL18, 0x00), { SX9310_REG_PROX_CTRL19, 0x00 },
SX_INIT(PROX_CTRL19, 0x00), { SX9310_REG_SAR_CTRL0, SX9310_REG_SAR_CTRL0_SARDEB_4_SAMPLES |
SX_INIT(SAR_CTRL0, SX9310_REG_SAR_CTRL0_SARDEB_4_SAMPLES | SX9310_REG_SAR_CTRL0_SARHYST_8 },
SX9310_REG_SAR_CTRL0_SARHYST_8), { SX9310_REG_SAR_CTRL1, SX9310_REG_SAR_CTRL1_SLOPE(10781250) },
SX_INIT(SAR_CTRL1, SX9310_REG_SAR_CTRL1_SLOPE(10781250)), { SX9310_REG_SAR_CTRL2, SX9310_REG_SAR_CTRL2_SAROFFSET_DEFAULT },
SX_INIT(SAR_CTRL2, SX9310_REG_SAR_CTRL2_SAROFFSET_DEFAULT),
}; };
/* Activate all channels and perform an initial compensation. */ /* Activate all channels and perform an initial compensation. */
@ -807,7 +797,7 @@ static int sx9310_init_compensation(struct iio_dev *indio_dev)
/* run the compensation phase on all channels */ /* run the compensation phase on all channels */
ret = regmap_write(data->regmap, SX9310_REG_PROX_CTRL0, ret = regmap_write(data->regmap, SX9310_REG_PROX_CTRL0,
ctrl0 | SX9310_REG_PROX_CTRL0_EN_MASK); ctrl0 | SX9310_REG_PROX_CTRL0_SENSOREN_MASK);
if (ret < 0) if (ret < 0)
return ret; return ret;
@ -816,7 +806,7 @@ static int sx9310_init_compensation(struct iio_dev *indio_dev)
ret = regmap_read(data->regmap, SX9310_REG_STAT1, &val); ret = regmap_read(data->regmap, SX9310_REG_STAT1, &val);
if (ret < 0) if (ret < 0)
goto out; goto out;
if (!(val & SX9310_COMPSTAT_MASK)) if (!(val & SX9310_REG_STAT1_COMPSTAT_MASK))
break; break;
} }
@ -989,7 +979,7 @@ static int __maybe_unused sx9310_suspend(struct device *dev)
if (ret) if (ret)
goto out; goto out;
ctrl0 = data->suspend_ctrl0 & ~SX9310_REG_PROX_CTRL0_EN_MASK; ctrl0 = data->suspend_ctrl0 & ~SX9310_REG_PROX_CTRL0_SENSOREN_MASK;
ret = regmap_write(data->regmap, SX9310_REG_PROX_CTRL0, ctrl0); ret = regmap_write(data->regmap, SX9310_REG_PROX_CTRL0, ctrl0);
if (ret) if (ret)
goto out; goto out;