Commit 745712c7 authored by Barnabás Czémán's avatar Barnabás Czémán Committed by Jonathan Cameron

iio: light: stk3310: make chip id check expandable

Modify chip id check for support easier additions
for compatible variants.
Signed-off-by: default avatarBarnabás Czémán <trabarni@gmail.com>
Link: https://lore.kernel.org/r/20240521-stk3311-v1-2-07a4966b355a@gmail.comSigned-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 709aeedc
...@@ -81,6 +81,13 @@ static const struct reg_field stk3310_reg_field_flag_psint = ...@@ -81,6 +81,13 @@ static const struct reg_field stk3310_reg_field_flag_psint =
static const struct reg_field stk3310_reg_field_flag_nf = static const struct reg_field stk3310_reg_field_flag_nf =
REG_FIELD(STK3310_REG_FLAG, 0, 0); REG_FIELD(STK3310_REG_FLAG, 0, 0);
static const u8 stk3310_chip_ids[] = {
STK3310_CHIP_ID_VAL,
STK3311X_CHIP_ID_VAL,
STK3311_CHIP_ID_VAL,
STK3335_CHIP_ID_VAL,
};
/* Estimate maximum proximity values with regard to measurement scale. */ /* Estimate maximum proximity values with regard to measurement scale. */
static const int stk3310_ps_max[4] = { static const int stk3310_ps_max[4] = {
STK3310_PS_MAX_VAL / 640, STK3310_PS_MAX_VAL / 640,
...@@ -197,6 +204,16 @@ static const struct attribute_group stk3310_attribute_group = { ...@@ -197,6 +204,16 @@ static const struct attribute_group stk3310_attribute_group = {
.attrs = stk3310_attributes .attrs = stk3310_attributes
}; };
static int stk3310_check_chip_id(const u8 chip_id)
{
for (int i = 0; i < ARRAY_SIZE(stk3310_chip_ids); i++) {
if (chip_id == stk3310_chip_ids[i])
return 0;
}
return -ENODEV;
}
static int stk3310_get_index(const int table[][2], int table_size, static int stk3310_get_index(const int table[][2], int table_size,
int val, int val2) int val, int val2)
{ {
...@@ -473,12 +490,9 @@ static int stk3310_init(struct iio_dev *indio_dev) ...@@ -473,12 +490,9 @@ static int stk3310_init(struct iio_dev *indio_dev)
if (ret < 0) if (ret < 0)
return ret; return ret;
if (chipid != STK3310_CHIP_ID_VAL && ret = stk3310_check_chip_id(chipid);
chipid != STK3311_CHIP_ID_VAL && if (ret < 0)
chipid != STK3311X_CHIP_ID_VAL &&
chipid != STK3335_CHIP_ID_VAL) {
dev_warn(&client->dev, "unknown chip id: 0x%x\n", chipid); dev_warn(&client->dev, "unknown chip id: 0x%x\n", chipid);
}
state = STK3310_STATE_EN_ALS | STK3310_STATE_EN_PS; state = STK3310_STATE_EN_ALS | STK3310_STATE_EN_PS;
ret = stk3310_set_state(data, state); ret = stk3310_set_state(data, state);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment