From d95c12848d20942772460f8c310c76a5f86f4e6d Mon Sep 17 00:00:00 2001 From: Fabio Baltieri Date: Tue, 18 Jul 2023 11:28:40 +0000 Subject: [PATCH] drivers: input: add few missing gpio_add_callback return check Add few missing check on gpio_add_callback and gpio_add_callback_dt calls, fixes a coverity warning. Signed-off-by: Fabio Baltieri --- drivers/input/input_gpio_qdec.c | 6 +++++- drivers/input/input_gt911.c | 6 +++++- drivers/input/input_xpt2046.c | 8 +++++++- 3 files changed, 17 insertions(+), 3 deletions(-) diff --git a/drivers/input/input_gpio_qdec.c b/drivers/input/input_gpio_qdec.c index 85716fdcc1..88d403cdc5 100644 --- a/drivers/input/input_gpio_qdec.c +++ b/drivers/input/input_gpio_qdec.c @@ -204,7 +204,11 @@ static int gpio_qdec_init(const struct device *dev) return ret; } - gpio_add_callback_dt(gpio, &data->gpio_cb); + ret = gpio_add_callback_dt(gpio, &data->gpio_cb); + if (ret < 0) { + LOG_ERR("Could not set gpio callback"); + return ret; + } } data->prev_step = gpio_qdec_get_step(dev); diff --git a/drivers/input/input_gt911.c b/drivers/input/input_gt911.c index a13586caf8..99468b4ed3 100644 --- a/drivers/input/input_gt911.c +++ b/drivers/input/input_gt911.c @@ -343,7 +343,11 @@ static int gt911_init(const struct device *dev) } #ifdef CONFIG_INPUT_GT911_INTERRUPT - gpio_add_callback(config->int_gpio.port, &data->int_gpio_cb); + r = gpio_add_callback(config->int_gpio.port, &data->int_gpio_cb); + if (r < 0) { + LOG_ERR("Could not set gpio callback"); + return ret; + } #else k_timer_start(&data->timer, K_MSEC(CONFIG_INPUT_GT911_PERIOD_MS), K_MSEC(CONFIG_INPUT_GT911_PERIOD_MS)); diff --git a/drivers/input/input_xpt2046.c b/drivers/input/input_xpt2046.c index 4c4f4c514b..6e56fcb587 100644 --- a/drivers/input/input_xpt2046.c +++ b/drivers/input/input_xpt2046.c @@ -125,6 +125,7 @@ static void xpt2046_work_handler(struct k_work *kw) { struct xpt2046_data *data = CONTAINER_OF(kw, struct xpt2046_data, work); struct xpt2046_config *config = (struct xpt2046_config *)data->dev->config; + int ret; const struct spi_buf txb = {.buf = tbuf, .len = sizeof(tbuf)}; const struct spi_buf rxb = {.buf = data->rbuf, .len = sizeof(data->rbuf)}; @@ -180,7 +181,12 @@ static void xpt2046_work_handler(struct k_work *kw) /* Ensure that we send released event */ k_work_reschedule(&data->dwork, K_MSEC(100)); } - gpio_add_callback(config->int_gpio.port, &data->int_gpio_cb); + + ret = gpio_add_callback(config->int_gpio.port, &data->int_gpio_cb); + if (ret < 0) { + LOG_ERR("Could not set gpio callback"); + return; + } } static int xpt2046_init(const struct device *dev)