Lines Matching +full:positive +full:- +full:port +full:- +full:input

4  * SPDX-License-Identifier: Apache-2.0
12 #include <zephyr/dt-bindings/adc/ads114s0x_adc.h>
85 FIELD_GET(GENMASK(pos + length - 1, pos), value)
87 target &= ~GENMASK(pos + length - 1, pos); \
88 target |= FIELD_PREP(GENMASK(pos + length - 1, pos), value)
356 * - AIN0 as positive input
357 * - AIN1 as negative input
363 * - disable reference monitor
364 * - enable positive reference buffer
365 * - disable negative reference buffer
366 * - use internal reference
367 * - enable internal voltage reference
376 * - disable global chop
377 * - use internal oscillator
378 * - single shot conversion mode
379 * - low latency filter
380 * - 20 samples per second
389 * - delay of 14*t_mod
390 * - disable gain
391 * - gain 1
398 * - disable PGA output rail flag
399 * - low-side power switch
400 * - IDAC off
407 * - disconnect IDAC1
408 * - disconnect IDAC2
439 uint8_t gpio_direction; /* one bit per GPIO, 1 = input */
453 k_sem_give(&data->data_ready_signal); in ads114s0x_data_ready_handler()
459 const struct ads114s0x_config *config = dev->config; in ads114s0x_read_register()
483 int result = spi_transceive_dt(&config->bus, &tx, &rx); in ads114s0x_read_register()
486 LOG_ERR("%s: spi_transceive failed with error %i", dev->name, result); in ads114s0x_read_register()
491 LOG_DBG("%s: read from register 0x%02X value 0x%02X", dev->name, register_address, *value); in ads114s0x_read_register()
499 const struct ads114s0x_config *config = dev->config; in ads114s0x_write_register()
515 LOG_DBG("%s: writing to register 0x%02X value 0x%02X", dev->name, register_address, value); in ads114s0x_write_register()
516 int result = spi_write_dt(&config->bus, &tx); in ads114s0x_write_register()
519 LOG_ERR("%s: spi_write failed with error %i", dev->name, result); in ads114s0x_write_register()
530 const struct ads114s0x_config *config = dev->config; in ads114s0x_write_multiple_registers()
548 LOG_WRN("%s: ignoring the command to write 0 registers", dev->name); in ads114s0x_write_multiple_registers()
549 return -EINVAL; in ads114s0x_write_multiple_registers()
553 buffer_tx[1] = count - 1; in ads114s0x_write_multiple_registers()
560 __ASSERT(register_addresses[i - 1] + 1 == register_addresses[i], in ads114s0x_write_multiple_registers()
564 int result = spi_write_dt(&config->bus, &tx); in ads114s0x_write_multiple_registers()
567 LOG_ERR("%s: spi_write failed with error %i", dev->name, result); in ads114s0x_write_multiple_registers()
576 const struct ads114s0x_config *config = dev->config; in ads114s0x_send_command()
589 LOG_DBG("%s: sending command 0x%02X", dev->name, command); in ads114s0x_send_command()
590 int result = spi_write_dt(&config->bus, &tx); in ads114s0x_send_command()
593 LOG_ERR("%s: spi_write failed with error %i", dev->name, result); in ads114s0x_send_command()
603 const struct ads114s0x_config *config = dev->config; in ads114s0x_channel_setup()
616 uint16_t acquisition_time_value = ADC_ACQ_TIME_VALUE(channel_cfg->acquisition_time); in ads114s0x_channel_setup()
617 uint16_t acquisition_time_unit = ADC_ACQ_TIME_UNIT(channel_cfg->acquisition_time); in ads114s0x_channel_setup()
626 if (channel_cfg->channel_id != 0) { in ads114s0x_channel_setup()
627 LOG_ERR("%s: only one channel is supported", dev->name); in ads114s0x_channel_setup()
628 return -EINVAL; in ads114s0x_channel_setup()
636 if (channel_cfg->acquisition_time != ADC_ACQ_TIME_DEFAULT && in ads114s0x_channel_setup()
638 LOG_ERR("%s: invalid acquisition time %i", dev->name, in ads114s0x_channel_setup()
639 channel_cfg->acquisition_time); in ads114s0x_channel_setup()
640 return -EINVAL; in ads114s0x_channel_setup()
643 if (channel_cfg->acquisition_time == ADC_ACQ_TIME_DEFAULT) { in ads114s0x_channel_setup()
649 switch (channel_cfg->reference) { in ads114s0x_channel_setup()
653 /* disable positive reference buffer */ in ads114s0x_channel_setup()
661 /* enable positive reference buffer */ in ads114s0x_channel_setup()
669 /* enable positive reference buffer */ in ads114s0x_channel_setup()
675 LOG_ERR("%s: reference %i is not supported", dev->name, channel_cfg->reference); in ads114s0x_channel_setup()
676 return -EINVAL; in ads114s0x_channel_setup()
679 if (channel_cfg->differential) { in ads114s0x_channel_setup()
682 dev->name, channel_cfg->input_positive, channel_cfg->input_negative); in ads114s0x_channel_setup()
683 if (channel_cfg->input_positive >= ADS114S0X_INPUT_SELECTION_AINCOM) { in ads114s0x_channel_setup()
684 LOG_ERR("%s: positive channel input %i is invalid", dev->name, in ads114s0x_channel_setup()
685 channel_cfg->input_positive); in ads114s0x_channel_setup()
686 return -EINVAL; in ads114s0x_channel_setup()
689 if (channel_cfg->input_negative >= ADS114S0X_INPUT_SELECTION_AINCOM) { in ads114s0x_channel_setup()
690 LOG_ERR("%s: negative channel input %i is invalid", dev->name, in ads114s0x_channel_setup()
691 channel_cfg->input_negative); in ads114s0x_channel_setup()
692 return -EINVAL; in ads114s0x_channel_setup()
695 if (channel_cfg->input_positive == channel_cfg->input_negative) { in ads114s0x_channel_setup()
696 LOG_ERR("%s: negative and positive channel inputs must be different", in ads114s0x_channel_setup()
697 dev->name); in ads114s0x_channel_setup()
698 return -EINVAL; in ads114s0x_channel_setup()
701 ADS114S0X_REGISTER_INPMUX_MUXP_SET(input_mux, channel_cfg->input_positive); in ads114s0x_channel_setup()
702 ADS114S0X_REGISTER_INPMUX_MUXN_SET(input_mux, channel_cfg->input_negative); in ads114s0x_channel_setup()
703 pin_selections[0] = channel_cfg->input_positive; in ads114s0x_channel_setup()
704 pin_selections[1] = channel_cfg->input_negative; in ads114s0x_channel_setup()
706 LOG_DBG("%s: configuring channel for single ended measurement from input %i", in ads114s0x_channel_setup()
707 dev->name, channel_cfg->input_positive); in ads114s0x_channel_setup()
708 if (channel_cfg->input_positive >= ADS114S0X_INPUT_SELECTION_AINCOM) { in ads114s0x_channel_setup()
709 LOG_ERR("%s: channel input %i is invalid", dev->name, in ads114s0x_channel_setup()
710 channel_cfg->input_positive); in ads114s0x_channel_setup()
711 return -EINVAL; in ads114s0x_channel_setup()
714 ADS114S0X_REGISTER_INPMUX_MUXP_SET(input_mux, channel_cfg->input_positive); in ads114s0x_channel_setup()
716 pin_selections[0] = channel_cfg->input_positive; in ads114s0x_channel_setup()
720 switch (channel_cfg->gain) { in ads114s0x_channel_setup()
747 LOG_ERR("%s: gain value %i not supported", dev->name, channel_cfg->gain); in ads114s0x_channel_setup()
748 return -EINVAL; in ads114s0x_channel_setup()
751 if (channel_cfg->gain != ADC_GAIN_1) { in ads114s0x_channel_setup()
756 switch (config->idac_current) { in ads114s0x_channel_setup()
788 LOG_ERR("%s: IDAC magnitude %i not supported", dev->name, config->idac_current); in ads114s0x_channel_setup()
789 return -EINVAL; in ads114s0x_channel_setup()
792 if (channel_cfg->current_source_pin_set) { in ads114s0x_channel_setup()
793 LOG_DBG("%s: current source pin set to %i and %i", dev->name, in ads114s0x_channel_setup()
794 channel_cfg->current_source_pin[0], channel_cfg->current_source_pin[1]); in ads114s0x_channel_setup()
795 if (channel_cfg->current_source_pin[0] > 0b1111) { in ads114s0x_channel_setup()
796 LOG_ERR("%s: invalid selection %i for I1MUX", dev->name, in ads114s0x_channel_setup()
797 channel_cfg->current_source_pin[0]); in ads114s0x_channel_setup()
798 return -EINVAL; in ads114s0x_channel_setup()
801 if (channel_cfg->current_source_pin[1] > 0b1111) { in ads114s0x_channel_setup()
802 LOG_ERR("%s: invalid selection %i for I2MUX", dev->name, in ads114s0x_channel_setup()
803 channel_cfg->current_source_pin[1]); in ads114s0x_channel_setup()
804 return -EINVAL; in ads114s0x_channel_setup()
807 ADS114S0X_REGISTER_IDACMUX_I1MUX_SET(idac_mux, channel_cfg->current_source_pin[0]); in ads114s0x_channel_setup()
808 ADS114S0X_REGISTER_IDACMUX_I2MUX_SET(idac_mux, channel_cfg->current_source_pin[1]); in ads114s0x_channel_setup()
809 pin_selections[2] = channel_cfg->current_source_pin[0]; in ads114s0x_channel_setup()
810 pin_selections[3] = channel_cfg->current_source_pin[1]; in ads114s0x_channel_setup()
813 LOG_DBG("%s: current source pins not set", dev->name); in ads114s0x_channel_setup()
829 dev->name); in ads114s0x_channel_setup()
830 return -EINVAL; in ads114s0x_channel_setup()
835 ADS114S0X_REGISTER_VBIAS_VB_LEVEL_SET(vbias, config->vbias_level); in ads114s0x_channel_setup()
837 if ((channel_cfg->vbias_pins & in ads114s0x_channel_setup()
839 LOG_ERR("%s: invalid VBIAS pin selection 0x%08X", dev->name, in ads114s0x_channel_setup()
840 channel_cfg->vbias_pins); in ads114s0x_channel_setup()
841 return -EINVAL; in ads114s0x_channel_setup()
844 vbias |= channel_cfg->vbias_pins; in ads114s0x_channel_setup()
867 LOG_ERR("%s: unable to configure registers", dev->name); in ads114s0x_channel_setup()
878 if (sequence->options) { in ads114s0x_validate_buffer_size()
879 needed *= (1 + sequence->options->extra_samplings); in ads114s0x_validate_buffer_size()
882 if (sequence->buffer_size < needed) { in ads114s0x_validate_buffer_size()
883 return -ENOMEM; in ads114s0x_validate_buffer_size()
892 if (sequence->resolution != ADS114S0X_RESOLUTION) { in ads114s0x_validate_sequence()
893 LOG_ERR("%s: invalid resolution", dev->name); in ads114s0x_validate_sequence()
894 return -EINVAL; in ads114s0x_validate_sequence()
897 if (sequence->channels != BIT(0)) { in ads114s0x_validate_sequence()
898 LOG_ERR("%s: invalid channel", dev->name); in ads114s0x_validate_sequence()
899 return -EINVAL; in ads114s0x_validate_sequence()
902 if (sequence->oversampling) { in ads114s0x_validate_sequence()
903 LOG_ERR("%s: oversampling is not supported", dev->name); in ads114s0x_validate_sequence()
904 return -EINVAL; in ads114s0x_validate_sequence()
915 data->buffer = data->buffer_ptr; in adc_context_update_buffer_pointer()
923 data->buffer_ptr = data->buffer; in adc_context_start_sampling()
924 k_sem_give(&data->acquire_signal); in adc_context_start_sampling()
931 struct ads114s0x_data *data = dev->data; in ads114s0x_adc_start_read()
936 LOG_ERR("%s: sequence validation failed", dev->name); in ads114s0x_adc_start_read()
940 data->buffer = sequence->buffer; in ads114s0x_adc_start_read()
942 adc_context_start_read(&data->ctx, sequence); in ads114s0x_adc_start_read()
945 result = adc_context_wait_for_completion(&data->ctx); in ads114s0x_adc_start_read()
953 const struct ads114s0x_config *config = dev->config; in ads114s0x_send_start_read()
956 if (config->gpio_start_sync.port == 0) { in ads114s0x_send_start_read()
959 LOG_ERR("%s: unable to send START/SYNC command", dev->name); in ads114s0x_send_start_read()
963 result = gpio_pin_set_dt(&config->gpio_start_sync, 1); in ads114s0x_send_start_read()
966 LOG_ERR("%s: unable to start ADC operation", dev->name); in ads114s0x_send_start_read()
973 result = gpio_pin_set_dt(&config->gpio_start_sync, 0); in ads114s0x_send_start_read()
976 LOG_ERR("%s: unable to start ADC operation", dev->name); in ads114s0x_send_start_read()
986 struct ads114s0x_data *data = dev->data; in ads114s0x_wait_data_ready()
988 return k_sem_take(&data->data_ready_signal, ADC_CONTEXT_WAIT_FOR_COMPLETION_TIMEOUT); in ads114s0x_wait_data_ready()
993 const struct ads114s0x_config *config = dev->config; in ads114s0x_read_sample()
1015 int result = spi_transceive_dt(&config->bus, &tx, &rx); in ads114s0x_read_sample()
1018 LOG_ERR("%s: spi_transceive failed with error %i", dev->name, result); in ads114s0x_read_sample()
1023 LOG_DBG("%s: read ADC sample %i", dev->name, *buffer); in ads114s0x_read_sample()
1031 struct ads114s0x_data *data = dev->data; in ads114s0x_adc_perform_read()
1033 k_sem_take(&data->acquire_signal, K_FOREVER); in ads114s0x_adc_perform_read()
1034 k_sem_reset(&data->data_ready_signal); in ads114s0x_adc_perform_read()
1038 LOG_ERR("%s: unable to start ADC conversion", dev->name); in ads114s0x_adc_perform_read()
1039 adc_context_complete(&data->ctx, result); in ads114s0x_adc_perform_read()
1045 LOG_ERR("%s: waiting for data to be ready failed", dev->name); in ads114s0x_adc_perform_read()
1046 adc_context_complete(&data->ctx, result); in ads114s0x_adc_perform_read()
1050 result = ads114s0x_read_sample(dev, data->buffer); in ads114s0x_adc_perform_read()
1052 LOG_ERR("%s: reading sample failed", dev->name); in ads114s0x_adc_perform_read()
1053 adc_context_complete(&data->ctx, result); in ads114s0x_adc_perform_read()
1057 data->buffer++; in ads114s0x_adc_perform_read()
1059 adc_context_on_sampling_done(&data->ctx, dev); in ads114s0x_adc_perform_read()
1069 struct ads114s0x_data *data = dev->data; in ads114s0x_adc_read_async()
1071 adc_context_lock(&data->ctx, true, async); in ads114s0x_adc_read_async()
1073 adc_context_release(&data->ctx, result); in ads114s0x_adc_read_async()
1081 struct ads114s0x_data *data = dev->data; in ads114s0x_read()
1083 adc_context_lock(&data->ctx, false, NULL); in ads114s0x_read()
1085 adc_context_release(&data->ctx, result); in ads114s0x_read()
1094 struct ads114s0x_data *data = dev->data; in ads114s0x_read()
1096 adc_context_lock(&data->ctx, false, NULL); in ads114s0x_read()
1099 while (result == 0 && k_sem_take(&data->ctx.sync, K_NO_WAIT) != 0) { in ads114s0x_read()
1103 adc_context_release(&data->ctx, result); in ads114s0x_read()
1124 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_write_config()
1130 ADS114S0X_REGISTER_GPIOCON_CON_SET(gpio_con, data->gpio_enabled); in ads114s0x_gpio_write_config()
1131 ADS114S0X_REGISTER_GPIODAT_DAT_SET(gpio_dat, data->gpio_value); in ads114s0x_gpio_write_config()
1132 ADS114S0X_REGISTER_GPIODAT_DIR_SET(gpio_dat, data->gpio_direction); in ads114s0x_gpio_write_config()
1144 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_write_value()
1147 ADS114S0X_REGISTER_GPIODAT_DAT_SET(gpio_dat, data->gpio_value); in ads114s0x_gpio_write_value()
1148 ADS114S0X_REGISTER_GPIODAT_DIR_SET(gpio_dat, data->gpio_direction); in ads114s0x_gpio_write_value()
1155 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_set_output()
1159 LOG_ERR("%s: invalid pin %i", dev->name, pin); in ads114s0x_gpio_set_output()
1160 return -EINVAL; in ads114s0x_gpio_set_output()
1163 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_set_output()
1165 data->gpio_enabled |= BIT(pin); in ads114s0x_gpio_set_output()
1166 data->gpio_direction &= ~BIT(pin); in ads114s0x_gpio_set_output()
1169 data->gpio_value |= BIT(pin); in ads114s0x_gpio_set_output()
1171 data->gpio_value &= ~BIT(pin); in ads114s0x_gpio_set_output()
1176 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_set_output()
1183 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_set_input()
1187 LOG_ERR("%s: invalid pin %i", dev->name, pin); in ads114s0x_gpio_set_input()
1188 return -EINVAL; in ads114s0x_gpio_set_input()
1191 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_set_input()
1193 data->gpio_enabled |= BIT(pin); in ads114s0x_gpio_set_input()
1194 data->gpio_direction |= BIT(pin); in ads114s0x_gpio_set_input()
1195 data->gpio_value &= ~BIT(pin); in ads114s0x_gpio_set_input()
1199 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_set_input()
1206 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_deconfigure()
1210 LOG_ERR("%s: invalid pin %i", dev->name, pin); in ads114s0x_gpio_deconfigure()
1211 return -EINVAL; in ads114s0x_gpio_deconfigure()
1214 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_deconfigure()
1216 data->gpio_enabled &= ~BIT(pin); in ads114s0x_gpio_deconfigure()
1217 data->gpio_direction |= BIT(pin); in ads114s0x_gpio_deconfigure()
1218 data->gpio_value &= ~BIT(pin); in ads114s0x_gpio_deconfigure()
1222 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_deconfigure()
1229 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_set_pin_value()
1233 LOG_ERR("%s: invalid pin %i", dev->name, pin); in ads114s0x_gpio_set_pin_value()
1234 return -EINVAL; in ads114s0x_gpio_set_pin_value()
1237 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_set_pin_value()
1239 if ((BIT(pin) & data->gpio_enabled) == 0) { in ads114s0x_gpio_set_pin_value()
1240 LOG_ERR("%s: gpio pin %i not configured", dev->name, pin); in ads114s0x_gpio_set_pin_value()
1241 result = -EINVAL; in ads114s0x_gpio_set_pin_value()
1242 } else if ((BIT(pin) & data->gpio_direction) != 0) { in ads114s0x_gpio_set_pin_value()
1243 LOG_ERR("%s: gpio pin %i not configured as output", dev->name, pin); in ads114s0x_gpio_set_pin_value()
1244 result = -EINVAL; in ads114s0x_gpio_set_pin_value()
1246 data->gpio_value |= BIT(pin); in ads114s0x_gpio_set_pin_value()
1251 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_set_pin_value()
1258 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_get_pin_value()
1263 LOG_ERR("%s: invalid pin %i", dev->name, pin); in ads114s0x_gpio_get_pin_value()
1264 return -EINVAL; in ads114s0x_gpio_get_pin_value()
1267 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_get_pin_value()
1269 if ((BIT(pin) & data->gpio_enabled) == 0) { in ads114s0x_gpio_get_pin_value()
1270 LOG_ERR("%s: gpio pin %i not configured", dev->name, pin); in ads114s0x_gpio_get_pin_value()
1271 result = -EINVAL; in ads114s0x_gpio_get_pin_value()
1272 } else if ((BIT(pin) & data->gpio_direction) == 0) { in ads114s0x_gpio_get_pin_value()
1273 LOG_ERR("%s: gpio pin %i not configured as input", dev->name, pin); in ads114s0x_gpio_get_pin_value()
1274 result = -EINVAL; in ads114s0x_gpio_get_pin_value()
1277 data->gpio_value = ADS114S0X_REGISTER_GPIODAT_DAT_GET(gpio_dat); in ads114s0x_gpio_get_pin_value()
1278 *value = (BIT(pin) & data->gpio_value) != 0; in ads114s0x_gpio_get_pin_value()
1281 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_get_pin_value()
1288 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_port_get_raw()
1292 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_port_get_raw()
1295 data->gpio_value = ADS114S0X_REGISTER_GPIODAT_DAT_GET(gpio_dat); in ads114s0x_gpio_port_get_raw()
1296 *value = data->gpio_value; in ads114s0x_gpio_port_get_raw()
1298 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_port_get_raw()
1306 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_port_set_masked_raw()
1309 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_port_set_masked_raw()
1311 data->gpio_value = ((data->gpio_value & ~mask) | (mask & value)) & data->gpio_enabled & in ads114s0x_gpio_port_set_masked_raw()
1312 ~data->gpio_direction; in ads114s0x_gpio_port_set_masked_raw()
1315 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_port_set_masked_raw()
1322 struct ads114s0x_data *data = dev->data; in ads114s0x_gpio_port_toggle_bits()
1325 k_mutex_lock(&data->gpio_lock, K_FOREVER); in ads114s0x_gpio_port_toggle_bits()
1327 data->gpio_value = (data->gpio_value ^ pins) & data->gpio_enabled & ~data->gpio_direction; in ads114s0x_gpio_port_toggle_bits()
1330 k_mutex_unlock(&data->gpio_lock); in ads114s0x_gpio_port_toggle_bits()
1343 const struct ads114s0x_config *config = dev->config; in ads114s0x_init()
1344 struct ads114s0x_data *data = dev->data; in ads114s0x_init()
1346 adc_context_init(&data->ctx); in ads114s0x_init()
1348 k_sem_init(&data->data_ready_signal, 0, 1); in ads114s0x_init()
1349 k_sem_init(&data->acquire_signal, 0, 1); in ads114s0x_init()
1352 k_mutex_init(&data->gpio_lock); in ads114s0x_init()
1355 if (!spi_is_ready_dt(&config->bus)) { in ads114s0x_init()
1356 LOG_ERR("%s: SPI device is not ready", dev->name); in ads114s0x_init()
1357 return -ENODEV; in ads114s0x_init()
1360 if (config->gpio_reset.port != NULL) { in ads114s0x_init()
1361 result = gpio_pin_configure_dt(&config->gpio_reset, GPIO_OUTPUT_ACTIVE); in ads114s0x_init()
1363 LOG_ERR("%s: failed to initialize GPIO for reset", dev->name); in ads114s0x_init()
1368 if (config->gpio_start_sync.port != NULL) { in ads114s0x_init()
1369 result = gpio_pin_configure_dt(&config->gpio_start_sync, GPIO_OUTPUT_INACTIVE); in ads114s0x_init()
1371 LOG_ERR("%s: failed to initialize GPIO for start/sync", dev->name); in ads114s0x_init()
1376 result = gpio_pin_configure_dt(&config->gpio_data_ready, GPIO_INPUT); in ads114s0x_init()
1378 LOG_ERR("%s: failed to initialize GPIO for data ready", dev->name); in ads114s0x_init()
1382 result = gpio_pin_interrupt_configure_dt(&config->gpio_data_ready, GPIO_INT_EDGE_TO_ACTIVE); in ads114s0x_init()
1384 LOG_ERR("%s: failed to configure data ready interrupt", dev->name); in ads114s0x_init()
1385 return -EIO; in ads114s0x_init()
1388 gpio_init_callback(&data->callback_data_ready, ads114s0x_data_ready_handler, in ads114s0x_init()
1389 BIT(config->gpio_data_ready.pin)); in ads114s0x_init()
1390 result = gpio_add_callback(config->gpio_data_ready.port, &data->callback_data_ready); in ads114s0x_init()
1392 LOG_ERR("%s: failed to add data ready callback", dev->name); in ads114s0x_init()
1393 return -EIO; in ads114s0x_init()
1397 k_tid_t tid = k_thread_create(&data->thread, config->stack, in ads114s0x_init()
1406 if (config->gpio_reset.port == NULL) { in ads114s0x_init()
1409 LOG_ERR("%s: unable to send RESET command", dev->name); in ads114s0x_init()
1414 gpio_pin_set_dt(&config->gpio_reset, 0); in ads114s0x_init()
1421 LOG_ERR("%s: unable to read status register", dev->name); in ads114s0x_init()
1426 LOG_ERR("%s: ADS114 is not yet ready", dev->name); in ads114s0x_init()
1427 return -EBUSY; in ads114s0x_init()
1438 LOG_ERR("%s: unable to set default reference control values", dev->name); in ads114s0x_init()
1447 LOG_ERR("%s: unable to read reference control values", dev->name); in ads114s0x_init()
1452 LOG_ERR("%s: reference control register is incorrect: 0x%02X", dev->name, in ads114s0x_init()
1454 return -EIO; in ads114s0x_init()
1458 data->gpio_enabled = 0x00; in ads114s0x_init()
1459 data->gpio_direction = 0x0F; in ads114s0x_init()
1460 data->gpio_value = 0x00; in ads114s0x_init()
1465 LOG_ERR("%s: unable to configure defaults for GPIOs", dev->name); in ads114s0x_init()
1470 adc_context_unlock_unconditionally(&data->ctx); in ads114s0x_init()