Lines Matching +full:i2c +full:- +full:retry +full:- +full:count

1 // SPDX-License-Identifier: GPL-2.0-only
8 #include <linux/i2c.h>
37 * BU21023GUL/BU21023MUV/BU21024FV-M registers map
270 * rohm_i2c_burst_read - execute combined I2C message for ROHM BU21023/24
285 struct i2c_adapter *adap = client->adapter; in rohm_i2c_burst_read()
289 msg[0].addr = client->addr; in rohm_i2c_burst_read()
294 msg[1].addr = client->addr; in rohm_i2c_burst_read()
303 ret = -EIO; in rohm_i2c_burst_read()
315 struct i2c_client *client = ts->client; in rohm_ts_manual_calibration()
316 struct device *dev = &client->dev; in rohm_ts_manual_calibration()
317 u8 buf[33]; /* for PRM1_X_H(0x08)-TOUCH(0x28) */ in rohm_ts_manual_calibration()
319 int retry; in rohm_ts_manual_calibration() local
358 for (retry = 0; retry < CALIBRATION_RETRY_MAX; retry++) { in rohm_ts_manual_calibration()
362 #define READ_CALIB_BUF(reg) buf[((reg) - PRM1_X_H)] in rohm_ts_manual_calibration()
374 READ_CALIB_BUF(PRM1_X_L)) - AXIS_OFFSET; in rohm_ts_manual_calibration()
376 READ_CALIB_BUF(PRM1_Y_L)) - AXIS_OFFSET; in rohm_ts_manual_calibration()
393 calib_x -= AXIS_ADJUST; in rohm_ts_manual_calibration()
399 calib_y -= AXIS_ADJUST; in rohm_ts_manual_calibration()
504 error = -EBUSY; in rohm_ts_manual_calibration()
523 struct i2c_client *client = ts->client; in rohm_ts_soft_irq()
524 struct input_dev *input_dev = ts->input; in rohm_ts_soft_irq()
525 struct device *dev = &client->dev; in rohm_ts_soft_irq()
527 u8 buf[10]; /* for POS_X1_H(0x20)-TOUCH_GESTURE(0x29) */ in rohm_ts_soft_irq()
533 int finger_count = -1; in rohm_ts_soft_irq()
534 int prev_finger_count = ts->finger_count; in rohm_ts_soft_irq()
535 int count; in rohm_ts_soft_irq() local
548 #define READ_POS_BUF(reg) buf[((reg) - POS_X1_H)] in rohm_ts_soft_irq()
570 if (++ts->contact_count[0] >= threshold) in rohm_ts_soft_irq()
576 if (++ts->contact_count[1] >= threshold) in rohm_ts_soft_irq()
591 if (++ts->contact_count[2] >= threshold) in rohm_ts_soft_irq()
603 count = ts->contact_count[finger_count]; in rohm_ts_soft_irq()
604 memset(ts->contact_count, 0, sizeof(ts->contact_count)); in rohm_ts_soft_irq()
605 ts->contact_count[finger_count] = count; in rohm_ts_soft_irq()
625 ts->finger_count = finger_count; in rohm_ts_soft_irq()
645 struct device *dev = &client->dev; in rohm_ts_load_firmware()
648 unsigned int retry = 0; in rohm_ts_load_firmware() local
666 if (retry) { in rohm_ts_load_firmware()
669 /* settings for retry */ in rohm_ts_load_firmware()
690 len = fw->size; in rohm_ts_load_firmware()
696 xfer_len, &fw->data[offset]); in rohm_ts_load_firmware()
700 len -= xfer_len; in rohm_ts_load_firmware()
719 error = -EIO; in rohm_ts_load_firmware()
720 } while (++retry <= FIRMWARE_RETRY_MAX); in rohm_ts_load_firmware()
733 scoped_cond_guard(mutex_intr, return -EINTR, &ts->input->mutex) { in rohm_ts_update_setting()
735 ts->setup2 |= setting_bit; in rohm_ts_update_setting()
737 ts->setup2 &= ~setting_bit; in rohm_ts_update_setting()
739 if (ts->initialized) { in rohm_ts_update_setting()
740 error = i2c_smbus_write_byte_data(ts->client, in rohm_ts_update_setting()
742 ts->setup2); in rohm_ts_update_setting()
757 return sysfs_emit(buf, "%d\n", !!(ts->setup2 & SWAP_XY)); in swap_xy_show()
761 const char *buf, size_t count) in swap_xy_store() argument
773 return error ?: count; in swap_xy_store()
782 return sysfs_emit(buf, "%d\n", !!(ts->setup2 & INV_X)); in inv_x_show()
786 const char *buf, size_t count) in inv_x_store() argument
798 return error ?: count; in inv_x_store()
807 return sysfs_emit(buf, "%d\n", !!(ts->setup2 & INV_Y)); in inv_y_show()
811 const char *buf, size_t count) in inv_y_store() argument
823 return error ?: count; in inv_y_store()
840 struct device *dev = &client->dev; in rohm_ts_device_init()
843 guard(disable_irq)(&client->irq); in rohm_ts_device_init()
856 /* Waiting for the analog warm-up, max. 200usec */ in rohm_ts_device_init()
1031 dev_err(&client->dev, in rohm_ts_power_off()
1039 dev_err(&client->dev, in rohm_ts_power_off()
1048 struct i2c_client *client = ts->client; in rohm_ts_open()
1051 if (!ts->initialized) { in rohm_ts_open()
1052 error = rohm_ts_device_init(client, ts->setup2); in rohm_ts_open()
1054 dev_err(&client->dev, in rohm_ts_open()
1059 ts->initialized = true; in rohm_ts_open()
1069 rohm_ts_power_off(ts->client); in rohm_ts_close()
1071 ts->initialized = false; in rohm_ts_close()
1076 struct device *dev = &client->dev; in rohm_bu21023_i2c_probe()
1081 if (!client->irq) { in rohm_bu21023_i2c_probe()
1083 return -EINVAL; in rohm_bu21023_i2c_probe()
1086 if (!client->adapter->algo->master_xfer) { in rohm_bu21023_i2c_probe()
1087 dev_err(dev, "I2C level transfers not supported\n"); in rohm_bu21023_i2c_probe()
1088 return -EOPNOTSUPP; in rohm_bu21023_i2c_probe()
1098 return -ENOMEM; in rohm_bu21023_i2c_probe()
1100 ts->client = client; in rohm_bu21023_i2c_probe()
1101 ts->setup2 = MAF_1SAMPLE; in rohm_bu21023_i2c_probe()
1106 return -ENOMEM; in rohm_bu21023_i2c_probe()
1108 input->name = BU21023_NAME; in rohm_bu21023_i2c_probe()
1109 input->id.bustype = BUS_I2C; in rohm_bu21023_i2c_probe()
1110 input->open = rohm_ts_open; in rohm_bu21023_i2c_probe()
1111 input->close = rohm_ts_close; in rohm_bu21023_i2c_probe()
1113 ts->input = input; in rohm_bu21023_i2c_probe()
1129 error = devm_request_threaded_irq(dev, client->irq, in rohm_bu21023_i2c_probe()
1131 IRQF_ONESHOT, client->name, ts); in rohm_bu21023_i2c_probe()
1150 MODULE_DEVICE_TABLE(i2c, rohm_bu21023_i2c_id);