Commit fbae3fb1 authored by Wolfram Sang's avatar Wolfram Sang Committed by Jean Delvare
Browse files

i2c: Remove all i2c_set_clientdata(client, NULL) in drivers

I2C drivers can use the clientdata-pointer to point to private data. As I2C
devices are not really unregistered, but merely detached from their driver, it
used to be the drivers obligation to clear this pointer during remove() or a
failed probe(). As a couple of drivers forgot to do this, it was agreed that it
was cleaner if the i2c-core does this clearance when appropriate, as there is
no guarantee for the lifetime of the clientdata-pointer after remove() anyhow.
This feature was added to the core with commit
e4a7b9b0

 to fix the faulty drivers.

As there is no need anymore to clear the clientdata-pointer, remove all current
occurrences in the drivers to simplify the code and prevent confusion.
Signed-off-by: default avatarWolfram Sang <w.sang@pengutronix.de>
Acked-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
Acked-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
Acked-by: default avatarRichard Purdie <rpurdie@linux.intel.com>
Acked-by: default avatarDmitry Torokhov <dtor@mail.ru>
Signed-off-by: default avatarJean Delvare <khali@linux-fr.org>
parent 35bfc353
...@@ -316,7 +316,6 @@ static int __devinit adt7411_probe(struct i2c_client *client, ...@@ -316,7 +316,6 @@ static int __devinit adt7411_probe(struct i2c_client *client,
exit_remove: exit_remove:
sysfs_remove_group(&client->dev.kobj, &adt7411_attr_grp); sysfs_remove_group(&client->dev.kobj, &adt7411_attr_grp);
exit_free: exit_free:
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return ret; return ret;
} }
...@@ -327,7 +326,6 @@ static int __devexit adt7411_remove(struct i2c_client *client) ...@@ -327,7 +326,6 @@ static int __devexit adt7411_remove(struct i2c_client *client)
hwmon_device_unregister(data->hwmon_dev); hwmon_device_unregister(data->hwmon_dev);
sysfs_remove_group(&client->dev.kobj, &adt7411_attr_grp); sysfs_remove_group(&client->dev.kobj, &adt7411_attr_grp);
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return 0; return 0;
} }
......
...@@ -1141,7 +1141,6 @@ exit_remove: ...@@ -1141,7 +1141,6 @@ exit_remove:
&(asc7621_params[i].sda.dev_attr)); &(asc7621_params[i].sda.dev_attr));
} }
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return err; return err;
} }
...@@ -1196,7 +1195,6 @@ static int asc7621_remove(struct i2c_client *client) ...@@ -1196,7 +1195,6 @@ static int asc7621_remove(struct i2c_client *client)
&(asc7621_params[i].sda.dev_attr)); &(asc7621_params[i].sda.dev_attr));
} }
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return 0; return 0;
} }
......
...@@ -662,7 +662,6 @@ exit_remove: ...@@ -662,7 +662,6 @@ exit_remove:
sysfs_remove_group(&client->dev.kobj, &f75375_group); sysfs_remove_group(&client->dev.kobj, &f75375_group);
exit_free: exit_free:
kfree(data); kfree(data);
i2c_set_clientdata(client, NULL);
return err; return err;
} }
...@@ -672,7 +671,6 @@ static int f75375_remove(struct i2c_client *client) ...@@ -672,7 +671,6 @@ static int f75375_remove(struct i2c_client *client)
hwmon_device_unregister(data->hwmon_dev); hwmon_device_unregister(data->hwmon_dev);
sysfs_remove_group(&client->dev.kobj, &f75375_group); sysfs_remove_group(&client->dev.kobj, &f75375_group);
kfree(data); kfree(data);
i2c_set_clientdata(client, NULL);
return 0; return 0;
} }
......
...@@ -236,7 +236,6 @@ error_hwmon_device_register: ...@@ -236,7 +236,6 @@ error_hwmon_device_register:
sysfs_remove_group(&client->dev.kobj, &g760a_group); sysfs_remove_group(&client->dev.kobj, &g760a_group);
error_sysfs_create_group: error_sysfs_create_group:
kfree(data); kfree(data);
i2c_set_clientdata(client, NULL);
return err; return err;
} }
...@@ -247,7 +246,6 @@ static int g760a_remove(struct i2c_client *client) ...@@ -247,7 +246,6 @@ static int g760a_remove(struct i2c_client *client)
hwmon_device_unregister(data->hwmon_dev); hwmon_device_unregister(data->hwmon_dev);
sysfs_remove_group(&client->dev.kobj, &g760a_group); sysfs_remove_group(&client->dev.kobj, &g760a_group);
kfree(data); kfree(data);
i2c_set_clientdata(client, NULL);
return 0; return 0;
} }
......
...@@ -136,7 +136,6 @@ static int lm73_remove(struct i2c_client *client) ...@@ -136,7 +136,6 @@ static int lm73_remove(struct i2c_client *client)
hwmon_device_unregister(hwmon_dev); hwmon_device_unregister(hwmon_dev);
sysfs_remove_group(&client->dev.kobj, &lm73_group); sysfs_remove_group(&client->dev.kobj, &lm73_group);
i2c_set_clientdata(client, NULL);
return 0; return 0;
} }
......
...@@ -192,7 +192,6 @@ lm75_probe(struct i2c_client *client, const struct i2c_device_id *id) ...@@ -192,7 +192,6 @@ lm75_probe(struct i2c_client *client, const struct i2c_device_id *id)
exit_remove: exit_remove:
sysfs_remove_group(&client->dev.kobj, &lm75_group); sysfs_remove_group(&client->dev.kobj, &lm75_group);
exit_free: exit_free:
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return status; return status;
} }
...@@ -204,7 +203,6 @@ static int lm75_remove(struct i2c_client *client) ...@@ -204,7 +203,6 @@ static int lm75_remove(struct i2c_client *client)
hwmon_device_unregister(data->hwmon_dev); hwmon_device_unregister(data->hwmon_dev);
sysfs_remove_group(&client->dev.kobj, &lm75_group); sysfs_remove_group(&client->dev.kobj, &lm75_group);
lm75_write_value(client, LM75_REG_CONF, data->orig_conf); lm75_write_value(client, LM75_REG_CONF, data->orig_conf);
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return 0; return 0;
} }
......
...@@ -399,7 +399,6 @@ static int lm95241_remove(struct i2c_client *client) ...@@ -399,7 +399,6 @@ static int lm95241_remove(struct i2c_client *client)
hwmon_device_unregister(data->hwmon_dev); hwmon_device_unregister(data->hwmon_dev);
sysfs_remove_group(&client->dev.kobj, &lm95241_group); sysfs_remove_group(&client->dev.kobj, &lm95241_group);
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return 0; return 0;
} }
......
...@@ -224,7 +224,6 @@ fail_remove_sysfs: ...@@ -224,7 +224,6 @@ fail_remove_sysfs:
fail_restore_config: fail_restore_config:
tmp102_write_reg(client, TMP102_CONF_REG, tmp102->config_orig); tmp102_write_reg(client, TMP102_CONF_REG, tmp102->config_orig);
fail_free: fail_free:
i2c_set_clientdata(client, NULL);
kfree(tmp102); kfree(tmp102);
return status; return status;
...@@ -247,7 +246,6 @@ static int __devexit tmp102_remove(struct i2c_client *client) ...@@ -247,7 +246,6 @@ static int __devexit tmp102_remove(struct i2c_client *client)
config | TMP102_CONF_SD); config | TMP102_CONF_SD);
} }
i2c_set_clientdata(client, NULL);
kfree(tmp102); kfree(tmp102);
return 0; return 0;
......
...@@ -295,7 +295,6 @@ exit_remove: ...@@ -295,7 +295,6 @@ exit_remove:
sysfs_remove_group(&client->dev.kobj, &tmp421_group); sysfs_remove_group(&client->dev.kobj, &tmp421_group);
exit_free: exit_free:
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return err; return err;
...@@ -308,7 +307,6 @@ static int tmp421_remove(struct i2c_client *client) ...@@ -308,7 +307,6 @@ static int tmp421_remove(struct i2c_client *client)
hwmon_device_unregister(data->hwmon_dev); hwmon_device_unregister(data->hwmon_dev);
sysfs_remove_group(&client->dev.kobj, &tmp421_group); sysfs_remove_group(&client->dev.kobj, &tmp421_group);
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return 0; return 0;
......
...@@ -1197,7 +1197,6 @@ ERROR4: ...@@ -1197,7 +1197,6 @@ ERROR4:
if (data->lm75[1]) if (data->lm75[1])
i2c_unregister_device(data->lm75[1]); i2c_unregister_device(data->lm75[1]);
ERROR3: ERROR3:
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
ERROR1: ERROR1:
return err; return err;
...@@ -1219,7 +1218,6 @@ w83781d_remove(struct i2c_client *client) ...@@ -1219,7 +1218,6 @@ w83781d_remove(struct i2c_client *client)
if (data->lm75[1]) if (data->lm75[1])
i2c_unregister_device(data->lm75[1]); i2c_unregister_device(data->lm75[1]);
i2c_set_clientdata(client, NULL);
kfree(data); kfree(data);
return 0; return 0;
......
...@@ -173,7 +173,6 @@ static int smbalert_remove(struct i2c_client *ara) ...@@ -173,7 +173,6 @@ static int smbalert_remove(struct i2c_client *ara)
cancel_work_sync(&alert->alert); cancel_work_sync(&alert->alert);
i2c_set_clientdata(ara, NULL);
kfree(alert); kfree(alert);
return 0; return 0;
} }
......
...@@ -287,7 +287,6 @@ static int __devexit adp5588_remove(struct i2c_client *client) ...@@ -287,7 +287,6 @@ static int __devexit adp5588_remove(struct i2c_client *client)
free_irq(client->irq, kpad); free_irq(client->irq, kpad);
cancel_delayed_work_sync(&kpad->work); cancel_delayed_work_sync(&kpad->work);
input_unregister_device(kpad->input); input_unregister_device(kpad->input);
i2c_set_clientdata(client, NULL);
kfree(kpad); kfree(kpad);
return 0; return 0;
......
...@@ -778,8 +778,6 @@ static int __devexit lm8323_remove(struct i2c_client *client) ...@@ -778,8 +778,6 @@ static int __devexit lm8323_remove(struct i2c_client *client)
struct lm8323_chip *lm = i2c_get_clientdata(client); struct lm8323_chip *lm = i2c_get_clientdata(client);
int i; int i;
i2c_set_clientdata(client, NULL);
disable_irq_wake(client->irq); disable_irq_wake(client->irq);
free_irq(client->irq, lm); free_irq(client->irq, lm);
cancel_work_sync(&lm->work); cancel_work_sync(&lm->work);
......
...@@ -265,7 +265,6 @@ static int __devexit max7359_remove(struct i2c_client *client) ...@@ -265,7 +265,6 @@ static int __devexit max7359_remove(struct i2c_client *client)
free_irq(client->irq, keypad); free_irq(client->irq, keypad);
input_unregister_device(keypad->input_dev); input_unregister_device(keypad->input_dev);
i2c_set_clientdata(client, NULL);
kfree(keypad); kfree(keypad);
return 0; return 0;
......
...@@ -358,7 +358,6 @@ static int __devexit qt2160_remove(struct i2c_client *client) ...@@ -358,7 +358,6 @@ static int __devexit qt2160_remove(struct i2c_client *client)
input_unregister_device(qt2160->input); input_unregister_device(qt2160->input);
kfree(qt2160); kfree(qt2160);
i2c_set_clientdata(client, NULL);
return 0; return 0;
} }
......
...@@ -316,8 +316,6 @@ static int __devexit tca6416_keypad_remove(struct i2c_client *client) ...@@ -316,8 +316,6 @@ static int __devexit tca6416_keypad_remove(struct i2c_client *client)
input_unregister_device(chip->input); input_unregister_device(chip->input);
kfree(chip); kfree(chip);
i2c_set_clientdata(client, NULL);
return 0; return 0;
} }
......
...@@ -97,7 +97,6 @@ static int __devexit ad714x_i2c_remove(struct i2c_client *client) ...@@ -97,7 +97,6 @@ static int __devexit ad714x_i2c_remove(struct i2c_client *client)
struct ad714x_chip *chip = i2c_get_clientdata(client); struct ad714x_chip *chip = i2c_get_clientdata(client);
ad714x_remove(chip); ad714x_remove(chip);
i2c_set_clientdata(client, NULL);
return 0; return 0;
} }
......
...@@ -168,8 +168,6 @@ static int __devexit pcf8574_kp_remove(struct i2c_client *client) ...@@ -168,8 +168,6 @@ static int __devexit pcf8574_kp_remove(struct i2c_client *client)
input_unregister_device(lp->idev); input_unregister_device(lp->idev);
kfree(lp); kfree(lp);
i2c_set_clientdata(client, NULL);
return 0; return 0;
} }
......
...@@ -613,7 +613,6 @@ static int __devexit synaptics_i2c_remove(struct i2c_client *client) ...@@ -613,7 +613,6 @@ static int __devexit synaptics_i2c_remove(struct i2c_client *client)
free_irq(client->irq, touch); free_irq(client->irq, touch);
input_unregister_device(touch->input); input_unregister_device(touch->input);
i2c_set_clientdata(client, NULL);
kfree(touch); kfree(touch);
return 0; return 0;
......
...@@ -812,10 +812,8 @@ static int __devinit ad7879_probe(struct i2c_client *client, ...@@ -812,10 +812,8 @@ static int __devinit ad7879_probe(struct i2c_client *client,
ts->bus = client; ts->bus = client;
error = ad7879_construct(client, ts); error = ad7879_construct(client, ts);
if (error) { if (error)
i2c_set_clientdata(client, NULL);
kfree(ts); kfree(ts);
}
return error; return error;
} }
...@@ -825,7 +823,6 @@ static int __devexit ad7879_remove(struct i2c_client *client) ...@@ -825,7 +823,6 @@ static int __devexit ad7879_remove(struct i2c_client *client)
struct ad7879 *ts = dev_get_drvdata(&client->dev); struct ad7879 *ts = dev_get_drvdata(&client->dev);
ad7879_destroy(client, ts); ad7879_destroy(client, ts);
i2c_set_clientdata(client, NULL);
kfree(ts); kfree(ts);
return 0; return 0;
......
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