Lines Matching refs:adis

25 	struct adis *adis = iio_device_get_drvdata(indio_dev);  in adis_update_scan_mode_burst()  local
29 burst_length = adis->data->burst_len + adis->burst_extra_len; in adis_update_scan_mode_burst()
31 if (adis->data->burst_max_len) in adis_update_scan_mode_burst()
32 burst_max_length = adis->data->burst_max_len; in adis_update_scan_mode_burst()
36 adis->xfer = kcalloc(2, sizeof(*adis->xfer), GFP_KERNEL); in adis_update_scan_mode_burst()
37 if (!adis->xfer) in adis_update_scan_mode_burst()
40 adis->buffer = kzalloc(burst_max_length + sizeof(u16), GFP_KERNEL); in adis_update_scan_mode_burst()
41 if (!adis->buffer) { in adis_update_scan_mode_burst()
42 kfree(adis->xfer); in adis_update_scan_mode_burst()
43 adis->xfer = NULL; in adis_update_scan_mode_burst()
47 tx = adis->buffer + burst_max_length; in adis_update_scan_mode_burst()
48 tx[0] = ADIS_READ_REG(adis->data->burst_reg_cmd); in adis_update_scan_mode_burst()
51 adis->xfer[0].tx_buf = tx; in adis_update_scan_mode_burst()
52 adis->xfer[0].bits_per_word = 8; in adis_update_scan_mode_burst()
53 adis->xfer[0].len = 2; in adis_update_scan_mode_burst()
54 if (adis->data->burst_max_speed_hz) in adis_update_scan_mode_burst()
55 adis->xfer[0].speed_hz = adis->data->burst_max_speed_hz; in adis_update_scan_mode_burst()
56 adis->xfer[1].rx_buf = adis->buffer; in adis_update_scan_mode_burst()
57 adis->xfer[1].bits_per_word = 8; in adis_update_scan_mode_burst()
58 adis->xfer[1].len = burst_length; in adis_update_scan_mode_burst()
59 if (adis->data->burst_max_speed_hz) in adis_update_scan_mode_burst()
60 adis->xfer[1].speed_hz = adis->data->burst_max_speed_hz; in adis_update_scan_mode_burst()
62 spi_message_init(&adis->msg); in adis_update_scan_mode_burst()
63 spi_message_add_tail(&adis->xfer[0], &adis->msg); in adis_update_scan_mode_burst()
64 spi_message_add_tail(&adis->xfer[1], &adis->msg); in adis_update_scan_mode_burst()
72 struct adis *adis = iio_device_get_drvdata(indio_dev); in adis_update_scan_mode() local
78 kfree(adis->xfer); in adis_update_scan_mode()
79 kfree(adis->buffer); in adis_update_scan_mode()
81 if (adis->data->burst_len) in adis_update_scan_mode()
86 adis->xfer = kcalloc(scan_count + 1, sizeof(*adis->xfer), GFP_KERNEL); in adis_update_scan_mode()
87 if (!adis->xfer) in adis_update_scan_mode()
90 adis->buffer = kcalloc(indio_dev->scan_bytes, 2, GFP_KERNEL); in adis_update_scan_mode()
91 if (!adis->buffer) { in adis_update_scan_mode()
92 kfree(adis->xfer); in adis_update_scan_mode()
93 adis->xfer = NULL; in adis_update_scan_mode()
97 rx = adis->buffer; in adis_update_scan_mode()
100 spi_message_init(&adis->msg); in adis_update_scan_mode()
103 adis->xfer[j].bits_per_word = 8; in adis_update_scan_mode()
105 adis->xfer[j].cs_change = 1; in adis_update_scan_mode()
106 adis->xfer[j].len = 2; in adis_update_scan_mode()
107 adis->xfer[j].delay.value = adis->data->read_delay; in adis_update_scan_mode()
108 adis->xfer[j].delay.unit = SPI_DELAY_UNIT_USECS; in adis_update_scan_mode()
110 adis->xfer[j].tx_buf = &tx[j]; in adis_update_scan_mode()
112 adis->xfer[j].rx_buf = &rx[j - 1]; in adis_update_scan_mode()
113 spi_message_add_tail(&adis->xfer[j], &adis->msg); in adis_update_scan_mode()
133 struct adis *adis = iio_device_get_drvdata(indio_dev); in adis_trigger_handler() local
136 if (adis->data->has_paging) { in adis_trigger_handler()
137 mutex_lock(&adis->state_lock); in adis_trigger_handler()
138 if (adis->current_page != 0) { in adis_trigger_handler()
139 adis->tx[0] = ADIS_WRITE_REG(ADIS_REG_PAGE_ID); in adis_trigger_handler()
140 adis->tx[1] = 0; in adis_trigger_handler()
141 ret = spi_write(adis->spi, adis->tx, 2); in adis_trigger_handler()
143 dev_err(&adis->spi->dev, "Failed to change device page: %d\n", ret); in adis_trigger_handler()
144 mutex_unlock(&adis->state_lock); in adis_trigger_handler()
148 adis->current_page = 0; in adis_trigger_handler()
152 ret = spi_sync(adis->spi, &adis->msg); in adis_trigger_handler()
153 if (adis->data->has_paging) in adis_trigger_handler()
154 mutex_unlock(&adis->state_lock); in adis_trigger_handler()
156 dev_err(&adis->spi->dev, "Failed to read data: %d", ret); in adis_trigger_handler()
160 iio_push_to_buffers_with_timestamp(indio_dev, adis->buffer, in adis_trigger_handler()
171 struct adis *adis = arg; in adis_buffer_cleanup() local
173 kfree(adis->buffer); in adis_buffer_cleanup()
174 kfree(adis->xfer); in adis_buffer_cleanup()
192 devm_adis_setup_buffer_and_trigger(struct adis *adis, struct iio_dev *indio_dev, in devm_adis_setup_buffer_and_trigger() argument
200 ret = devm_iio_triggered_buffer_setup(&adis->spi->dev, indio_dev, in devm_adis_setup_buffer_and_trigger()
206 if (adis->spi->irq) { in devm_adis_setup_buffer_and_trigger()
207 ret = devm_adis_probe_trigger(adis, indio_dev); in devm_adis_setup_buffer_and_trigger()
212 return devm_add_action_or_reset(&adis->spi->dev, adis_buffer_cleanup, in devm_adis_setup_buffer_and_trigger()
213 adis); in devm_adis_setup_buffer_and_trigger()