drm/radeon: switch to a finer grained reset for evergreen
[linux-3.10.git] / drivers / i2c / i2c-smbus.c
index 9836d08..92cdd23 100644 (file)
@@ -142,7 +142,8 @@ static int smbalert_probe(struct i2c_client *ara,
        struct i2c_adapter *adapter = ara->adapter;
        int res;
 
-       alert = kzalloc(sizeof(struct i2c_smbus_alert), GFP_KERNEL);
+       alert = devm_kzalloc(&ara->dev, sizeof(struct i2c_smbus_alert),
+                            GFP_KERNEL);
        if (!alert)
                return -ENOMEM;
 
@@ -154,10 +155,8 @@ static int smbalert_probe(struct i2c_client *ara,
        if (setup->irq > 0) {
                res = devm_request_irq(&ara->dev, setup->irq, smbalert_irq,
                                       0, "smbus_alert", alert);
-               if (res) {
-                       kfree(alert);
+               if (res)
                        return res;
-               }
        }
 
        i2c_set_clientdata(ara, alert);
@@ -167,14 +166,12 @@ static int smbalert_probe(struct i2c_client *ara,
        return 0;
 }
 
-/* IRQ resource is managed so it is freed automatically */
+/* IRQ and memory resources are managed so they are freed automatically */
 static int smbalert_remove(struct i2c_client *ara)
 {
        struct i2c_smbus_alert *alert = i2c_get_clientdata(ara);
 
        cancel_work_sync(&alert->alert);
-
-       kfree(alert);
        return 0;
 }
 
@@ -245,18 +242,7 @@ int i2c_handle_smbus_alert(struct i2c_client *ara)
 }
 EXPORT_SYMBOL_GPL(i2c_handle_smbus_alert);
 
-static int __init i2c_smbus_init(void)
-{
-       return i2c_add_driver(&smbalert_driver);
-}
-
-static void __exit i2c_smbus_exit(void)
-{
-       i2c_del_driver(&smbalert_driver);
-}
-
-module_init(i2c_smbus_init);
-module_exit(i2c_smbus_exit);
+module_i2c_driver(smbalert_driver);
 
 MODULE_AUTHOR("Jean Delvare <khali@linux-fr.org>");
 MODULE_DESCRIPTION("SMBus protocol extensions support");