Commit 265d426d authored by Benjamin Tissoires's avatar Benjamin Tissoires Committed by Dmitry Torokhov

Input: elan_i2c - fix return tests of i2c_smbus_read_block_data()

i2c_smbus_read_block_data() returns negative errno else the number of
data bytes in the slave's response.

Checking for error not null means the function always fails if the device
answers properly.

So given that we read 3 bytes and access those, better check that we
actually read those 3 bytes.
Signed-off-by: default avatarBenjamin Tissoires <benjamin.tissoires@redhat.com>
Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent 979987de
...@@ -222,11 +222,13 @@ static int elan_smbus_get_checksum(struct i2c_client *client, ...@@ -222,11 +222,13 @@ static int elan_smbus_get_checksum(struct i2c_client *client,
static int elan_smbus_get_max(struct i2c_client *client, static int elan_smbus_get_max(struct i2c_client *client,
unsigned int *max_x, unsigned int *max_y) unsigned int *max_x, unsigned int *max_y)
{ {
int ret;
int error; int error;
u8 val[3]; u8 val[3];
error = i2c_smbus_read_block_data(client, ETP_SMBUS_RANGE_CMD, val); ret = i2c_smbus_read_block_data(client, ETP_SMBUS_RANGE_CMD, val);
if (error) { if (ret != 3) {
error = ret < 0 ? ret : -EIO;
dev_err(&client->dev, "failed to get dimensions: %d\n", error); dev_err(&client->dev, "failed to get dimensions: %d\n", error);
return error; return error;
} }
...@@ -240,12 +242,13 @@ static int elan_smbus_get_max(struct i2c_client *client, ...@@ -240,12 +242,13 @@ static int elan_smbus_get_max(struct i2c_client *client,
static int elan_smbus_get_resolution(struct i2c_client *client, static int elan_smbus_get_resolution(struct i2c_client *client,
u8 *hw_res_x, u8 *hw_res_y) u8 *hw_res_x, u8 *hw_res_y)
{ {
int ret;
int error; int error;
u8 val[3]; u8 val[3];
error = i2c_smbus_read_block_data(client, ret = i2c_smbus_read_block_data(client, ETP_SMBUS_RESOLUTION_CMD, val);
ETP_SMBUS_RESOLUTION_CMD, val); if (ret != 3) {
if (error) { error = ret < 0 ? ret : -EIO;
dev_err(&client->dev, "failed to get resolution: %d\n", error); dev_err(&client->dev, "failed to get resolution: %d\n", error);
return error; return error;
} }
...@@ -260,12 +263,13 @@ static int elan_smbus_get_num_traces(struct i2c_client *client, ...@@ -260,12 +263,13 @@ static int elan_smbus_get_num_traces(struct i2c_client *client,
unsigned int *x_traces, unsigned int *x_traces,
unsigned int *y_traces) unsigned int *y_traces)
{ {
int ret;
int error; int error;
u8 val[3]; u8 val[3];
error = i2c_smbus_read_block_data(client, ret = i2c_smbus_read_block_data(client, ETP_SMBUS_XY_TRACENUM_CMD, val);
ETP_SMBUS_XY_TRACENUM_CMD, val); if (ret != 3) {
if (error) { error = ret < 0 ? ret : -EIO;
dev_err(&client->dev, "failed to get trace info: %d\n", error); dev_err(&client->dev, "failed to get trace info: %d\n", error);
return error; return error;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment