Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

iio: make use of devm_iio_kfifo_buffer_setup() helper

All drivers that already call devm_iio_kfifo_allocate() &
iio_device_attach_buffer() are simple to convert to
iio_device_attach_kfifo_buffer() in a single go.

This change does that; the unwind order is preserved.
What is important, is that the devm_iio_kfifo_buffer_setup() be called
after the indio_dev->modes is assigned, to make sure that
INDIO_BUFFER_SOFTWARE flag is set and not overridden by the assignment to
indio_dev->modes.

Also, the INDIO_BUFFER_SOFTWARE has been removed from the assignments of
'indio_dev->modes' because it is set by devm_iio_kfifo_buffer_setup().

Signed-off-by: Alexandru Ardelean <alexandru.ardelean@analog.com>
Reviewed-by: Gwendal Grignou <gwendal@chromium.org>
Reviewed-by: Matt Ranostay <matt.ranostay@konsulko.com>x
Link: https://lore.kernel.org/r/20210215104043.91251-4-alexandru.ardelean@analog.com
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>

authored by

Alexandru Ardelean and committed by
Jonathan Cameron
17395ce2 e36db6a0

+74 -124
+5 -9
drivers/iio/accel/ssp_accel_sensor.c
··· 96 96 int ret; 97 97 struct iio_dev *indio_dev; 98 98 struct ssp_sensor_data *spd; 99 - struct iio_buffer *buffer; 100 99 101 100 indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(*spd)); 102 101 if (!indio_dev) ··· 108 109 109 110 indio_dev->name = ssp_accel_device_name; 110 111 indio_dev->info = &ssp_accel_iio_info; 111 - indio_dev->modes = INDIO_BUFFER_SOFTWARE; 112 112 indio_dev->channels = ssp_acc_channels; 113 113 indio_dev->num_channels = ARRAY_SIZE(ssp_acc_channels); 114 114 indio_dev->available_scan_masks = ssp_accel_scan_mask; 115 115 116 - buffer = devm_iio_kfifo_allocate(&pdev->dev); 117 - if (!buffer) 118 - return -ENOMEM; 119 - 120 - iio_device_attach_buffer(indio_dev, buffer); 121 - 122 - indio_dev->setup_ops = &ssp_accel_buffer_ops; 116 + ret = devm_iio_kfifo_buffer_setup(&pdev->dev, indio_dev, 117 + INDIO_BUFFER_SOFTWARE, 118 + &ssp_accel_buffer_ops); 119 + if (ret) 120 + return ret; 123 121 124 122 platform_set_drvdata(pdev, indio_dev); 125 123
+6 -8
drivers/iio/adc/ina2xx-adc.c
··· 953 953 { 954 954 struct ina2xx_chip_info *chip; 955 955 struct iio_dev *indio_dev; 956 - struct iio_buffer *buffer; 957 956 unsigned int val; 958 957 enum ina2xx_ids type; 959 958 int ret; ··· 1016 1017 return ret; 1017 1018 } 1018 1019 1019 - indio_dev->modes = INDIO_DIRECT_MODE | INDIO_BUFFER_SOFTWARE; 1020 + indio_dev->modes = INDIO_DIRECT_MODE; 1020 1021 if (id->driver_data == ina226) { 1021 1022 indio_dev->channels = ina226_channels; 1022 1023 indio_dev->num_channels = ARRAY_SIZE(ina226_channels); ··· 1027 1028 indio_dev->info = &ina219_info; 1028 1029 } 1029 1030 indio_dev->name = id->name; 1030 - indio_dev->setup_ops = &ina2xx_setup_ops; 1031 1031 1032 - buffer = devm_iio_kfifo_allocate(&indio_dev->dev); 1033 - if (!buffer) 1034 - return -ENOMEM; 1035 - 1036 - iio_device_attach_buffer(indio_dev, buffer); 1032 + ret = devm_iio_kfifo_buffer_setup(&client->dev, indio_dev, 1033 + INDIO_BUFFER_SOFTWARE, 1034 + &ina2xx_setup_ops); 1035 + if (ret) 1036 + return ret; 1037 1037 1038 1038 return iio_device_register(indio_dev); 1039 1039 }
+5 -13
drivers/iio/adc/ti_am335x_adc.c
··· 385 385 unsigned long flags, 386 386 const struct iio_buffer_setup_ops *setup_ops) 387 387 { 388 - struct iio_buffer *buffer; 389 388 int ret; 390 389 391 - buffer = devm_iio_kfifo_allocate(dev); 392 - if (!buffer) 393 - return -ENOMEM; 394 - 395 - iio_device_attach_buffer(indio_dev, buffer); 396 - 397 - ret = devm_request_threaded_irq(dev, irq, pollfunc_th, pollfunc_bh, 398 - flags, indio_dev->name, indio_dev); 390 + ret = devm_iio_kfifo_buffer_setup(dev, indio_dev, 391 + INDIO_BUFFER_SOFTWARE, 392 + setup_ops); 399 393 if (ret) 400 394 return ret; 401 395 402 - indio_dev->setup_ops = setup_ops; 403 - indio_dev->modes |= INDIO_BUFFER_SOFTWARE; 404 - 405 - return 0; 396 + return devm_request_threaded_irq(dev, irq, pollfunc_th, pollfunc_bh, 397 + flags, indio_dev->name, indio_dev); 406 398 } 407 399 408 400 static const char * const chan_name_ain[] = {
+5 -8
drivers/iio/common/cros_ec_sensors/cros_ec_sensors_core.c
··· 334 334 * We can not use trigger here, as events are generated 335 335 * as soon as sample_frequency is set. 336 336 */ 337 - struct iio_buffer *buffer; 338 - 339 - buffer = devm_iio_kfifo_allocate(dev); 340 - if (!buffer) 341 - return -ENOMEM; 342 - 343 - iio_device_attach_buffer(indio_dev, buffer); 344 - indio_dev->modes = INDIO_BUFFER_SOFTWARE; 337 + ret = devm_iio_kfifo_buffer_setup(dev, indio_dev, 338 + INDIO_BUFFER_SOFTWARE, 339 + NULL); 340 + if (ret) 341 + return ret; 345 342 346 343 ret = cros_ec_sensorhub_register_push_data( 347 344 sensor_hub, sensor_platform->sensor_num,
+5 -9
drivers/iio/gyro/ssp_gyro_sensor.c
··· 96 96 int ret; 97 97 struct iio_dev *indio_dev; 98 98 struct ssp_sensor_data *spd; 99 - struct iio_buffer *buffer; 100 99 101 100 indio_dev = devm_iio_device_alloc(&pdev->dev, sizeof(*spd)); 102 101 if (!indio_dev) ··· 108 109 109 110 indio_dev->name = ssp_gyro_name; 110 111 indio_dev->info = &ssp_gyro_iio_info; 111 - indio_dev->modes = INDIO_BUFFER_SOFTWARE; 112 112 indio_dev->channels = ssp_gyro_channels; 113 113 indio_dev->num_channels = ARRAY_SIZE(ssp_gyro_channels); 114 114 indio_dev->available_scan_masks = ssp_gyro_scan_mask; 115 115 116 - buffer = devm_iio_kfifo_allocate(&pdev->dev); 117 - if (!buffer) 118 - return -ENOMEM; 119 - 120 - iio_device_attach_buffer(indio_dev, buffer); 121 - 122 - indio_dev->setup_ops = &ssp_gyro_buffer_ops; 116 + ret = devm_iio_kfifo_buffer_setup(&pdev->dev, indio_dev, 117 + INDIO_BUFFER_SOFTWARE, 118 + &ssp_gyro_buffer_ops); 119 + if (ret) 120 + return ret; 123 121 124 122 platform_set_drvdata(pdev, indio_dev); 125 123
+7 -9
drivers/iio/health/max30100.c
··· 418 418 const struct i2c_device_id *id) 419 419 { 420 420 struct max30100_data *data; 421 - struct iio_buffer *buffer; 422 421 struct iio_dev *indio_dev; 423 422 int ret; 424 423 ··· 425 426 if (!indio_dev) 426 427 return -ENOMEM; 427 428 428 - buffer = devm_iio_kfifo_allocate(&client->dev); 429 - if (!buffer) 430 - return -ENOMEM; 431 - 432 - iio_device_attach_buffer(indio_dev, buffer); 433 - 434 429 indio_dev->name = MAX30100_DRV_NAME; 435 430 indio_dev->channels = max30100_channels; 436 431 indio_dev->info = &max30100_info; 437 432 indio_dev->num_channels = ARRAY_SIZE(max30100_channels); 438 433 indio_dev->available_scan_masks = max30100_scan_masks; 439 - indio_dev->modes = (INDIO_BUFFER_SOFTWARE | INDIO_DIRECT_MODE); 440 - indio_dev->setup_ops = &max30100_buffer_setup_ops; 434 + indio_dev->modes = INDIO_DIRECT_MODE; 435 + 436 + ret = devm_iio_kfifo_buffer_setup(&client->dev, indio_dev, 437 + INDIO_BUFFER_SOFTWARE, 438 + &max30100_buffer_setup_ops); 439 + if (ret) 440 + return ret; 441 441 442 442 data = iio_priv(indio_dev); 443 443 data->indio_dev = indio_dev;
+7 -9
drivers/iio/health/max30102.c
··· 506 506 const struct i2c_device_id *id) 507 507 { 508 508 struct max30102_data *data; 509 - struct iio_buffer *buffer; 510 509 struct iio_dev *indio_dev; 511 510 int ret; 512 511 unsigned int reg; ··· 514 515 if (!indio_dev) 515 516 return -ENOMEM; 516 517 517 - buffer = devm_iio_kfifo_allocate(&client->dev); 518 - if (!buffer) 519 - return -ENOMEM; 520 - 521 - iio_device_attach_buffer(indio_dev, buffer); 522 - 523 518 indio_dev->name = MAX30102_DRV_NAME; 524 519 indio_dev->info = &max30102_info; 525 - indio_dev->modes = (INDIO_BUFFER_SOFTWARE | INDIO_DIRECT_MODE); 526 - indio_dev->setup_ops = &max30102_buffer_setup_ops; 520 + indio_dev->modes = INDIO_DIRECT_MODE; 527 521 528 522 data = iio_priv(indio_dev); 529 523 data->indio_dev = indio_dev; ··· 540 548 default: 541 549 return -ENODEV; 542 550 } 551 + 552 + ret = devm_iio_kfifo_buffer_setup(&client->dev, indio_dev, 553 + INDIO_BUFFER_SOFTWARE, 554 + &max30102_buffer_setup_ops); 555 + if (ret) 556 + return ret; 543 557 544 558 data->regmap = devm_regmap_init_i2c(client, &max30102_regmap_config); 545 559 if (IS_ERR(data->regmap)) {
+6 -8
drivers/iio/imu/inv_icm42600/inv_icm42600_accel.c
··· 709 709 const char *name; 710 710 struct inv_icm42600_timestamp *ts; 711 711 struct iio_dev *indio_dev; 712 - struct iio_buffer *buffer; 713 712 int ret; 714 713 715 714 name = devm_kasprintf(dev, GFP_KERNEL, "%s-accel", st->name); ··· 719 720 if (!indio_dev) 720 721 return ERR_PTR(-ENOMEM); 721 722 722 - buffer = devm_iio_kfifo_allocate(dev); 723 - if (!buffer) 724 - return ERR_PTR(-ENOMEM); 725 - 726 723 ts = iio_priv(indio_dev); 727 724 inv_icm42600_timestamp_init(ts, inv_icm42600_odr_to_period(st->conf.accel.odr)); 728 725 729 726 iio_device_set_drvdata(indio_dev, st); 730 727 indio_dev->name = name; 731 728 indio_dev->info = &inv_icm42600_accel_info; 732 - indio_dev->modes = INDIO_DIRECT_MODE | INDIO_BUFFER_SOFTWARE; 729 + indio_dev->modes = INDIO_DIRECT_MODE; 733 730 indio_dev->channels = inv_icm42600_accel_channels; 734 731 indio_dev->num_channels = ARRAY_SIZE(inv_icm42600_accel_channels); 735 732 indio_dev->available_scan_masks = inv_icm42600_accel_scan_masks; 736 - indio_dev->setup_ops = &inv_icm42600_buffer_ops; 737 733 738 - iio_device_attach_buffer(indio_dev, buffer); 734 + ret = devm_iio_kfifo_buffer_setup(dev, indio_dev, 735 + INDIO_BUFFER_SOFTWARE, 736 + &inv_icm42600_buffer_ops); 737 + if (ret) 738 + return ERR_PTR(ret); 739 739 740 740 ret = devm_iio_device_register(dev, indio_dev); 741 741 if (ret)
+6 -7
drivers/iio/imu/inv_icm42600/inv_icm42600_gyro.c
··· 720 720 const char *name; 721 721 struct inv_icm42600_timestamp *ts; 722 722 struct iio_dev *indio_dev; 723 - struct iio_buffer *buffer; 724 723 int ret; 725 724 726 725 name = devm_kasprintf(dev, GFP_KERNEL, "%s-gyro", st->name); ··· 730 731 if (!indio_dev) 731 732 return ERR_PTR(-ENOMEM); 732 733 733 - buffer = devm_iio_kfifo_allocate(dev); 734 - if (!buffer) 735 - return ERR_PTR(-ENOMEM); 736 - 737 734 ts = iio_priv(indio_dev); 738 735 inv_icm42600_timestamp_init(ts, inv_icm42600_odr_to_period(st->conf.gyro.odr)); 739 736 740 737 iio_device_set_drvdata(indio_dev, st); 741 738 indio_dev->name = name; 742 739 indio_dev->info = &inv_icm42600_gyro_info; 743 - indio_dev->modes = INDIO_DIRECT_MODE | INDIO_BUFFER_SOFTWARE; 740 + indio_dev->modes = INDIO_DIRECT_MODE; 744 741 indio_dev->channels = inv_icm42600_gyro_channels; 745 742 indio_dev->num_channels = ARRAY_SIZE(inv_icm42600_gyro_channels); 746 743 indio_dev->available_scan_masks = inv_icm42600_gyro_scan_masks; 747 744 indio_dev->setup_ops = &inv_icm42600_buffer_ops; 748 745 749 - iio_device_attach_buffer(indio_dev, buffer); 746 + ret = devm_iio_kfifo_buffer_setup(dev, indio_dev, 747 + INDIO_BUFFER_SOFTWARE, 748 + &inv_icm42600_buffer_ops); 749 + if (ret) 750 + return ERR_PTR(ret); 750 751 751 752 ret = devm_iio_device_register(dev, indio_dev); 752 753 if (ret)
+6 -9
drivers/iio/imu/st_lsm6dsx/st_lsm6dsx_buffer.c
··· 739 739 740 740 int st_lsm6dsx_fifo_setup(struct st_lsm6dsx_hw *hw) 741 741 { 742 - struct iio_buffer *buffer; 743 - int i; 742 + int i, ret; 744 743 745 744 for (i = 0; i < ST_LSM6DSX_ID_MAX; i++) { 746 745 if (!hw->iio_devs[i]) 747 746 continue; 748 747 749 - buffer = devm_iio_kfifo_allocate(hw->dev); 750 - if (!buffer) 751 - return -ENOMEM; 752 - 753 - iio_device_attach_buffer(hw->iio_devs[i], buffer); 754 - hw->iio_devs[i]->modes |= INDIO_BUFFER_SOFTWARE; 755 - hw->iio_devs[i]->setup_ops = &st_lsm6dsx_buffer_ops; 748 + ret = devm_iio_kfifo_buffer_setup(hw->dev, hw->iio_devs[i], 749 + INDIO_BUFFER_SOFTWARE, 750 + &st_lsm6dsx_buffer_ops); 751 + if (ret) 752 + return ret; 756 753 } 757 754 758 755 return 0;
+5 -7
drivers/iio/light/acpi-als.c
··· 165 165 { 166 166 struct acpi_als *als; 167 167 struct iio_dev *indio_dev; 168 - struct iio_buffer *buffer; 168 + int ret; 169 169 170 170 indio_dev = devm_iio_device_alloc(&device->dev, sizeof(*als)); 171 171 if (!indio_dev) ··· 179 179 180 180 indio_dev->name = ACPI_ALS_DEVICE_NAME; 181 181 indio_dev->info = &acpi_als_info; 182 - indio_dev->modes = INDIO_BUFFER_SOFTWARE; 183 182 indio_dev->channels = acpi_als_channels; 184 183 indio_dev->num_channels = ARRAY_SIZE(acpi_als_channels); 185 184 186 - buffer = devm_iio_kfifo_allocate(&device->dev); 187 - if (!buffer) 188 - return -ENOMEM; 189 - 190 - iio_device_attach_buffer(indio_dev, buffer); 185 + ret = devm_iio_kfifo_buffer_setup(&device->dev, indio_dev, 186 + INDIO_BUFFER_SOFTWARE, NULL); 187 + if (ret) 188 + return ret; 191 189 192 190 return devm_iio_device_register(&device->dev, indio_dev); 193 191 }
+7 -9
drivers/iio/light/apds9960.c
··· 988 988 const struct i2c_device_id *id) 989 989 { 990 990 struct apds9960_data *data; 991 - struct iio_buffer *buffer; 992 991 struct iio_dev *indio_dev; 993 992 int ret; 994 993 ··· 995 996 if (!indio_dev) 996 997 return -ENOMEM; 997 998 998 - buffer = devm_iio_kfifo_allocate(&client->dev); 999 - if (!buffer) 1000 - return -ENOMEM; 1001 - 1002 - iio_device_attach_buffer(indio_dev, buffer); 1003 - 1004 999 indio_dev->info = &apds9960_info; 1005 1000 indio_dev->name = APDS9960_DRV_NAME; 1006 1001 indio_dev->channels = apds9960_channels; 1007 1002 indio_dev->num_channels = ARRAY_SIZE(apds9960_channels); 1008 1003 indio_dev->available_scan_masks = apds9960_scan_masks; 1009 - indio_dev->modes = (INDIO_BUFFER_SOFTWARE | INDIO_DIRECT_MODE); 1010 - indio_dev->setup_ops = &apds9960_buffer_setup_ops; 1004 + indio_dev->modes = INDIO_DIRECT_MODE; 1005 + 1006 + ret = devm_iio_kfifo_buffer_setup(&client->dev, indio_dev, 1007 + INDIO_BUFFER_SOFTWARE, 1008 + &apds9960_buffer_setup_ops); 1009 + if (ret) 1010 + return ret; 1011 1011 1012 1012 data = iio_priv(indio_dev); 1013 1013 i2c_set_clientdata(client, indio_dev);
+4 -19
drivers/staging/iio/impedance-analyzer/ad5933.c
··· 602 602 .postdisable = ad5933_ring_postdisable, 603 603 }; 604 604 605 - static int ad5933_register_ring_funcs_and_init(struct device *dev, 606 - struct iio_dev *indio_dev) 607 - { 608 - struct iio_buffer *buffer; 609 - 610 - buffer = devm_iio_kfifo_allocate(dev); 611 - if (!buffer) 612 - return -ENOMEM; 613 - 614 - iio_device_attach_buffer(indio_dev, buffer); 615 - 616 - /* Ring buffer functions - here trigger setup related */ 617 - indio_dev->setup_ops = &ad5933_ring_setup_ops; 618 - 619 - return 0; 620 - } 621 - 622 605 static void ad5933_work(struct work_struct *work) 623 606 { 624 607 struct ad5933_state *st = container_of(work, ··· 744 761 745 762 indio_dev->info = &ad5933_info; 746 763 indio_dev->name = id->name; 747 - indio_dev->modes = (INDIO_BUFFER_SOFTWARE | INDIO_DIRECT_MODE); 764 + indio_dev->modes = INDIO_DIRECT_MODE; 748 765 indio_dev->channels = ad5933_channels; 749 766 indio_dev->num_channels = ARRAY_SIZE(ad5933_channels); 750 767 751 - ret = ad5933_register_ring_funcs_and_init(&client->dev, indio_dev); 768 + ret = devm_iio_kfifo_buffer_setup(&client->dev, indio_dev, 769 + INDIO_BUFFER_SOFTWARE, 770 + &ad5933_ring_setup_ops); 752 771 if (ret) 753 772 return ret; 754 773