Lines Matching +full:ph23 +full:- +full:proxraw +full:- +full:strength
1 // SPDX-License-Identifier: GPL-2.0
186 ret = regmap_read(data->regmap, SX9324_REG_AFE_PH0 + chan->channel, &val); in sx9324_phase_configuration_show()
195 buf[len - 1] = '\n'; in sx9324_phase_configuration_show()
315 regmap_reg_range(SX9324_REG_IRQ_CFG2 + 1, SX9324_REG_GNRL_CTRL0 - 1),
316 regmap_reg_range(SX9324_REG_GNRL_CTRL1 + 1, SX9324_REG_AFE_CTRL0 - 1),
317 regmap_reg_range(SX9324_REG_AFE_CTRL9 + 1, SX9324_REG_PROX_CTRL0 - 1),
318 regmap_reg_range(SX9324_REG_PROX_CTRL7 + 1, SX9324_REG_ADV_CTRL0 - 1),
319 regmap_reg_range(SX9324_REG_ADV_CTRL20 + 1, SX9324_REG_PHASE_SEL - 1),
320 regmap_reg_range(SX9324_REG_SAR_LSB + 1, SX9324_REG_RESET - 1),
321 regmap_reg_range(SX9324_REG_RESET + 1, SX9324_REG_WHOAMI - 1),
322 regmap_reg_range(SX9324_REG_WHOAMI + 1, SX9324_REG_REVISION - 1),
361 ret = regmap_write(data->regmap, SX9324_REG_PHASE_SEL, chan->channel); in sx9324_read_prox_data()
365 return regmap_bulk_read(data->regmap, chan->address, val, sizeof(*val)); in sx9324_read_prox_data()
377 ret = regmap_read(data->regmap, SX9324_REG_GNRL_CTRL0, &val); in sx9324_wait_for_sample()
393 reg = SX9324_REG_PROX_CTRL0 + chan->channel / 2; in sx9324_read_gain()
394 ret = regmap_read(data->regmap, reg, ®val); in sx9324_read_gain()
400 regval--; in sx9324_read_gain()
403 return -EINVAL; in sx9324_read_gain()
416 ret = regmap_read(data->regmap, SX9324_REG_GNRL_CTRL0, ®val); in sx9324_read_samp_freq()
437 return -EBUSY; in sx9324_read_raw()
444 return -EBUSY; in sx9324_read_raw()
452 return -EINVAL; in sx9324_read_raw()
463 if (chan->type != IIO_PROXIMITY) in sx9324_read_avail()
464 return -EINVAL; in sx9324_read_avail()
478 return -EINVAL; in sx9324_read_avail()
493 return -EINVAL; in sx9324_set_samp_freq()
495 guard(mutex)(&data->mutex); in sx9324_set_samp_freq()
497 return regmap_update_bits(data->regmap, in sx9324_set_samp_freq()
514 reg = SX9324_REG_PROX_CTRL6 + chan->channel / 2; in sx9324_read_thresh()
515 ret = regmap_read(data->regmap, reg, ®val); in sx9324_read_thresh()
537 ret = regmap_read(data->regmap, SX9324_REG_PROX_CTRL5, ®val); in sx9324_read_hysteresis()
545 *val = pthresh >> (5 - regval); in sx9324_read_hysteresis()
555 ret = regmap_read(data->regmap, SX9324_REG_PROX_CTRL5, ®val); in sx9324_read_far_debounce()
573 ret = regmap_read(data->regmap, SX9324_REG_PROX_CTRL5, ®val); in sx9324_read_close_debounce()
594 if (chan->type != IIO_PROXIMITY) in sx9324_read_event_val()
595 return -EINVAL; in sx9324_read_event_val()
607 return -EINVAL; in sx9324_read_event_val()
612 return -EINVAL; in sx9324_read_event_val()
621 reg = SX9324_REG_PROX_CTRL6 + chan->channel / 2; in sx9324_write_thresh()
627 return -EINVAL; in sx9324_write_thresh()
629 guard(mutex)(&data->mutex); in sx9324_write_thresh()
631 return regmap_write(data->regmap, reg, val); in sx9324_write_thresh()
653 return -EINVAL; in sx9324_write_hysteresis()
656 guard(mutex)(&data->mutex); in sx9324_write_hysteresis()
658 return regmap_update_bits(data->regmap, SX9324_REG_PROX_CTRL5, in sx9324_write_hysteresis()
669 return -EINVAL; in sx9324_write_far_debounce()
673 guard(mutex)(&data->mutex); in sx9324_write_far_debounce()
675 return regmap_update_bits(data->regmap, SX9324_REG_PROX_CTRL5, in sx9324_write_far_debounce()
687 return -EINVAL; in sx9324_write_close_debounce()
691 guard(mutex)(&data->mutex); in sx9324_write_close_debounce()
693 return regmap_update_bits(data->regmap, SX9324_REG_PROX_CTRL5, in sx9324_write_close_debounce()
706 if (chan->type != IIO_PROXIMITY) in sx9324_write_event_val()
707 return -EINVAL; in sx9324_write_event_val()
719 return -EINVAL; in sx9324_write_event_val()
724 return -EINVAL; in sx9324_write_event_val()
733 reg = SX9324_REG_PROX_CTRL0 + chan->channel / 2; in sx9324_write_gain()
737 return -EINVAL; in sx9324_write_gain()
741 guard(mutex)(&data->mutex); in sx9324_write_gain()
743 return regmap_update_bits(data->regmap, reg, in sx9324_write_gain()
760 return -EINVAL; in sx9324_write_raw()
845 ret = regmap_set_bits(data->regmap, SX9324_REG_STAT2, in sx9324_init_compensation()
850 return regmap_read_poll_timeout(data->regmap, SX9324_REG_STAT2, val, in sx9324_init_compensation()
865 return reg_def->def; in sx9324_parse_phase_prop()
869 return reg_def->def; in sx9324_parse_phase_prop()
886 if (!reg_def->property || !adev) in sx_common_get_raw_register_config()
889 snprintf(prop, ARRAY_SIZE(prop), "%s,reg_%s", acpi_device_hid(adev), reg_def->property); in sx_common_get_raw_register_config()
894 reg_def->def = raw; in sx_common_get_raw_register_config()
904 static const char * const sx9324_csidle[] = { "hi-z", "hi-z", "gnd", in sx9324_get_default_reg()
913 switch (reg_def->reg) { in sx9324_get_default_reg()
915 reg_def->def = sx9324_parse_phase_prop(dev, reg_def, in sx9324_get_default_reg()
916 "semtech,ph0-pin"); in sx9324_get_default_reg()
919 reg_def->def = sx9324_parse_phase_prop(dev, reg_def, in sx9324_get_default_reg()
920 "semtech,ph1-pin"); in sx9324_get_default_reg()
923 reg_def->def = sx9324_parse_phase_prop(dev, reg_def, in sx9324_get_default_reg()
924 "semtech,ph2-pin"); in sx9324_get_default_reg()
927 reg_def->def = sx9324_parse_phase_prop(dev, reg_def, in sx9324_get_default_reg()
928 "semtech,ph3-pin"); in sx9324_get_default_reg()
931 ret = device_property_match_property_string(dev, "semtech,cs-idle-sleep", in sx9324_get_default_reg()
935 reg_def->def &= ~SX9324_REG_AFE_CTRL0_CSIDLE_MASK; in sx9324_get_default_reg()
936 reg_def->def |= ret << SX9324_REG_AFE_CTRL0_CSIDLE_SHIFT; in sx9324_get_default_reg()
939 ret = device_property_match_property_string(dev, "semtech,int-comp-resistor", in sx9324_get_default_reg()
943 reg_def->def &= ~SX9324_REG_AFE_CTRL0_RINT_MASK; in sx9324_get_default_reg()
944 reg_def->def |= ret << SX9324_REG_AFE_CTRL0_RINT_SHIFT; in sx9324_get_default_reg()
949 if (reg_def->reg == SX9324_REG_AFE_CTRL4) in sx9324_get_default_reg()
950 prop = "semtech,ph01-resolution"; in sx9324_get_default_reg()
952 prop = "semtech,ph23-resolution"; in sx9324_get_default_reg()
958 raw = ilog2(raw) - 3; in sx9324_get_default_reg()
960 reg_def->def &= ~SX9324_REG_AFE_CTRL4_RESOLUTION_MASK; in sx9324_get_default_reg()
961 reg_def->def |= FIELD_PREP(SX9324_REG_AFE_CTRL4_RESOLUTION_MASK, in sx9324_get_default_reg()
966 "semtech,input-precharge-resistor-ohms", in sx9324_get_default_reg()
971 reg_def->def &= ~SX9324_REG_AFE_CTRL8_RESFILTIN_MASK; in sx9324_get_default_reg()
972 reg_def->def |= FIELD_PREP(SX9324_REG_AFE_CTRL8_RESFILTIN_MASK, in sx9324_get_default_reg()
978 "semtech,input-analog-gain", &raw); in sx9324_get_default_reg()
983 * +---------+----------------+----------------+ in sx9324_get_default_reg()
985 * +---------+----------------+----------------+ in sx9324_get_default_reg()
990 * +---------+----------------+----------------+ in sx9324_get_default_reg()
992 reg_def->def &= ~SX9324_REG_AFE_CTRL9_AGAIN_MASK; in sx9324_get_default_reg()
993 reg_def->def |= FIELD_PREP(SX9324_REG_AFE_CTRL9_AGAIN_MASK, in sx9324_get_default_reg()
998 ret = device_property_read_u32(dev, "semtech,startup-sensor", in sx9324_get_default_reg()
1003 reg_def->def &= ~SX9324_REG_ADV_CTRL5_STARTUPSENS_MASK; in sx9324_get_default_reg()
1004 reg_def->def |= FIELD_PREP(SX9324_REG_ADV_CTRL5_STARTUPSENS_MASK, in sx9324_get_default_reg()
1008 ret = device_property_read_u32(dev, "semtech,avg-pos-strength", in sx9324_get_default_reg()
1014 raw = clamp(ilog2(pos), 3, 11) - (pos >= 32 ? 4 : 3); in sx9324_get_default_reg()
1016 reg_def->def &= ~SX9324_REG_PROX_CTRL4_AVGPOSFILT_MASK; in sx9324_get_default_reg()
1017 reg_def->def |= FIELD_PREP(SX9324_REG_PROX_CTRL4_AVGPOSFILT_MASK, in sx9324_get_default_reg()
1022 if (reg_def->reg == SX9324_REG_PROX_CTRL0) in sx9324_get_default_reg()
1023 prop = "semtech,ph01-proxraw-strength"; in sx9324_get_default_reg()
1025 prop = "semtech,ph23-proxraw-strength"; in sx9324_get_default_reg()
1030 reg_def->def &= ~SX9324_REG_PROX_CTRL0_RAWFILT_MASK; in sx9324_get_default_reg()
1031 reg_def->def |= FIELD_PREP(SX9324_REG_PROX_CTRL0_RAWFILT_MASK, in sx9324_get_default_reg()
1045 indio_dev->name = "sx9324"; in sx9324_check_whoami()
1092 disable_irq_nosync(data->client->irq); in sx9324_suspend()
1094 guard(mutex)(&data->mutex); in sx9324_suspend()
1095 ret = regmap_read(data->regmap, SX9324_REG_GNRL_CTRL1, ®val); in sx9324_suspend()
1099 data->suspend_ctrl = in sx9324_suspend()
1104 return regmap_write(data->regmap, SX9324_REG_GNRL_CTRL1, 0); in sx9324_suspend()
1111 scoped_guard(mutex, &data->mutex) { in sx9324_resume()
1112 int ret = regmap_write(data->regmap, SX9324_REG_GNRL_CTRL1, in sx9324_resume()
1113 data->suspend_ctrl | in sx9324_resume()
1119 enable_irq(data->client->irq); in sx9324_resume()