Input: qt2160 - convert to use devm_* api

Use devm_* api to simplify code, this makes it unnecessary to explicitly
release resources.

Signed-off-by: Yangtao Li <frank.li@vivo.com>
Link: https://lore.kernel.org/r/20230714080611.81302-7-frank.li@vivo.com
Link: https://lore.kernel.org/r/20230724051345.335219-4-dmitry.torokhov@gmail.com
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
This commit is contained in:
Yangtao Li 2023-07-23 22:13:42 -07:00 committed by Dmitry Torokhov
parent d675c9b573
commit 3e4bb047b2

View file

@ -239,7 +239,7 @@ static int qt2160_write(struct i2c_client *client, u8 reg, u8 data)
static int qt2160_register_leds(struct qt2160_data *qt2160) static int qt2160_register_leds(struct qt2160_data *qt2160)
{ {
struct i2c_client *client = qt2160->client; struct i2c_client *client = qt2160->client;
int ret; int error;
int i; int i;
for (i = 0; i < QT2160_NUM_LEDS_X; i++) { for (i = 0; i < QT2160_NUM_LEDS_X; i++) {
@ -252,9 +252,9 @@ static int qt2160_register_leds(struct qt2160_data *qt2160)
led->id = i; led->id = i;
led->qt2160 = qt2160; led->qt2160 = qt2160;
ret = led_classdev_register(&client->dev, &led->cdev); error = devm_led_classdev_register(&client->dev, &led->cdev);
if (ret < 0) if (error)
return ret; return error;
} }
/* Tur off LEDs */ /* Tur off LEDs */
@ -265,14 +265,6 @@ static int qt2160_register_leds(struct qt2160_data *qt2160)
return 0; return 0;
} }
static void qt2160_unregister_leds(struct qt2160_data *qt2160)
{
int i;
for (i = 0; i < QT2160_NUM_LEDS_X; i++)
led_classdev_unregister(&qt2160->leds[i].cdev);
}
#else #else
static inline int qt2160_register_leds(struct qt2160_data *qt2160) static inline int qt2160_register_leds(struct qt2160_data *qt2160)
@ -280,10 +272,6 @@ static inline int qt2160_register_leds(struct qt2160_data *qt2160)
return 0; return 0;
} }
static inline void qt2160_unregister_leds(struct qt2160_data *qt2160)
{
}
#endif #endif
static bool qt2160_identify(struct i2c_client *client) static bool qt2160_identify(struct i2c_client *client)
@ -334,13 +322,13 @@ static int qt2160_probe(struct i2c_client *client)
return -ENODEV; return -ENODEV;
/* Chip is valid and active. Allocate structure */ /* Chip is valid and active. Allocate structure */
qt2160 = kzalloc(sizeof(struct qt2160_data), GFP_KERNEL); qt2160 = devm_kzalloc(&client->dev, sizeof(*qt2160), GFP_KERNEL);
input = input_allocate_device(); if (!qt2160)
if (!qt2160 || !input) { return -ENOMEM;
dev_err(&client->dev, "insufficient memory\n");
error = -ENOMEM; input = devm_input_allocate_device(&client->dev);
goto err_free_mem; if (!input)
} return -ENOMEM;
qt2160->client = client; qt2160->client = client;
qt2160->input = input; qt2160->input = input;
@ -366,22 +354,24 @@ static int qt2160_probe(struct i2c_client *client)
error = qt2160_write(client, QT2160_CMD_CALIBRATE, 1); error = qt2160_write(client, QT2160_CMD_CALIBRATE, 1);
if (error) { if (error) {
dev_err(&client->dev, "failed to calibrate device\n"); dev_err(&client->dev, "failed to calibrate device\n");
goto err_free_mem; return error;
} }
if (client->irq) { if (client->irq) {
error = request_threaded_irq(client->irq, NULL, qt2160_irq, error = devm_request_threaded_irq(&client->dev, client->irq,
IRQF_ONESHOT, "qt2160", input); NULL, qt2160_irq,
IRQF_ONESHOT,
"qt2160", input);
if (error) { if (error) {
dev_err(&client->dev, dev_err(&client->dev,
"failed to allocate irq %d\n", client->irq); "failed to allocate irq %d\n", client->irq);
goto err_free_mem; return error;
} }
} else { } else {
error = input_setup_polling(input, qt2160_get_key_matrix); error = input_setup_polling(input, qt2160_get_key_matrix);
if (error) { if (error) {
dev_err(&client->dev, "Failed to setup polling\n"); dev_err(&client->dev, "Failed to setup polling\n");
goto err_free_mem; return error;
} }
input_set_poll_interval(input, QT2160_CYCLE_INTERVAL); input_set_poll_interval(input, QT2160_CYCLE_INTERVAL);
} }
@ -389,43 +379,17 @@ static int qt2160_probe(struct i2c_client *client)
error = qt2160_register_leds(qt2160); error = qt2160_register_leds(qt2160);
if (error) { if (error) {
dev_err(&client->dev, "Failed to register leds\n"); dev_err(&client->dev, "Failed to register leds\n");
goto err_free_irq; return error;
} }
error = input_register_device(qt2160->input); error = input_register_device(qt2160->input);
if (error) { if (error) {
dev_err(&client->dev, dev_err(&client->dev,
"Failed to register input device\n"); "Failed to register input device\n");
goto err_unregister_leds; return error;
} }
i2c_set_clientdata(client, qt2160);
return 0; return 0;
err_unregister_leds:
qt2160_unregister_leds(qt2160);
err_free_irq:
if (client->irq)
free_irq(client->irq, qt2160);
err_free_mem:
input_free_device(input);
kfree(qt2160);
return error;
}
static void qt2160_remove(struct i2c_client *client)
{
struct qt2160_data *qt2160 = i2c_get_clientdata(client);
qt2160_unregister_leds(qt2160);
/* Release IRQ so no queue will be scheduled */
if (client->irq)
free_irq(client->irq, qt2160);
input_unregister_device(qt2160->input);
kfree(qt2160);
} }
static const struct i2c_device_id qt2160_idtable[] = { static const struct i2c_device_id qt2160_idtable[] = {
@ -442,7 +406,6 @@ static struct i2c_driver qt2160_driver = {
.id_table = qt2160_idtable, .id_table = qt2160_idtable,
.probe = qt2160_probe, .probe = qt2160_probe,
.remove = qt2160_remove,
}; };
module_i2c_driver(qt2160_driver); module_i2c_driver(qt2160_driver);